home
·
contact
·
privacy
projects
/
plomrogue2
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Optimize dijkstra mapping for volume calculation.
[plomrogue2]
/
plomrogue
/
commands.py
diff --git
a/plomrogue/commands.py
b/plomrogue/commands.py
index e62d6639468d0e5606bd0bec4cbfcf77cc396a37..6c356658e20ae48c858652f353f96353d879f6b0 100644
(file)
--- a/
plomrogue/commands.py
+++ b/
plomrogue/commands.py
@@
-10,31
+10,59
@@
def cmd_TASKS(game, connection_id):
cmd_TASKS.argtypes = ''
def cmd_ALL(game, msg, connection_id):
cmd_TASKS.argtypes = ''
def cmd_ALL(game, msg, connection_id):
- import math
+
+ def lower_msg_by_volume(msg, volume):
+ lowered_msg = ''
+ for c in msg:
+ c = c
+ while random.random() > volume * 8:
+ if c.isupper():
+ c = c.lower()
+ elif c != '.':
+ c = '.'
+ else:
+ c = ' '
+ lowered_msg += c
+ return lowered_msg
+
+ import random
if not connection_id in game.sessions:
raise GameError('need to be logged in for this')
speaker = game.get_thing(game.sessions[connection_id], False)
if not connection_id in game.sessions:
raise GameError('need to be logged in for this')
speaker = game.get_thing(game.sessions[connection_id], False)
- dijkstra_map = Map(game.map_geometry.size)
- n_max = 256
- dijkstra_map
.terrain = [n_max for i in range(dijkstra_
map.size_i)]
- dijkstra_map[
speaker.position
] = 0
+ n_max = 255
+ map_size = game.map.size_i
+ dijkstra_map
= [n_max for i in range(game.
map.size_i)]
+ dijkstra_map[
game.map.get_position_index(speaker.position)
] = 0
shrunk = True
while shrunk:
shrunk = False
shrunk = True
while shrunk:
shrunk = False
- for
pos in dijkstra_map
:
- if game.map
[pos
] == 'X':
+ for
i in range(map_size)
:
+ if game.map
.terrain[i
] == 'X':
continue
continue
- neighbors = game.map_geometry.get_neighbors
(pos
)
+ neighbors = game.map_geometry.get_neighbors
_i(i
)
for direction in [d for d in neighbors if neighbors[d]]:
for direction in [d for d in neighbors if neighbors[d]]:
-
yx
= neighbors[direction]
- if dijkstra_map[
yx] < dijkstra_map[pos
] - 1:
- dijkstra_map[
pos] = dijkstra_map[yx
] + 1
+
j
= neighbors[direction]
+ if dijkstra_map[
j] < dijkstra_map[i
] - 1:
+ dijkstra_map[
i] = dijkstra_map[j
] + 1
shrunk = True
shrunk = True
+ #print('DEBUG')
+ #line_to_print = []
+ #x = 0
+ #for n in dijkstra_map:
+ # line_to_print += ['%3s' % n]
+ # x += 1
+ # if x >= game.map.size.x:
+ # x = 0
+ # print(' '.join(line_to_print))
for c_id in game.sessions:
listener = game.get_thing(game.sessions[c_id], create_unfound=False)
for c_id in game.sessions:
listener = game.get_thing(game.sessions[c_id], create_unfound=False)
- volume = 1 / max(1, dijkstra_map[listener.position])
+ listener_vol = dijkstra_map[game.map.get_position_index(listener.position)]
+ volume = 1 / max(1, listener_vol)
+ lowered_msg = lower_msg_by_volume(msg, volume)
+ lowered_nick = lower_msg_by_volume(speaker.nickname, volume)
game.io.send('CHAT ' +
game.io.send('CHAT ' +
- quote('(volume: %.3f) %s: %s' % (volume, speaker.nickname, msg)),
+ quote('(volume: %.2f) %s: %s' % (volume, lowered_nick,
+ lowered_msg)),
c_id)
cmd_ALL.argtypes = 'string'
c_id)
cmd_ALL.argtypes = 'string'