ya2 · news · projects · code · about

retrieve test coordinates
[pmachines.git] / logics / scenes / scene_domino.py
1 from logics.scene import Scene
2 from logics.items.box import Box
3 from logics.items.shelf import Shelf
4 from logics.items.domino import Domino, DownStrategy
5 from logics.items.basketball import Basketball
6 from logics.items.teetertooter import TeeterTooter
7
8
9 class SceneDomino(Scene):
10
11 @staticmethod
12 def name():
13 return _('Domino')
14
15 def _set_items(self):
16 self.items = []
17 #self.items += [Box(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, count=3)]
18 #self.items += [Shelf(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, count=3)]
19 self.items += [Shelf(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, mass=0, pos=(-1.2, 0, -.6))]
20 self.items += [Shelf(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, mass=0, pos=(1.2, 0, -.6))]
21 self.items += [Domino(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, count=2)]
22 self.items += [Domino(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, pos=(-1.14, 0, -.04))]
23 self.items[-1].set_strategy(DownStrategy(self.items[-1]._np, 60))
24 self.items += [Domino(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, pos=(-.49, 0, -.04))]
25 self.items[-1].set_strategy(DownStrategy(self.items[-1]._np, 60))
26 self.items += [Domino(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, pos=(0.94, 0, -.04))]
27 self.items[-1].set_strategy(DownStrategy(self.items[-1]._np, 60))
28 self.items += [Domino(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, pos=(1.55, 0, -.04))]
29 self.items[-1].set_strategy(DownStrategy(self.items[-1]._np, 60))
30 self.items += [Domino(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, pos=(2.09, 0, -.04))]
31 self.items[-1].set_strategy(DownStrategy(self.items[-1]._np, 88))
32 #self.items += [Basketball(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, count=3)]
33 #self.items += [TeeterTooter(self._world, self._mouse_plane_node, self.cb_inst, self.current_bottom, self.repos, count=3)]
34
35 def _instr_txt(self):
36 txt = _('Scene: ') + self.name() + '\n\n'
37 txt += _('Goal: every domino piece must fall\n\n')
38 txt += _('keep \5mouse_l\5 pressed to drag an item\n\n'
39 'keep \5mouse_r\5 pressed to rotate an item')
40 return txt
41
42 def _win_condition(self):
43 return all(itm.strategy.win_condition() for itm in self.items) and not self._paused