diff options
author | Kelly Rauchenberger <fefferburbia@gmail.com> | 2018-05-17 15:55:37 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-05-17 15:55:37 -0400 |
commit | 90aadf3844386824140a20d7fbb847bc16009a94 (patch) | |
tree | 6f83fce90e71abb22b1a8f3e09c79963b2a34d5d /scripts | |
parent | bc63fa57ced1c7329f7fdcfd168eaf7e290158bc (diff) | |
parent | 86f0106d0523825549f1e74b835688c78a10cf6c (diff) | |
download | therapy-90aadf3844386824140a20d7fbb847bc16009a94.tar.gz therapy-90aadf3844386824140a20d7fbb847bc16009a94.tar.bz2 therapy-90aadf3844386824140a20d7fbb847bc16009a94.zip |
Merge pull request #7 from hatkirby/es-rewrite
The ECS rewrite exceeds the original branch in functionality, so it is time to merge it in.
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/checkpoint.lua | 19 | ||||
-rw-r--r-- | scripts/common.lua | 21 | ||||
-rw-r--r-- | scripts/movplat.lua | 8 |
3 files changed, 48 insertions, 0 deletions
diff --git a/scripts/checkpoint.lua b/scripts/checkpoint.lua new file mode 100644 index 0000000..04cf357 --- /dev/null +++ b/scripts/checkpoint.lua | |||
@@ -0,0 +1,19 @@ | |||
1 | checkpoint = {} | ||
2 | |||
3 | function checkpoint.OnTouch(id, player) | ||
4 | curMap = entity.new(realizing().activeMap) | ||
5 | |||
6 | if not player:playable().checkpointMapObject or | ||
7 | not curMap:mappable().mapId == player:playable().checkpointMapId or | ||
8 | not id:prototypable().mapObjectIndex == | ||
9 | player:playable().checkpointMapObjectIndex then | ||
10 | |||
11 | player:playable().checkpointMapObject = true | ||
12 | player:playable().checkpointMapId = curMap:mappable().mapId | ||
13 | player:playable().checkpointMapObjectIndex = | ||
14 | id:prototypable().mapObjectIndex | ||
15 | player:playable().checkpointPos = player:transformable().pos | ||
16 | |||
17 | playSound("res/Pickup_Coin23.wav", 0.25) | ||
18 | end | ||
19 | end | ||
diff --git a/scripts/common.lua b/scripts/common.lua new file mode 100644 index 0000000..d84d97d --- /dev/null +++ b/scripts/common.lua | |||
@@ -0,0 +1,21 @@ | |||
1 | function waitForTick() | ||
2 | return coroutine.yield() | ||
3 | end | ||
4 | |||
5 | function moveLeft(id, len, speed) | ||
6 | local remaining = len / speed | ||
7 | |||
8 | while (remaining > 0) do | ||
9 | id:ponderable().vel.x = -speed | ||
10 | remaining = remaining - waitForTick() | ||
11 | end | ||
12 | end | ||
13 | |||
14 | function moveRight(id, len, speed) | ||
15 | local remaining = len / speed | ||
16 | |||
17 | while (remaining > 0) do | ||
18 | id:ponderable().vel.x = speed | ||
19 | remaining = remaining - waitForTick() | ||
20 | end | ||
21 | end | ||
diff --git a/scripts/movplat.lua b/scripts/movplat.lua new file mode 100644 index 0000000..21cc61a --- /dev/null +++ b/scripts/movplat.lua | |||
@@ -0,0 +1,8 @@ | |||
1 | movplat = {} | ||
2 | |||
3 | function movplat.Behavior(id) | ||
4 | while true do | ||
5 | moveRight(id, 90, 30) | ||
6 | moveLeft(id, 90, 30) | ||
7 | end | ||
8 | end | ||