Skip to content

Latest commit

 

History

History
197 lines (129 loc) · 4.6 KB

readme.rst

File metadata and controls

197 lines (129 loc) · 4.6 KB

About

TODO

License

MIT (LICENSE.txt)

Requirements

Below is a general list of the requirements:

  • Python 2.7
  • pygame 1.9.x
  • PyOpenGL 3.x

Version numbers mentioned above are being used within development. If you successfully use it with different versions, please send me a note.

Installation of requirements on Ubuntu

  1. Install package python-pygame.
  2. Install PyOpenGL using pip thru sudo.

Installation of requirements on Fedora Core 18

  1. Install package pygame.
  2. Install package PyOpenGL.

Installation of requirements on OSX Lion

  1. Install pygame package for OSX Lion+ (http://pygame.org/).
  2. Install PyOpenGL using pip thru sudo. (If it fails, try updating pip by doing i.e. "sudo easy_install-2.7 pip" first.)
  3. Install X11/XQuartz (http://xquartz.macosforge.org/).

Installation of the game

  1. Download code of Joe Danger (https://bitbucket.org/theblacklion/joe-danger/get/default.tar.gz).
  2. Download code of diamond framework (https://bitbucket.org/theblacklion/diamond-framework/get/default.tar.gz).
  3. Unpack both archives (e.g. tar xzvf *joe-danger*tar.gz).
  4. Symlink diamond framework as "diamond" into the folder of Joe Danger (next to joedng.py).
  5. ./joedng.py

Player modes (technical)

The player can have one of the following modes:

  • WALK
  • JUMP
  • CROUCH
  • CLIMB
  • ACTION
  • FALL
  • DIE

Use "switch_to_mode" methods to handle transitions and setup of each mode. Use "can_switch_to_mode" to test if e.g. CLIMB is possible and makes sense. If player gets hit by an enemy switch to DIE mode. If player has no ground below and not in CLIMB, DIE or JUMP mode accelerate downwards. If player has ground below and velocity >= 7.0 set velocity to -x/5 and switch to JUMP mode. If player has ground below set velocity to 0.0. If player has ground above and velocity <= 0.0 set JUMP energy and velocity to 0.0. If player has ground at left or right set velocity to 0.0.

  1. WALK mode

1.1 Enter indicators

  • Default mode.

1.2 Possible commands

  • LEFT => Move left.
  • RIGHT => Move right.
  • UP => Try to CLIMB up, else switch to JUMP mode.
  • DOWN => Try to CLIMB down, else switch to CROUCH mode.
  • ACTION => Switch to ACTION mode.

1.3 Exit indicators

  • If player looses ground switch to FALL mode.
  1. JUMP mode

2.1 Enter indicators

  • Switch from WALK (full jump) or CLIMB (half jump) mode or bump on ground.

2.2 Possible commands

  • LEFT => Move left.
  • RIGHT => Move right.
  • UP => Try to CLIMB up, else accelerate upwards if possible.

2.3 Exit indicators

  • If player cannot jump higher anymore switch to FALL mode.
  • If UP is not being pressed switch to FALL mode.
  1. CROUCH mode

3.1 Enter indicators

  • Switch from WALK mode.

3.2 Possible commands

  • LEFT => Move left.
  • RIGHT => Move right.
  1. CLIMB mode

4.1 Enter indicators

  • Switch from other mode.

4.2 Possible commands

  • LEFT => Move left.
  • RIGHT => Move right.
  • UP => Move up if possible, else switch to JUMP mode.
  • DOWN => Move down.

4.3 Exit indicators

  • If player leaves climb passabiity tiles switch to FALL mode.
  1. ACTION mode

5.1 Enter indicators

  • Switch from other mode (ACTION key pressed down).

5.2 Possible commands

  • SAME AS ORIENTATION => Try to press button.
  • AGAINST ORIENTATION => Try to drag some box/boulder.
  • UP => Try to shoot.
  • DOWN => Try to place a bomb.

5.3 Exit indicators

  • If ACTION key released switch to last mode.
  1. FALL mode

6.1 Enter indicators

  • Switch from other mode.

6.2 Possible commands

  • LEFT => Move left.
  • RIGHT => Move right.
  • UP => Try to CLIMB up.
  • DOWN => Try to CLIMB down.

6.3 Exit indicators

  • If player has ground below switch to WALK mode.
  1. DIE mode

7.1 Enter indicators

  • Switch from other mode.

7.2 Possible commands

None.

7.3 Exit indicators

  • If animation is done, respawn on last save point.

Known bugs

  • Screen autosizing with multi monitor setup unuseable. The game asks the engine to adapt to your current screen size. It will try to stretch it horizontally and reduce its size vertically to create a fullscreen experience on all screens. When using a multi monitor setup it might try to use both screens which will result in strange gameplay and a performance brakedown.
  • In the tilematrix editor when changing the sector size in the tilesheet view, the rebuild afterwards tends to crash pygame. This is reproducible when activating the display of the sector coords. Also the selection does not show up properly anymore. It appears only in the old sector area.