MoveEvent.py 1.6KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. from intelligine.core.exceptions import UnableToFoundMovement
  2. from intelligine.synergy.event.move.direction import get_position_with_direction_decal
  3. from intelligine.shorcut.brain import get_brain_part
  4. from synergine.core.exceptions import NotConcernedEvent
  5. from intelligine.synergy.event.Event import Event
  6. from synergine.core.simulation.mechanism.Mechanism import Mechanism
  7. from intelligine.cst import COL_WALKER, BRAIN_SCHEMA, BRAIN_PART_MOVE
  8. from synergine_xyz.cst import POSITION
  9. class MoveEvent(Event):
  10. PARAM_POSITION = 'pos'
  11. PARAM_DIRECTION = 'dir'
  12. _mechanism = Mechanism
  13. _concern = COL_WALKER
  14. def _prepare(self, object_id, context, parameters={}):
  15. try:
  16. direction = self._get_direction(object_id, context)
  17. except UnableToFoundMovement:
  18. raise NotConcernedEvent()
  19. object_point = context.metas.value.get(POSITION, object_id)
  20. move_to_point = get_position_with_direction_decal(direction, object_point)
  21. # TODO: future: c le brain qui calcule ou aller, et donc si c possible
  22. if self._direction_point_is_possible(context, move_to_point):
  23. parameters[self.PARAM_POSITION] = move_to_point
  24. parameters[self.PARAM_DIRECTION] = direction
  25. # TODO: Sinon lever un NotConcernedEvent
  26. return parameters
  27. def _get_direction(self, object_id, context):
  28. object_move_brain_part = get_brain_part(context, object_id, BRAIN_PART_MOVE)
  29. return object_move_brain_part.get_direction(context, object_id)
  30. @staticmethod
  31. def _direction_point_is_possible(context, direction_point):
  32. return context.position_is_penetrable(direction_point)