More Rocks
04/14/21 08:23 Filed in: PICO-8
Today, I make my Ferb game more challenging by placing more rocks.
Last time, I added an explosion whenever the meteors crashed into the ground. Today, I want to make the game more challenging by leaving debris (another rock) at the point of impact. That is, the more impacts, the more rocks. But, I want to make sure the landscape isn't completely covered by rocks or Ferb won't be able to get around. I also want to make sure the rocks aren't placed so near to one another that Ferb can't jump over them. So the plan is:
I'll tackle these problems one at a time, and do point number 1 today.
Rocks are objects, so I can just create another rock object at the point of impact. I also want to make sure I create the rock after the explosion completes its animation. Before I can do any of that, I need an array to keep track of all the rocks. First, I want to refactor my initrocks function which creates a rock, by extracting all the code into a new function.
data:image/s3,"s3://crabby-images/476ad/476ad69f1aa3cf40723b178ecc57abbdd42126bf" alt="Screen Shot 2021-04-14 at 8.31.22 AM"
Becomes:
data:image/s3,"s3://crabby-images/cf184/cf18487354c19fa8299925fdaa342eb181002e7b" alt="Screen Shot 2021-04-14 at 8.34.58 AM"
I also need to pass in the x coordinate of the rock since I want to position it at the point of impact.
data:image/s3,"s3://crabby-images/c8e08/c8e08feb91124a08b73e4eb009577240a5d36f00" alt="Screen Shot 2021-04-14 at 8.36.53 AM"
Next I want to add the rock to the therocks array. I could do this in either function, but it feels better in initrocks, but would make the code simpler in createarock. I won't go into why, but I'll put it in initrocks where it belongs.
data:image/s3,"s3://crabby-images/fb099/fb099dee8bd3d52fcf97b99c0c729e5f25c87c6b" alt="Screen Shot 2021-04-14 at 9.01.03 AM"
I now return a rock object from createarock. I insert the rock into the array on line 288. One interesting thing is that in Lua, I would use the command:
table.insert(therocks, rock)
But PICO-8 doesn't seem to support that command and uses add instead.
I now need to change all of the code that deals with rock to use the array instead.
data:image/s3,"s3://crabby-images/65786/65786773dd5291b8c35ff1d010ecccaaa29cb0c8" alt="Screen Shot 2021-04-14 at 8.48.31 AM"
Becomes:
data:image/s3,"s3://crabby-images/6e579/6e5792003116abb026537480ba5ad4476ff6a63a" alt="Screen Shot 2021-04-14 at 8.51.12 AM"
Also, unlike Lua, PICO-8 has a simplified syntax for looping over an array (table). I should add a return after line 174, but this is good enough for now.
data:image/s3,"s3://crabby-images/fba41/fba412ec27a2d72f87ddff338a38016e383c3ac0" alt="Screen Shot 2021-04-14 at 8.53.41 AM"
beomes:
data:image/s3,"s3://crabby-images/1f419/1f419c4b8ababc261ab208e7a8fe28a7c7a97cce" alt="Screen Shot 2021-04-14 at 8.54.58 AM"
Again, I'm just looping through each of the rocks in the array.
Just to make sure everything is as it was before all of these changes, I run the program and see it works as expected.
Now, I need to create a new rock at the point of impact. There are again two places I can do this; either where I reset the meteor after the collision or where I draw the explosion (and call resetmeteor).
.
data:image/s3,"s3://crabby-images/7da97/7da97c2c783182e71f7ab8e99b38b65f95216e2f" alt="Screen Shot 2021-04-14 at 9.05.59 AM"
data:image/s3,"s3://crabby-images/7dc0d/7dc0d853316a3b96abbe03508e512308cf13d93d" alt="Screen Shot 2021-04-14 at 9.04.12 AM"
Both options have a code-stink about them (It feels wrong to put the code in either.). That tells me I should refactor drawexplosion. I'll do a minor refactor by moving line 335 into its own function and handle the rock there.
data:image/s3,"s3://crabby-images/a6b59/a6b59a3941a3ea3b7f2f44d5629156992c120e39" alt="Screen Shot 2021-04-14 at 9.25.05 AM"
This feels a bit better. Lines 325-326 creates a new rock at the position of the meteor and adds the new rock to the array. These two lines look similar to the two I added in initrocks. Let's refactor.
data:image/s3,"s3://crabby-images/3e4e1/3e4e1a5c9c107f8c8269c08bf031a5be4e7262c0" alt="Screen Shot 2021-04-14 at 9.30.14 AM"
data:image/s3,"s3://crabby-images/98011/9801193dcc425d6d91f9f76e349da18e6e533313" alt="Screen Shot 2021-04-14 at 9.30.45 AM"
The new function at line 291 simplifies the code a bit. I also now create the initial rock at a random location. Let's run it and see what happens.
data:image/s3,"s3://crabby-images/c9316/c93162b990a76afefd463d275af06eba91354cb0" alt="Screen Shot 2021-04-14 at 9.32.24 AM"
That looks good, apart from the problems I need to address in the last two points of:
I'll tackle them next time. Again, here is the cart:
data:image/s3,"s3://crabby-images/c7e00/c7e004561c3da4c5f9356dd4971189ce4b9d3f90" alt="ferb.p8"
- - place more rocks (this means creating an array to track the rocks and changing existing code to use the array)
- - put an upper limit to the number of rocks placed.
- - space the rocks (which means spacing the meteors)
I'll tackle these problems one at a time, and do point number 1 today.
Create an Array of Rocks
Rocks are objects, so I can just create another rock object at the point of impact. I also want to make sure I create the rock after the explosion completes its animation. Before I can do any of that, I need an array to keep track of all the rocks. First, I want to refactor my initrocks function which creates a rock, by extracting all the code into a new function.
data:image/s3,"s3://crabby-images/476ad/476ad69f1aa3cf40723b178ecc57abbdd42126bf" alt="Screen Shot 2021-04-14 at 8.31.22 AM"
Becomes:
data:image/s3,"s3://crabby-images/cf184/cf18487354c19fa8299925fdaa342eb181002e7b" alt="Screen Shot 2021-04-14 at 8.34.58 AM"
I also need to pass in the x coordinate of the rock since I want to position it at the point of impact.
data:image/s3,"s3://crabby-images/c8e08/c8e08feb91124a08b73e4eb009577240a5d36f00" alt="Screen Shot 2021-04-14 at 8.36.53 AM"
Next I want to add the rock to the therocks array. I could do this in either function, but it feels better in initrocks, but would make the code simpler in createarock. I won't go into why, but I'll put it in initrocks where it belongs.
data:image/s3,"s3://crabby-images/fb099/fb099dee8bd3d52fcf97b99c0c729e5f25c87c6b" alt="Screen Shot 2021-04-14 at 9.01.03 AM"
I now return a rock object from createarock. I insert the rock into the array on line 288. One interesting thing is that in Lua, I would use the command:
table.insert(therocks, rock)
But PICO-8 doesn't seem to support that command and uses add instead.
I now need to change all of the code that deals with rock to use the array instead.
data:image/s3,"s3://crabby-images/65786/65786773dd5291b8c35ff1d010ecccaaa29cb0c8" alt="Screen Shot 2021-04-14 at 8.48.31 AM"
Becomes:
data:image/s3,"s3://crabby-images/6e579/6e5792003116abb026537480ba5ad4476ff6a63a" alt="Screen Shot 2021-04-14 at 8.51.12 AM"
Also, unlike Lua, PICO-8 has a simplified syntax for looping over an array (table). I should add a return after line 174, but this is good enough for now.
data:image/s3,"s3://crabby-images/fba41/fba412ec27a2d72f87ddff338a38016e383c3ac0" alt="Screen Shot 2021-04-14 at 8.53.41 AM"
beomes:
data:image/s3,"s3://crabby-images/1f419/1f419c4b8ababc261ab208e7a8fe28a7c7a97cce" alt="Screen Shot 2021-04-14 at 8.54.58 AM"
Again, I'm just looping through each of the rocks in the array.
Just to make sure everything is as it was before all of these changes, I run the program and see it works as expected.
Creating New Rocks
Now, I need to create a new rock at the point of impact. There are again two places I can do this; either where I reset the meteor after the collision or where I draw the explosion (and call resetmeteor).
.
data:image/s3,"s3://crabby-images/7da97/7da97c2c783182e71f7ab8e99b38b65f95216e2f" alt="Screen Shot 2021-04-14 at 9.05.59 AM"
data:image/s3,"s3://crabby-images/7dc0d/7dc0d853316a3b96abbe03508e512308cf13d93d" alt="Screen Shot 2021-04-14 at 9.04.12 AM"
Both options have a code-stink about them (It feels wrong to put the code in either.). That tells me I should refactor drawexplosion. I'll do a minor refactor by moving line 335 into its own function and handle the rock there.
data:image/s3,"s3://crabby-images/a6b59/a6b59a3941a3ea3b7f2f44d5629156992c120e39" alt="Screen Shot 2021-04-14 at 9.25.05 AM"
This feels a bit better. Lines 325-326 creates a new rock at the position of the meteor and adds the new rock to the array. These two lines look similar to the two I added in initrocks. Let's refactor.
data:image/s3,"s3://crabby-images/3e4e1/3e4e1a5c9c107f8c8269c08bf031a5be4e7262c0" alt="Screen Shot 2021-04-14 at 9.30.14 AM"
data:image/s3,"s3://crabby-images/98011/9801193dcc425d6d91f9f76e349da18e6e533313" alt="Screen Shot 2021-04-14 at 9.30.45 AM"
The new function at line 291 simplifies the code a bit. I also now create the initial rock at a random location. Let's run it and see what happens.
data:image/s3,"s3://crabby-images/c9316/c93162b990a76afefd463d275af06eba91354cb0" alt="Screen Shot 2021-04-14 at 9.32.24 AM"
That looks good, apart from the problems I need to address in the last two points of:
- DONE - place more rocks (this means creating an array to track the rocks and changing existing code to use the array)
- - put an upper limit to the number of rocks placed.
- - space the rocks (which means spacing the meteors)
I'll tackle them next time. Again, here is the cart:
data:image/s3,"s3://crabby-images/c7e00/c7e004561c3da4c5f9356dd4971189ce4b9d3f90" alt="ferb.p8"