2.2.2 Cycle 3
Last updated
Last updated
This cycle I focused on getting a working camera system set up to make the experience of playing more engaging with a top-down camera angle. I am to get the camera to actively track and follow the character created in whilst also interacting with map barriers.
camera
The camera class here has uses for deciding what properties the camera should operate on such as the viewport or information about the scroll values
player / faune
Variable that stores all of the information and properties about the character such as position
bounds
Stores information about the map borders and where the camera should stop scrolling
Whilst the Phaser library contains documentation surrounding the use of the camera, lots of these resources were outdated creating for a process of trial and error to get the following aspects working properly. Most of the code took place in the Game.ts file since trying to create a separate file for simply camera controls created some errors regarding importing into the main scene.
This cycle whilst having a simple outcome and seeming relatively simple faced quite challenging regarding documentation and having to be very specific with measurements since many errors occurred in trying to be scalable.
1
Run code
Everything should still be visible with the new camera property taking control
Everything loads in correctly but positioning is not correct
Fail
2
Attempt to move character
Player moves around and the camera moves accordingly
Camera moves accordingly but will not centre onto the character
Fail
3
Move character to border of map
Camera should stop following the camera once it collides with the border to hide barriers
Camera does not stop when encountering borders and shows the black space beyond the map
Fail
After this failure in testing I had to make changes on how the camera was set up in the game.ts file which is where I had to make changes regarding measurements inside other files such as index.html and using this. to point to a specific object.
One example of a change made to the index.html file was making sure that due to the size of the map players do not use the scroll bar to make sure the camera is uncentered and taking them out of the experience since it is a web based game. To account for this I hid the overflow scroll bar and went through processes of using specific measurements to centre the camera but decided using the inner width and inner height divided allowed the game to be more accessible and scalable across different device sizes.
Changes I had to make to the Game.ts involved having to give specific measurements for the game map borders since they were not registering when using estimate numbers. Another example was using this. to point to specific objects and creating the cameras.main making it usable across the project. This also allowed me to properly use this to interact with the character "faune" which has got its own separate folders and files across the project making the overall project readable but still operational.
1
Run code
Everything should still be visible with the new camera property taking control
As expected
Pass
2
Attempt to move character
Player moves around and the camera moves accordingly
As expected
Pass
3
Move character to border of map
Camera should stop following the camera once it collides with the border to hide barriers
As expected
Pass
This video demonstrates the character moving around the map with the camera following the character's movements until it reaches the world border and stops tracking the character until it is able to do so again.