Home

Sunday, October 26, 2025

CAGD 470 Sprint Blog 4

10/26/2025

Sprint 4 Kickoff

For this sprint I had one huge focus that I needed to accomplish. Essentially it was to convert all of our old movement system to Unity’s new input system. At the start I had underestimated how much time this would actually end up taking me since I just thought it would be a simple change, but it ended up being more difficult than I thought. The problem was I was trying to quickly convert all of our old movement functions to now work through the new input system directly without first considering that the whole movement functions would need to be reworked.

For example, the old way of moving right and left was through directly telling my players transform.position to now move either left or right and the new input system does not seem to like that. Another big contributor to the problem was the fact that I did not stop and test my code every couple minutes like I should have been. Instead, I tried to rewrite and try to match everything with the new input system and then run my code. Long story short, I ended up getting all 3 of my main old movement functions (Move, Jump & Dash) to finally work in the end, but it would have been done a lot sooner and easier if I had been more patient with it.

Alongside this entire mess I was also trying to productively clean up and decouple a lot of my old code in order to get it to look much more professional and cleaner. This was important to do since my old script basically had a lot of moving parts all tied together. Essentially, I had all of the 3-movement mechanics, the collision detection as well as the glowing functions all in 1 script totaling over 400 lines of code. This was definitely an inefficient way of doing things since I would constantly need to go back to this script and alter or check the code for testing and debugging.

What I did for this was separate the players mechanics from the collision events into their own scripts that would tie directly back to my player prefab. Inside those scripts I also made headers for all the variables that could basically be considered in the same group. I set a bunch of those variables to private as well since I would not need to edit them inside the inspector window and would clear up a lot of space for the ones I did need. To summarize my player prefab would now have 2 scripts attached, one for all the player inputs/mechanics and one for all the collision tracking. This would now make it 10 times easier to go and update something in the code if I needed to in the future based on the thing I am trying to add. 



By the end of this sprint, I was also given some tasks to work on implementing a key and door system. So, what I did for this was create 2 simple prefabs in the meantime of a key and one of a door. As soon as I did that, I gave them colliders, and I was able to get them to play animations that I made inside the Editor. For the keys animation I made it so that it could be a looped animation that basically looks like the key is spinning and floating in space while the door was just a simple change in y position. Then I moved on to throwing the animation of the door into Unity’s Animator so that it could be listed as a clip. I would then play that clip through code whenever my player has collected a key and has collided with the door. This was simple enough to do after all my movement and code was polished up so I'm glad I was able to accomplish a lot this sprint.


Sunday, October 12, 2025

CAGD 470 Sprint Blog 3

10/12/2025

Sprint 3 Kickoff

At the start of this sprint, I was assigned some more programming tasks and a couple other ones that involved setting up our UI to showcase our players charges.


As I mentioned one of the key things I worked on this sprint was creating our games Sun Pillar working. This required quickly creating a simple prefab that I could use to test. I made a mock-up prefab and attached a collider to it so that my player could detect collisions with it. After that I made a tag for it and attached it to itself in the inspector. The way I got it to work was by creating a function inside my player controller script that would allow for this pillar to recharge my player’s sun charges if they collided with and stood there for a total of 5 seconds. 




After I made that I also wanted it to only grant me 4 charges and once I had the max amount of charges it would no longer keep charging our player. This was simple enough since I already had the recharge function working properly. The last thing I needed for this to fulfill my assigned card was to showcase some sort of visual for our character model charging.

This was perhaps the hardest thing to tackle since I had never altered any material in unity before but after a couple of searches, I was able to figure it out. I had to grab a reference of my players assigned material through code and I did that by assigning it in my start function.  Once I did that, I created 2 new functions, one that would play a pulse glow mechanic to show the physical glow when charging and the other to fade out the glow in a smooth way when my player reached full charge. I was able to make them work by creating a new color variable that would essentially be my new glowing color and setting my players material to this new color for a short period of time. Along with that I made some other variables that would handle the glow intensity.


Once I had these 2 functions working properly, I made sure to call them whenever my recharge function also gets called in my update. Getting this to work was so awesome since it is a huge feature we wanted to implement this time around. 






After all that I moved on to making sure our 2D sprites were properly hooked up to our UI so that we can now effectively display charges on screen. Since the 2D sprites were made last sprint, it was easy enough to have them hooked up. What I did for this was to go back into my player controller script and make 4 new variables for game objects. This 4 would be specific for each one of my groups of UI images I made inside of unity.



Each group consisted of 2 images, one to showcase when the charge is active and the other show it empty. Once I had those ready, I simply wrote 1 if statement followed by 4 else ifs in order to set those game object variables to off. It was easy enough to go down the line for each scenario where in the first statement they are all active and in the last one they are not. They all essentially just check to see how much sun charges my player has. 

That was pretty much my main focus this sprint with the exception of a few other things and ultimately, I think my team really stepped up this sprint and I believe we are beginning to head in the right direction.


CAGD 470 Sprint Blog 6

11/20/2025 Sprint 6 Kickoff For this sprint I focused on a couple of things that I needed to definitely take care of since last time. One of...