codecombat/app/lib/world/world_frame.coffee

71 lines
3.2 KiB
CoffeeScript
Raw Normal View History

2014-01-03 13:32:13 -05:00
ThangState = require './thang_state'
module.exports = class WorldFrame
2014-06-30 22:16:26 -04:00
@className: 'WorldFrame'
2014-01-03 13:32:13 -05:00
constructor: (@world, @time=0) ->
@thangStateMap = {}
@setState() if @world
2014-06-30 22:16:26 -04:00
2014-01-03 13:32:13 -05:00
getNextFrame: ->
# Optimized. Must be called while thangs are current at this frame.
nextTime = @time + @world.dt
return null if nextTime > @world.lifespan
@hash = @world.rand.seed
@hash += system.update() for system in @world.systems
nextFrame = new WorldFrame(@world, nextTime)
return nextFrame
setState: ->
for thang in @world.thangs
@thangStateMap[thang.id] = thang.getState()
restoreState: ->
thangState.restore() for thangID, thangState of @thangStateMap
for thang in @world.thangs
if not @thangStateMap[thang.id] and not thang.stateless
2014-06-30 22:16:26 -04:00
#console.log 'Frame', @time, 'restoring state for', thang.id, 'and saying it don\'t exist'
2014-01-03 13:32:13 -05:00
thang.exists = false
restorePartialState: (ratio) ->
thangState.restorePartial ratio for thangID, thangState of @thangStateMap
2014-01-03 13:32:13 -05:00
restoreStateForThang: (thang) ->
thangState = @thangStateMap[thang.id]
if not thangState
if not thang.stateless
thang.exists = false
2014-06-30 22:16:26 -04:00
#console.log 'Frame', @time, 'restoring state for', thang.id, 'in particular and saying it don\'t exist'
2014-01-03 13:32:13 -05:00
return
thangState.restore()
2014-06-30 22:16:26 -04:00
clearEvents: -> thang.currentEvents = [] for thang in @world.thangs
2014-01-03 13:32:13 -05:00
toString: ->
map = ((' ' for x in [0 .. @world.width]) \
for y in [0 .. @world.height])
2014-06-30 22:16:26 -04:00
symbols = '.ox@dfga[]/D'
2014-01-31 19:16:59 -05:00
for thang, i in @world.thangs when thang.rectangle
2014-01-03 13:32:13 -05:00
rect = thang.rectangle().axisAlignedBoundingBox()
for y in [Math.floor(rect.y - rect.height / 2) ... Math.ceil(rect.y + rect.height / 2)]
for x in [Math.floor(rect.x - rect.width / 2) ... Math.ceil(rect.x + rect.width / 2)]
2014-01-31 19:16:59 -05:00
map[y][x] = symbols[i % symbols.length] if 0 <= y < @world.height and 0 <= x < @world.width
2014-06-30 22:16:26 -04:00
@time + '\n' + (xs.join(' ') for xs in map).join('\n') + '\n'
2014-01-03 13:32:13 -05:00
serialize: (frameIndex, trackedPropertiesThangIDs, trackedPropertiesPerThangIndices, trackedPropertiesPerThangTypes, trackedPropertiesPerThangValues, specialValuesToKeys, specialKeysToValues) ->
# Optimize
for thangID, thangIndex in trackedPropertiesThangIDs
thangState = @thangStateMap[thangID]
if thangState
thangState.serialize(frameIndex, trackedPropertiesPerThangIndices[thangIndex], trackedPropertiesPerThangTypes[thangIndex], trackedPropertiesPerThangValues[thangIndex], specialValuesToKeys, specialKeysToValues)
@hash
@deserialize: (world, frameIndex, trackedPropertiesThangIDs, trackedPropertiesThangs, trackedPropertiesPerThangKeys, trackedPropertiesPerThangTypes, trackedPropertiesPerThangValues, specialKeysToValues, hash) ->
# Optimize
wf = new WorldFrame null, world.dt * frameIndex
wf.world = world
wf.hash = hash
for thangID, thangIndex in trackedPropertiesThangIDs
wf.thangStateMap[thangID] = ThangState.deserialize world, frameIndex, trackedPropertiesThangs[thangIndex], trackedPropertiesPerThangKeys[thangIndex], trackedPropertiesPerThangTypes[thangIndex], trackedPropertiesPerThangValues[thangIndex], specialKeysToValues
wf