- Added new monsters: ant, fireball
- Snake spit now animates - Changed sound effect for snake shooting - Added new sound effects for ant
|
@ -7,7 +7,6 @@ monsters
|
||||||
0 2 13
|
0 2 13
|
||||||
134 37 13
|
134 37 13
|
||||||
23 17 26
|
23 17 26
|
||||||
60 18 6
|
|
||||||
60 4 27
|
60 4 27
|
||||||
60 34 21
|
60 34 21
|
||||||
18 27 10
|
18 27 10
|
||||||
|
@ -26,6 +25,7 @@ monsters
|
||||||
17 2 28
|
17 2 28
|
||||||
17 37 28
|
17 37 28
|
||||||
49 21 26
|
49 21 26
|
||||||
|
157 17 6
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir 2
|
exitdir 2
|
||||||
44,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,44,
|
44,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,44,
|
||||||
|
|
|
@ -2,6 +2,7 @@ bgfile beach4.png
|
||||||
bg 0
|
bg 0
|
||||||
hurryup 30
|
hurryup 30
|
||||||
help
|
help
|
||||||
|
Beware - ants will grow after eating!
|
||||||
endhelp
|
endhelp
|
||||||
monsters
|
monsters
|
||||||
0 4 4
|
0 4 4
|
||||||
|
@ -9,7 +10,6 @@ monsters
|
||||||
49 30 18
|
49 30 18
|
||||||
49 16 18
|
49 16 18
|
||||||
1 36 1
|
1 36 1
|
||||||
1 26 7
|
|
||||||
1 3 1
|
1 3 1
|
||||||
15 32 22
|
15 32 22
|
||||||
15 30 22
|
15 30 22
|
||||||
|
@ -50,6 +50,8 @@ monsters
|
||||||
124 26 26
|
124 26 26
|
||||||
124 31 26
|
124 31 26
|
||||||
15 18 22
|
15 18 22
|
||||||
|
158 26 7
|
||||||
|
14 9 4
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir 2
|
exitdir 2
|
||||||
52,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,44,
|
52,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,44,
|
||||||
|
|
|
@ -10,7 +10,6 @@ monsters
|
||||||
6 23 5
|
6 23 5
|
||||||
1 25 20
|
1 25 20
|
||||||
18 38 10
|
18 38 10
|
||||||
1 8 5
|
|
||||||
124 27 11
|
124 27 11
|
||||||
124 34 7
|
124 34 7
|
||||||
1 6 13
|
1 6 13
|
||||||
|
@ -30,7 +29,9 @@ monsters
|
||||||
16 25 1
|
16 25 1
|
||||||
16 22 1
|
16 22 1
|
||||||
133 32 19
|
133 32 19
|
||||||
132 12 26 200 432 200 432 200 432 291 246
|
132 12 26 200 432 200 432 200 432 200 432 291 246
|
||||||
|
158 9 5
|
||||||
|
158 15 5
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir -1
|
exitdir -1
|
||||||
57,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,57,
|
57,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,57,
|
||||||
|
|
|
@ -10,10 +10,7 @@ monsters
|
||||||
60 26 25
|
60 26 25
|
||||||
60 16 27
|
60 16 27
|
||||||
60 5 26
|
60 5 26
|
||||||
133 30 4
|
|
||||||
133 33 15
|
133 33 15
|
||||||
18 25 16
|
|
||||||
49 16 9
|
|
||||||
7 26 8
|
7 26 8
|
||||||
15 26 5
|
15 26 5
|
||||||
15 27 5
|
15 27 5
|
||||||
|
@ -34,6 +31,10 @@ monsters
|
||||||
16 28 16
|
16 28 16
|
||||||
15 4 21
|
15 4 21
|
||||||
15 11 21
|
15 11 21
|
||||||
|
158 21 16
|
||||||
|
158 31 16
|
||||||
|
158 32 5
|
||||||
|
158 16 9
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir -1
|
exitdir -1
|
||||||
57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,56,84,84,84,84,84,84,56,
|
57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,56,84,84,84,84,84,84,56,
|
||||||
|
|
|
@ -7,10 +7,8 @@ monsters
|
||||||
0 5 6
|
0 5 6
|
||||||
134 34 4
|
134 34 4
|
||||||
23 16 18
|
23 16 18
|
||||||
132 37 5 600 96 600 96 600 96 600 96 600 444
|
132 37 5 600 96 600 96 600 96 600 96 600 96 600 444
|
||||||
132 2 27 40 448 40 448 40 448 40 448 40 121
|
132 2 27 40 448 40 448 40 448 40 448 40 448 40 121
|
||||||
49 13 22
|
|
||||||
49 26 18
|
|
||||||
49 21 26
|
49 21 26
|
||||||
133 28 22
|
133 28 22
|
||||||
133 10 26
|
133 10 26
|
||||||
|
@ -58,6 +56,8 @@ monsters
|
||||||
15 14 26
|
15 14 26
|
||||||
15 6 26
|
15 6 26
|
||||||
16 7 26
|
16 7 26
|
||||||
|
158 26 18
|
||||||
|
49 13 22
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir -1
|
exitdir -1
|
||||||
61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,
|
61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,
|
||||||
|
|
|
@ -9,8 +9,6 @@ monsters
|
||||||
23 22 14
|
23 22 14
|
||||||
12 11 14
|
12 11 14
|
||||||
12 27 14
|
12 27 14
|
||||||
12 18 4
|
|
||||||
12 2 4
|
|
||||||
12 36 24
|
12 36 24
|
||||||
12 21 24
|
12 21 24
|
||||||
133 8 23
|
133 8 23
|
||||||
|
@ -35,6 +33,9 @@ monsters
|
||||||
15 9 24
|
15 9 24
|
||||||
16 16 4
|
16 16 4
|
||||||
16 18 4
|
16 18 4
|
||||||
|
158 20 4
|
||||||
|
158 12 4
|
||||||
|
158 3 4
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir -1
|
exitdir -1
|
||||||
74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,
|
74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,74,
|
||||||
|
|
|
@ -7,20 +7,17 @@ monsters
|
||||||
0 6 27
|
0 6 27
|
||||||
134 12 27
|
134 12 27
|
||||||
23 30 8
|
23 30 8
|
||||||
49 14 6
|
|
||||||
133 2 14
|
133 2 14
|
||||||
133 38 3
|
133 38 3
|
||||||
133 33 14
|
133 33 14
|
||||||
60 21 14
|
60 21 14
|
||||||
49 27 19
|
49 27 19
|
||||||
132 37 24 600 400 340 400
|
132 37 24 600 400 600 400 340 400
|
||||||
18 31 8
|
|
||||||
18 12 22
|
18 12 22
|
||||||
17 21 19
|
17 21 19
|
||||||
17 32 19
|
17 32 19
|
||||||
17 10 22
|
17 10 22
|
||||||
16 29 8
|
16 29 8
|
||||||
16 31 8
|
|
||||||
16 11 6
|
16 11 6
|
||||||
16 4 6
|
16 4 6
|
||||||
16 5 6
|
16 5 6
|
||||||
|
@ -30,6 +27,10 @@ monsters
|
||||||
15 16 15
|
15 16 15
|
||||||
15 6 22
|
15 6 22
|
||||||
17 23 15
|
17 23 15
|
||||||
|
158 6 6
|
||||||
|
158 23 19
|
||||||
|
158 32 8
|
||||||
|
16 31 8
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir -1
|
exitdir -1
|
||||||
57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,57,
|
57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,57,
|
||||||
|
|
|
@ -11,7 +11,6 @@ monsters
|
||||||
18 8 20
|
18 8 20
|
||||||
18 28 16
|
18 28 16
|
||||||
133 32 12
|
133 32 12
|
||||||
133 8 12
|
|
||||||
15 35 12
|
15 35 12
|
||||||
15 27 12
|
15 27 12
|
||||||
15 12 12
|
15 12 12
|
||||||
|
@ -28,6 +27,9 @@ monsters
|
||||||
18 11 16
|
18 11 16
|
||||||
18 31 20
|
18 31 20
|
||||||
18 5 24
|
18 5 24
|
||||||
|
158 24 12
|
||||||
|
158 11 12
|
||||||
|
133 7 8
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir -1
|
exitdir -1
|
||||||
57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,
|
57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,57,
|
||||||
|
|
|
@ -10,11 +10,24 @@ monsters
|
||||||
1 25 8
|
1 25 8
|
||||||
1 15 4
|
1 15 4
|
||||||
1 8 12
|
1 8 12
|
||||||
18 29 12
|
|
||||||
18 11 8
|
|
||||||
18 33 4
|
|
||||||
133 1 8
|
133 1 8
|
||||||
133 20 28
|
133 20 28
|
||||||
|
158 29 12
|
||||||
|
158 11 8
|
||||||
|
158 33 4
|
||||||
|
15 22 23
|
||||||
|
15 17 23
|
||||||
|
16 35 23
|
||||||
|
16 4 23
|
||||||
|
16 12 12
|
||||||
|
16 31 8
|
||||||
|
16 9 4
|
||||||
|
16 24 4
|
||||||
|
17 23 12
|
||||||
|
17 22 12
|
||||||
|
17 17 8
|
||||||
|
15 6 8
|
||||||
|
15 30 4
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir -2
|
exitdir -2
|
||||||
33,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,33,
|
33,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,33,
|
||||||
|
|
|
@ -7,14 +7,14 @@ monsters
|
||||||
0 17 28
|
0 17 28
|
||||||
134 20 28
|
134 20 28
|
||||||
12 17 15
|
12 17 15
|
||||||
49 32 8
|
|
||||||
49 6 26
|
|
||||||
18 32 19
|
|
||||||
18 10 20
|
|
||||||
133 4 16
|
133 4 16
|
||||||
133 30 11
|
133 30 11
|
||||||
49 9 9
|
49 9 9
|
||||||
49 29 24
|
49 29 24
|
||||||
|
158 32 19
|
||||||
|
158 10 20
|
||||||
|
158 6 26
|
||||||
|
49 30 8
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir -2
|
exitdir -2
|
||||||
33,0,0,0,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,0,0,0,33,
|
33,0,0,0,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,33,0,0,0,33,
|
||||||
|
|
|
@ -4,15 +4,22 @@ hurryup 30
|
||||||
help
|
help
|
||||||
endhelp
|
endhelp
|
||||||
monsters
|
monsters
|
||||||
0 35 19
|
0 29 13
|
||||||
134 36 19
|
134 33 13
|
||||||
23 38 19
|
23 36 13
|
||||||
6 20 10
|
6 20 10
|
||||||
1 13 19
|
158 2 27
|
||||||
1 23 19
|
16 15 27
|
||||||
157 4 27
|
16 19 24
|
||||||
157 7 23
|
16 22 21
|
||||||
157 1 19
|
16 5 21
|
||||||
|
158 3 18
|
||||||
|
16 5 18
|
||||||
|
16 6 18
|
||||||
|
16 7 18
|
||||||
|
16 9 18
|
||||||
|
16 11 18
|
||||||
|
15 15 18
|
||||||
endmonsters
|
endmonsters
|
||||||
exitdir 1
|
exitdir 1
|
||||||
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
|
@ -29,20 +36,20 @@ exitdir 1
|
||||||
4,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,1,1,4,
|
||||||
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,1,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
4,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,1,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,1,1,1,1,1,1,4,
|
1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,1,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,1,1,1,1,1,1,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,1,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,1,1,1,1,1,1,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,1,1,1,1,1,1,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,1,1,1,1,1,1,4,
|
4,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,4,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,1,1,1,1,1,1,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,4,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,4,0,0,0,0,0,4,
|
4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,4,
|
||||||
4,0,0,0,0,0,0,0,0,4,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,4,0,0,0,0,0,4,
|
|
||||||
4,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,
|
4,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,
|
||||||
4,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,4,
|
4,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,4,
|
||||||
layer2
|
layer2
|
||||||
|
|
|
@ -42,11 +42,11 @@
|
||||||
407,level407.dat,The Fly
|
407,level407.dat,The Fly
|
||||||
404,level404.dat,Off Cuts
|
404,level404.dat,Off Cuts
|
||||||
408,level408.dat,Around and Around
|
408,level408.dat,Around and Around
|
||||||
419,level419.dat,Snakes and Ladders
|
|
||||||
403,level403.dat,Delayed Release
|
403,level403.dat,Delayed Release
|
||||||
405,level405.dat,Pitfalls
|
405,level405.dat,Pitfalls
|
||||||
413,level413.dat,Three Parts
|
413,level413.dat,Three Parts
|
||||||
418,level418.dat,Grilled
|
418,level418.dat,Grilled
|
||||||
|
419,level419.dat,Snakes and Ladders
|
||||||
415,level415.dat,Half Way
|
415,level415.dat,Half Way
|
||||||
422,level422.dat,Hanging Gardens
|
422,level422.dat,Hanging Gardens
|
||||||
421,level421.dat,Upwards and Onwards
|
421,level421.dat,Upwards and Onwards
|
||||||
|
|
After Width: | Height: | Size: 733 B |
After Width: | Height: | Size: 698 B |
After Width: | Height: | Size: 647 B |
After Width: | Height: | Size: 750 B |
After Width: | Height: | Size: 851 B |
After Width: | Height: | Size: 837 B |
After Width: | Height: | Size: 801 B |
After Width: | Height: | Size: 867 B |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 1.3 KiB |
After Width: | Height: | Size: 256 B |
After Width: | Height: | Size: 281 B |
After Width: | Height: | Size: 175 B |
10
defs.h
|
@ -329,7 +329,7 @@
|
||||||
/* enums */
|
/* enums */
|
||||||
|
|
||||||
/* sounds */
|
/* sounds */
|
||||||
#define MAXFX 61
|
#define MAXFX 63
|
||||||
#define FX_SHOOT 0
|
#define FX_SHOOT 0
|
||||||
#define FX_SLAM 1
|
#define FX_SLAM 1
|
||||||
#define FX_KILL 2
|
#define FX_KILL 2
|
||||||
|
@ -391,6 +391,8 @@
|
||||||
#define FX_CAMERA 58
|
#define FX_CAMERA 58
|
||||||
#define FX_LASER 59
|
#define FX_LASER 59
|
||||||
#define FX_HISS 60
|
#define FX_HISS 60
|
||||||
|
#define FX_CHOMP 61
|
||||||
|
#define FX_GROWL 62
|
||||||
|
|
||||||
// card suits
|
// card suits
|
||||||
#define CS_HEART 1
|
#define CS_HEART 1
|
||||||
|
@ -416,7 +418,7 @@
|
||||||
#define S_SLOPE 2
|
#define S_SLOPE 2
|
||||||
|
|
||||||
// Sprite types
|
// Sprite types
|
||||||
#define MAXPTYPES 158
|
#define MAXPTYPES 162
|
||||||
#define P_PLAYER 0
|
#define P_PLAYER 0
|
||||||
#define P_RAT 1
|
#define P_RAT 1
|
||||||
#define P_CHEESE 2
|
#define P_CHEESE 2
|
||||||
|
@ -580,6 +582,10 @@
|
||||||
#define P_RAYGUN 155
|
#define P_RAYGUN 155
|
||||||
#define P_RAYGUNBULLET 156
|
#define P_RAYGUNBULLET 156
|
||||||
#define P_FROG 157
|
#define P_FROG 157
|
||||||
|
#define P_ANT1 158
|
||||||
|
#define P_ANT2 159
|
||||||
|
#define P_ANT3 160
|
||||||
|
#define P_FIREBALL 161
|
||||||
|
|
||||||
|
|
||||||
#define FLY_FLYTIME 150
|
#define FLY_FLYTIME 150
|
||||||
|
|
384
rc.c
|
@ -2144,7 +2144,6 @@ void checkcollide(sprite_t *s) {
|
||||||
die(s);
|
die(s);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
printf("dead!\n");
|
|
||||||
die(s);
|
die(s);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -2207,6 +2206,46 @@ printf("dead!\n");
|
||||||
s2->willbecome = P_DIAMOND;
|
s2->willbecome = P_DIAMOND;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if ((s->id == P_ANT1) || (s->id == P_ANT2) || (s->id == P_ANT3)) {
|
||||||
|
int isfr;
|
||||||
|
// eat fruits
|
||||||
|
isfr = isfruit(s2->id);
|
||||||
|
if (isfr) {
|
||||||
|
int fruitamt;
|
||||||
|
// eat the fruit
|
||||||
|
s2->dead = D_FINAL;
|
||||||
|
playfx(FX_CHOMP);
|
||||||
|
puffin(-1, s2->x, s2->y, "nothing", 0);
|
||||||
|
// increase health
|
||||||
|
switch (isfr) {
|
||||||
|
case FT_FRUIT:
|
||||||
|
case FT_PERM:
|
||||||
|
case FT_TEMP:
|
||||||
|
fruitamt = 5;
|
||||||
|
break;
|
||||||
|
case FT_GEM:
|
||||||
|
default:
|
||||||
|
fruitamt = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
s->timer1 += fruitamt;
|
||||||
|
if (s->timer1 >= 5) {
|
||||||
|
s->timer1 = 0;
|
||||||
|
playfx(FX_GROWL);
|
||||||
|
// grow
|
||||||
|
if (s->id == P_ANT1) {
|
||||||
|
s->id = P_ANT2;
|
||||||
|
} else if (s->id == P_ANT2) {
|
||||||
|
s->id = P_ANT3;
|
||||||
|
} else if (s->id == P_ANT3) {
|
||||||
|
sprite_t *newsp;
|
||||||
|
// spawn a new ant
|
||||||
|
newsp = addsprite(P_ANT1, s2->x, s2->y, "spawned_ant");
|
||||||
|
puffin(-1, s->x+(s->dir*TILEH), s->y, "nothing", 0);
|
||||||
|
newsp->dir = -s->dir;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
} else if (inintro() && (s->id == P_RAT)) {
|
} else if (inintro() && (s->id == P_RAT)) {
|
||||||
// collect fruits
|
// collect fruits
|
||||||
if (isfruit(s2->id)) {
|
if (isfruit(s2->id)) {
|
||||||
|
@ -3147,6 +3186,332 @@ int movesprite(sprite_t *s) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} // end if inintro
|
} // end if inintro
|
||||||
|
} else if (s->id == P_ANT1) { // worker ant - moves like a rat
|
||||||
|
if (!s->falling) {
|
||||||
|
int move = B_FALSE;
|
||||||
|
int xdiff ,absxdiff;
|
||||||
|
tiletype_t *tunder;
|
||||||
|
|
||||||
|
/* distance to closest player */
|
||||||
|
xdiff = getxdisttoplayer(s, NULL);
|
||||||
|
absxdiff = abs(xdiff);
|
||||||
|
|
||||||
|
// tile in front and below
|
||||||
|
tt = gettileat(s->x + s->dir*getspeed(s) + (s->dir * (s->img->w/2)),s->y + (TILEH/2),NULL,NULL);
|
||||||
|
// tile below
|
||||||
|
tunder = gettileat(s->x ,s->y + 1,NULL,NULL);
|
||||||
|
/* if there's a hole in front of us and below*/
|
||||||
|
if (tt->solid == S_NOTSOLID) {
|
||||||
|
// we're on a slope
|
||||||
|
if (tunder->solid == S_SLOPE) {
|
||||||
|
move = B_TRUE;
|
||||||
|
} else {
|
||||||
|
if (s->angry || boss) {
|
||||||
|
if ((player && (player->y > s->y)) || (player2 && (player2->y > s->y))) {
|
||||||
|
/* if player is below, fall off */
|
||||||
|
if (xdiff <= (TILEW*8)) {
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
} else if ((player && (player->y == s->y)) || (player2 && player2->y == s->y)) {
|
||||||
|
if (globpowerup != PW_CAMERA) {
|
||||||
|
/* if player is at same level and close, jump */
|
||||||
|
if ((s->dir == D_RIGHT) && (xdiff > 0) && (xdiff <= (TILEW*7))) {
|
||||||
|
jump(s,D_RIGHT);
|
||||||
|
} else if ((s->dir == D_LEFT) && (xdiff < 0) && (xdiff >= -(TILEW*7))) {
|
||||||
|
jump(s,D_LEFT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (level->bottomopen && (s->y >= (480 - 100)) && isplayerabove(s)) {
|
||||||
|
// if near bottom of the screen and can fall through...
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (globpowerup == PW_CAMERA) {
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* either move or turn around */
|
||||||
|
if (move) {
|
||||||
|
rv = movex(s, s->dir*getspeed(s), B_TRUE);
|
||||||
|
if (rv) {
|
||||||
|
/* if we couldn't move (hit a wall), turn */
|
||||||
|
s->dir = -s->dir;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
s->dir = -s->dir;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (s->angry) {
|
||||||
|
if ((!s->jumping) && (!s->jumptimer)) {
|
||||||
|
/* if player is above us, jump */
|
||||||
|
if ( (player && (!player->dead) && (player->y < s->y)) ||
|
||||||
|
(player2 && (!player2->dead) && (player2->y < s->y))) {
|
||||||
|
if ((xdiff >= (TILEW*2)) && (xdiff <= (TILEW*3))) {
|
||||||
|
/* jump right */
|
||||||
|
jump(s, 1);
|
||||||
|
} else if ((xdiff <= -(TILEW*2)) && (xdiff >= -(TILEW*3))) {
|
||||||
|
/* jump left */
|
||||||
|
jump(s, -1);
|
||||||
|
} else if ((player && (s->y - player->y <= (TILEH*6))) ||
|
||||||
|
(player2 && (s->y - player2->y <= (TILEH*6)))) {
|
||||||
|
if ((xdiff >= 0) && (xdiff < (TILEW*2))) {
|
||||||
|
/* jump up */
|
||||||
|
jump(s, 0);
|
||||||
|
} else if ((xdiff <= 0) && (xdiff > -(TILEW*2))) {
|
||||||
|
/* jump up */
|
||||||
|
jump(s, 0);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* jump whichever way we're facing */
|
||||||
|
/*
|
||||||
|
s->jumpdir = s->dir;
|
||||||
|
s->jumping = 1;
|
||||||
|
s->jumpspeed = 5;
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else { // falling
|
||||||
|
tiletype_t *tunder, *t2under;
|
||||||
|
|
||||||
|
// tile below
|
||||||
|
tunder = gettileat(s->x ,s->y,NULL,NULL);
|
||||||
|
t2under = gettileat(s->x ,s->y+s->img->h,NULL,NULL);
|
||||||
|
if ((tunder->solid == S_SLOPE) || (t2under->solid == S_SLOPE)) {
|
||||||
|
movex(s, s->dir*getspeed(s), B_TRUE);
|
||||||
|
} else if (s->jumpdir) {
|
||||||
|
movex(s, s->jumpdir*getspeed(s), B_TRUE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (s->id == P_ANT2) { // soldier ant - moves like a tick
|
||||||
|
if (!s->falling) {
|
||||||
|
int move = B_FALSE;
|
||||||
|
int xdiff, absxdiff;
|
||||||
|
|
||||||
|
/* distance to player */
|
||||||
|
xdiff = getxdisttoplayer(s, NULL);
|
||||||
|
absxdiff = abs(xdiff);
|
||||||
|
|
||||||
|
tt = gettileat(s->x + s->dir+getspeed(s),s->y,NULL,NULL);
|
||||||
|
/* if there's a hole in front of us */
|
||||||
|
if (tt->solid == S_NOTSOLID) {
|
||||||
|
double ycutoff = s->y + (TILEH/2);
|
||||||
|
if ((player && (player->y >= ycutoff)) || (player2 && (player2->y >= ycutoff ))) {
|
||||||
|
/* if player is below and nearby, fall off */
|
||||||
|
if (xdiff <= (TILEW*16)) {
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
} else if ((player && (player->y == s->y)) || (player2 && (player2->y == s->y ))) {
|
||||||
|
if (globpowerup != PW_CAMERA) {
|
||||||
|
/* if player is at same level and close, jump */
|
||||||
|
if ((s->dir == D_RIGHT) && (xdiff > 0) && (xdiff <= (TILEW*7))) {
|
||||||
|
jump(s,D_RIGHT);
|
||||||
|
} else if ((s->dir == D_LEFT) && (xdiff < 0) && (xdiff >= -(TILEW*7))) {
|
||||||
|
jump(s,D_LEFT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (level->bottomopen && (s->y >= (480 - 100)) && isplayerabove(s)) {
|
||||||
|
// if near bottom of the screen and can fall through...
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (globpowerup == PW_CAMERA) {
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* either move or turn around */
|
||||||
|
if (move) {
|
||||||
|
rv = movex(s, s->dir*getspeed(s), B_TRUE);
|
||||||
|
if (rv) {
|
||||||
|
/* if we couldn't move (hit a wall), turn */
|
||||||
|
s->dir = -s->dir;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
s->dir = -s->dir;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* moves like an angry rat all the time */
|
||||||
|
if (globpowerup != PW_CAMERA) {
|
||||||
|
if ((playersalive()) && (!s->jumping) && (!s->jumptimer)) {
|
||||||
|
sprite_t *abovep;
|
||||||
|
/* if player is above us...*/
|
||||||
|
abovep = isplayerabove(s);
|
||||||
|
if (abovep) {
|
||||||
|
if ((xdiff >= (TILEW*2)) && (xdiff <= (TILEW*3))) { // if 2-3 tiles right
|
||||||
|
/* jump right */
|
||||||
|
jump(s, D_RIGHT);
|
||||||
|
} else if ((xdiff <= -(TILEW*2)) && (xdiff >= -(TILEW*3))) { // if 2-3 tiles left
|
||||||
|
/* jump left */
|
||||||
|
jump(s, D_LEFT);
|
||||||
|
} else if (s->y - abovep->y <= (TILEH*6)) { // player less than 6 tiles above
|
||||||
|
if ((xdiff >= 0) && (xdiff < (TILEW*4))) { // ... and within 4 tiles
|
||||||
|
/* jump up */
|
||||||
|
jump(s, 0);
|
||||||
|
} else if ((xdiff <= 0) && (xdiff > -(TILEW*4))) { // ... and within 4 tiles
|
||||||
|
/* jump up */
|
||||||
|
jump(s, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else { // falling
|
||||||
|
movex(s, s->jumpdir*getspeed(s), B_TRUE);
|
||||||
|
}
|
||||||
|
} else if (s->id == P_ANT3) { // moves like a snake
|
||||||
|
/* timer1 loopsfrom 0 - 19
|
||||||
|
|
||||||
|
if timer2 is 0, we can shoot. if it is 1, we can't.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
// inc shooting timer
|
||||||
|
if (s->timer1) {
|
||||||
|
s->timer1--;
|
||||||
|
if (s->timer1 == 0) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!s->falling) {
|
||||||
|
int move = B_FALSE;
|
||||||
|
int xdiff, absxdiff,ydiff;
|
||||||
|
|
||||||
|
/* distance to player */
|
||||||
|
xdiff = getxdisttoplayer(s, NULL);
|
||||||
|
absxdiff = abs(xdiff);
|
||||||
|
|
||||||
|
tt = gettileat(s->x + s->dir+getspeed(s),s->y,NULL,NULL);
|
||||||
|
/* if there's a hole in front of us */
|
||||||
|
if (tt->solid == S_NOTSOLID) {
|
||||||
|
if ((player && (player->y > s->y)) || (player2 && (player2->y > s->y))) {
|
||||||
|
/* if player is below, fall off */
|
||||||
|
if (xdiff <= (TILEW*8)) {
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
} else if ((player && (player->y == s->y)) || (player2 && player2->y == s->y)) {
|
||||||
|
if (s->angry) {
|
||||||
|
/* if player is at same level and close, jump */
|
||||||
|
if ((s->dir == D_RIGHT) && (xdiff > 0) && (xdiff <= (TILEW*7))) {
|
||||||
|
jump(s,D_RIGHT);
|
||||||
|
} else if ((s->dir == D_LEFT) && (xdiff < 0) && (xdiff >= -(TILEW*7))) {
|
||||||
|
jump(s,D_LEFT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (level->bottomopen && (s->y >= (480 - 100)) && isplayerabove(s)) {
|
||||||
|
// if near bottom of the screen and can fall through...
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (globpowerup == PW_CAMERA) {
|
||||||
|
move = B_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* shoot */
|
||||||
|
ydiff = getydisttoplayer(s);
|
||||||
|
ydiff = abs(ydiff);
|
||||||
|
|
||||||
|
// if there's a player close up/down...
|
||||||
|
if (ydiff <= (TILEH*4)) {
|
||||||
|
sprite_t *ss;
|
||||||
|
sprite_t *closeplayer;
|
||||||
|
int shoot = B_FALSE;
|
||||||
|
if (player && (s->y - player->y <= (TILEH*12)) ) {
|
||||||
|
closeplayer = player;
|
||||||
|
} else if (player2 && (s->y - player2->y <= (TILEH*12))) {
|
||||||
|
closeplayer = player2;
|
||||||
|
} else {
|
||||||
|
closeplayer = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (closeplayer) {
|
||||||
|
if (s->bullet == NULL) { // if we don't already have a bullet
|
||||||
|
// if we are facing the player
|
||||||
|
if ( (closeplayer->x < s->x) && (s->dir == D_LEFT) ) {
|
||||||
|
shoot = B_TRUE;
|
||||||
|
} else if ( (closeplayer->x > s->x) && (s->dir == D_RIGHT) ) {
|
||||||
|
shoot = B_TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (globpowerup == PW_CAMERA) shoot = B_FALSE;
|
||||||
|
if (shoot) {
|
||||||
|
// if our shooting timer is okay
|
||||||
|
if (s->timer1 == 0) {
|
||||||
|
playfx(FX_METEOR);
|
||||||
|
ss = addsprite(P_FIREBALL,s->x,s->y - s->img->h/2,"spit" );
|
||||||
|
ss->ys = 0;
|
||||||
|
ss->xs = s->dir * (getspeed(s)*2);
|
||||||
|
ss->dir = s->dir;
|
||||||
|
ss->owner = s;
|
||||||
|
|
||||||
|
s->bullet = ss;
|
||||||
|
|
||||||
|
// start timer for shooting again
|
||||||
|
s->timer1 = 200;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* either move or turn around */
|
||||||
|
if (move) {
|
||||||
|
rv = movex(s, s->dir*getspeed(s), B_TRUE);
|
||||||
|
if (rv) {
|
||||||
|
/* if we couldn't move (hit a wall), turn */
|
||||||
|
s->dir = -s->dir;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
s->dir = -s->dir;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (globpowerup != PW_CAMERA) {
|
||||||
|
if (playersalive() && (!s->jumping) && (!s->jumptimer)) {
|
||||||
|
/* if player is above us, jump */
|
||||||
|
if ( (player && (!player->dead) && (player->y < s->y)) ||
|
||||||
|
(player2 && (!player2->dead) && (player2->y < s->y))) {
|
||||||
|
if ((xdiff >= (TILEW*2)) && (xdiff <= (TILEW*3))) {
|
||||||
|
/* jump right */
|
||||||
|
jump(s, 1);
|
||||||
|
} else if ((xdiff <= -(TILEW*2)) && (xdiff >= -(TILEW*3))) {
|
||||||
|
/* jump left */
|
||||||
|
jump(s, -1);
|
||||||
|
} else if ((player && (s->y - player->y <= (TILEH*6))) ||
|
||||||
|
(player2 && (s->y - player2->y <= (TILEH*6)))) {
|
||||||
|
if ((xdiff >= 0) && (xdiff < (TILEW*2))) {
|
||||||
|
/* jump up */
|
||||||
|
jump(s, 0);
|
||||||
|
} else if ((xdiff <= 0) && (xdiff > -(TILEW*2))) {
|
||||||
|
/* jump up */
|
||||||
|
jump(s, 0);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* jump whichever way we're facing */
|
||||||
|
/*
|
||||||
|
s->jumpdir = s->dir;
|
||||||
|
s->jumping = 1;
|
||||||
|
s->jumpspeed = 5;
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else { // falling
|
||||||
|
movex(s, s->jumpdir*getspeed(s), B_TRUE);
|
||||||
|
}
|
||||||
|
|
||||||
} else if (s->id == P_SNAIL) {
|
} else if (s->id == P_SNAIL) {
|
||||||
if (!s->falling) {
|
if (!s->falling) {
|
||||||
int move = B_FALSE;
|
int move = B_FALSE;
|
||||||
|
@ -4035,7 +4400,6 @@ printf("setting target to y = %d\n",ss->timer2);
|
||||||
|
|
||||||
}
|
}
|
||||||
} else if (s->id == P_TICK) {
|
} else if (s->id == P_TICK) {
|
||||||
|
|
||||||
if (!s->falling) {
|
if (!s->falling) {
|
||||||
int move = B_FALSE;
|
int move = B_FALSE;
|
||||||
int xdiff, absxdiff;
|
int xdiff, absxdiff;
|
||||||
|
@ -4691,7 +5055,7 @@ printf("setting target to y = %d\n",ss->timer2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (s->id == P_SPIT) {
|
} else if ((s->id == P_SPIT) || (s->id == P_FIREBALL)) {
|
||||||
if (movex(s, s->xs, B_TRUE)) {
|
if (movex(s, s->xs, B_TRUE)) {
|
||||||
s->dead = D_FINAL;
|
s->dead = D_FINAL;
|
||||||
}
|
}
|
||||||
|
@ -5800,6 +6164,15 @@ double getspeed(sprite_t *s ) {
|
||||||
} else if (id == P_RAT) {
|
} else if (id == P_RAT) {
|
||||||
if (s->angry) speed = 1.5;
|
if (s->angry) speed = 1.5;
|
||||||
else speed = 1;
|
else speed = 1;
|
||||||
|
} else if (id == P_ANT1) {
|
||||||
|
if (s->angry) speed = 1.5;
|
||||||
|
else speed = 1;
|
||||||
|
} else if (id == P_ANT2) {
|
||||||
|
if (s->angry) speed = 2.5;
|
||||||
|
else speed = 2;
|
||||||
|
} else if (id == P_ANT3) {
|
||||||
|
if (s->angry) speed = 2.5;
|
||||||
|
else speed = 2;
|
||||||
} else if (id == P_SNAKE) {
|
} else if (id == P_SNAKE) {
|
||||||
if (s->angry) speed = 1.5;
|
if (s->angry) speed = 1.5;
|
||||||
else speed = 1;
|
else speed = 1;
|
||||||
|
@ -8457,6 +8830,8 @@ int initsound(void) {
|
||||||
loadfx(FX_CAMERA, "camera.wav");
|
loadfx(FX_CAMERA, "camera.wav");
|
||||||
loadfx(FX_LASER, "laser.wav");
|
loadfx(FX_LASER, "laser.wav");
|
||||||
loadfx(FX_HISS, "hiss.wav");
|
loadfx(FX_HISS, "hiss.wav");
|
||||||
|
loadfx(FX_CHOMP, "chomp.wav");
|
||||||
|
loadfx(FX_GROWL, "growl.wav");
|
||||||
|
|
||||||
// load sound effects
|
// load sound effects
|
||||||
for (i = 0; i < MAXFX; i++) {
|
for (i = 0; i < MAXFX; i++) {
|
||||||
|
@ -8985,7 +9360,6 @@ void moveallsprites(void) {
|
||||||
void checkcollideall(void) {
|
void checkcollideall(void) {
|
||||||
sprite_t *s;
|
sprite_t *s;
|
||||||
|
|
||||||
|
|
||||||
/* check collisions for player and effects */
|
/* check collisions for player and effects */
|
||||||
for (s = sprite ; s ; s = s->next) {
|
for (s = sprite ; s ; s = s->next) {
|
||||||
if (isplayer(s)) {
|
if (isplayer(s)) {
|
||||||
|
@ -9004,6 +9378,8 @@ void checkcollideall(void) {
|
||||||
checkcollide(s);
|
checkcollide(s);
|
||||||
} else if (inintro() && s->id == P_RAT) {
|
} else if (inintro() && s->id == P_RAT) {
|
||||||
checkcollide(s);
|
checkcollide(s);
|
||||||
|
} else if ((s->id == P_ANT1) || (s->id == P_ANT2) || (s->id == P_ANT3)) {
|
||||||
|
checkcollide(s);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
48
shared.c
|
@ -1339,6 +1339,31 @@ int loadimagesets(void) {
|
||||||
/* next 3 are auto generated */
|
/* next 3 are auto generated */
|
||||||
imageset[P_FROG].numimages = 8;
|
imageset[P_FROG].numimages = 8;
|
||||||
|
|
||||||
|
|
||||||
|
loadspriteimage(P_ANT1,F_WALK1, "sprites/ant1.png");
|
||||||
|
loadspriteimage(P_ANT1,F_JUMP, "sprites/ant1jump.png");
|
||||||
|
loadspriteimage(P_ANT1,F_FALL, "sprites/ant1jump.png");
|
||||||
|
loadspriteimage(P_ANT1,F_CAUGHT, "sprites/ant1caught.png");
|
||||||
|
loadspriteimage(P_ANT1,F_DEAD, "sprites/ant1dead.png");
|
||||||
|
/* next 3 are auto generated */
|
||||||
|
imageset[P_ANT1].numimages = 8;
|
||||||
|
|
||||||
|
loadspriteimage(P_ANT2,F_WALK1, "sprites/ant2.png");
|
||||||
|
loadspriteimage(P_ANT2,F_JUMP, "sprites/ant2jump.png");
|
||||||
|
loadspriteimage(P_ANT2,F_FALL, "sprites/ant2jump.png");
|
||||||
|
loadspriteimage(P_ANT2,F_CAUGHT, "sprites/ant2caught.png");
|
||||||
|
loadspriteimage(P_ANT2,F_DEAD, "sprites/ant2dead.png");
|
||||||
|
/* next 3 are auto generated */
|
||||||
|
imageset[P_ANT2].numimages = 8;
|
||||||
|
|
||||||
|
loadspriteimage(P_ANT3,F_WALK1, "sprites/ant3.png");
|
||||||
|
loadspriteimage(P_ANT3,F_JUMP, "sprites/ant3jump.png");
|
||||||
|
loadspriteimage(P_ANT3,F_FALL, "sprites/ant3jump.png");
|
||||||
|
loadspriteimage(P_ANT3,F_CAUGHT, "sprites/ant3caught.png");
|
||||||
|
loadspriteimage(P_ANT3,F_DEAD, "sprites/ant3dead.png");
|
||||||
|
/* next 3 are auto generated */
|
||||||
|
imageset[P_ANT3].numimages = 8;
|
||||||
|
|
||||||
loadspriteimage(P_SPIDER,F_WALK1, "sprites/newspider.png");
|
loadspriteimage(P_SPIDER,F_WALK1, "sprites/newspider.png");
|
||||||
loadspriteimage(P_SPIDER,F_JUMP, "sprites/newspiderjump.png");
|
loadspriteimage(P_SPIDER,F_JUMP, "sprites/newspiderjump.png");
|
||||||
loadspriteimage(P_SPIDER,F_FALL, "sprites/newspiderfall.png");
|
loadspriteimage(P_SPIDER,F_FALL, "sprites/newspiderfall.png");
|
||||||
|
@ -1781,8 +1806,13 @@ int loadimagesets(void) {
|
||||||
imageset[P_RAYGUNBULLET].numimages = 1;
|
imageset[P_RAYGUNBULLET].numimages = 1;
|
||||||
|
|
||||||
/* bullets */
|
/* bullets */
|
||||||
loadspriteimage(P_SPIT,F_WALK1, "sprites/spit.png");
|
loadspriteimage(P_SPIT,0, "sprites/spit.png");
|
||||||
imageset[P_SPIT].numimages = 1;
|
loadspriteimage(P_SPIT,1, "sprites/spit2.png");
|
||||||
|
imageset[P_SPIT].numimages = 2;
|
||||||
|
|
||||||
|
loadspriteimage(P_FIREBALL,0, "sprites/fire1.png");
|
||||||
|
loadspriteimage(P_FIREBALL,1, "sprites/fire2.png");
|
||||||
|
imageset[P_FIREBALL].numimages = 2;
|
||||||
|
|
||||||
|
|
||||||
// manual angry image for black cloud
|
// manual angry image for black cloud
|
||||||
|
@ -1967,7 +1997,11 @@ void drawsprite(sprite_t *s) {
|
||||||
if (isfruit(s->id)) {
|
if (isfruit(s->id)) {
|
||||||
frame = F_WALK1;
|
frame = F_WALK1;
|
||||||
} else if (isbullet(s->id)) {
|
} else if (isbullet(s->id)) {
|
||||||
frame = F_WALK1;
|
if ((timer/6) % 2 == 0) {
|
||||||
|
frame = F_WALK1;
|
||||||
|
} else {
|
||||||
|
frame = F_JUMP;
|
||||||
|
}
|
||||||
} else if (iseffect(s->id)) {
|
} else if (iseffect(s->id)) {
|
||||||
if ((s->id == P_PUFF) || (s->id == P_SMASH) || (s->id == P_SPARKLE)) {
|
if ((s->id == P_PUFF) || (s->id == P_SMASH) || (s->id == P_SPARKLE)) {
|
||||||
if (s->timer1 >= imageset[s->id].numimages) {
|
if (s->timer1 >= imageset[s->id].numimages) {
|
||||||
|
@ -2621,6 +2655,7 @@ int isfruit(int id) {
|
||||||
|
|
||||||
int isbullet(int id) {
|
int isbullet(int id) {
|
||||||
if (id == P_SPIT) return B_TRUE;
|
if (id == P_SPIT) return B_TRUE;
|
||||||
|
if (id == P_FIREBALL) return B_TRUE;
|
||||||
|
|
||||||
return B_FALSE;
|
return B_FALSE;
|
||||||
}
|
}
|
||||||
|
@ -3037,6 +3072,9 @@ int ismonster(int id) {
|
||||||
case P_SLUG:
|
case P_SLUG:
|
||||||
case P_FISH:
|
case P_FISH:
|
||||||
case P_FROG:
|
case P_FROG:
|
||||||
|
case P_ANT1:
|
||||||
|
case P_ANT2:
|
||||||
|
case P_ANT3:
|
||||||
return MT_MONSTER;
|
return MT_MONSTER;
|
||||||
case P_BLACKCLOUD:
|
case P_BLACKCLOUD:
|
||||||
case P_KINGRAT:
|
case P_KINGRAT:
|
||||||
|
@ -3533,6 +3571,10 @@ void setfruitinfo(void) {
|
||||||
|
|
||||||
setinfo(P_FROG, "Frog", "Green frogs will continually bounce around, making them more difficult to catch.", "frog.png");
|
setinfo(P_FROG, "Frog", "Green frogs will continually bounce around, making them more difficult to catch.", "frog.png");
|
||||||
|
|
||||||
|
setinfo(P_ANT1, "Worker Ant", "Worker ants are relatively easy to avoid, but when fed will quickly grow into more dangerous soldier ants.", "ant1.png");
|
||||||
|
setinfo(P_ANT2, "Soldier Ant", "Soldiers move faster and are more intelligent than their worker siblings. In addition, with just a little food they will become queens.", "ant2.png");
|
||||||
|
setinfo(P_ANT3, "Queen Ant", "After an ant has eaten enough, they become a Queen. Queens are just as fast as soldiers and can also breath fire. Furthermore, they are only one meal away from spawning additional ants!", "ant3.png");
|
||||||
|
|
||||||
setinfo(P_SNAKE, "Snake", "The snake moves in a similar fashion to the rat with one important exception - upon seeing a player they will spit a glob of deadly venom at them!", "snake.png");
|
setinfo(P_SNAKE, "Snake", "The snake moves in a similar fashion to the rat with one important exception - upon seeing a player they will spit a glob of deadly venom at them!", "snake.png");
|
||||||
setinfo(P_FLY, "Fly", "Annoying pests at the best of times, flies pose additional danger to dwarves. They fly around more erratically than bees and after landing can scurry quickly back and forth.", "fly.png");
|
setinfo(P_FLY, "Fly", "Annoying pests at the best of times, flies pose additional danger to dwarves. They fly around more erratically than bees and after landing can scurry quickly back and forth.", "fly.png");
|
||||||
|
|
||||||
|
|