forked from nighthawkcoders/teacher_portfolio
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
5 changed files
with
438 additions
and
58 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,329 @@ | ||
{ | ||
"cells": [ | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"---\n", | ||
"comments: true\n", | ||
"layout: notebook\n", | ||
"title: Revised Animation Lesson\n", | ||
"description: Lesson on adding animation to OOP Game\n", | ||
"type: ccc\n", | ||
"toc: true\n", | ||
"courses: { csse: {week: 15} }\n", | ||
"---" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Basic Steps of Animation\n", | ||
"\n", | ||
"Below is a sprite of Mr. Lopez. This was the first sprite created for his spritesheet, which outlines the animation of his movement \n", | ||
"frame by frame.\n", | ||
"\n", | ||
"<img src=\"{{ site.baseurl }}/images/gameimages/1_lopez.png\" alt=\"1_lopez\" style=\"height: 138px; width: 156px\">" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"Below is the spritesheet of Mr. Lopez. Each row has a different side of him, because in the project that we used this in, he was able to move freely in all 4 directions. His animation is simple, and depicts basic movement.\n", | ||
"\n", | ||
"<img src=\"{{ site.baseurl }}/images/gameimages/lopezspritesheet3.png\" alt=\"lopezspritesheet3\" style=\"height: 184px; width: 210px;\">" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"The first change that we made to the spritesheet was the addition of Mr. Lopez's cane. This was done to show a simple difference in how sprites can appear in the game. Our next step in animation will be drawing new sprites for running and idle animation. \n", | ||
"\n", | ||
"<img src=\"{{ site.baseurl }}/images/gameimages/canelopezspritesheet.png\" alt=\"canelopezspritesheet\" style=\"height: 184px; width: 210px\">" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"Below is the spritesheet of spritesheet with a few more rows idle animation, running, and punch (attack).\n", | ||
"\n", | ||
"<img src=\"{{ site.baseurl }}/images/gameimages/lopezanimation.png\" alt=\"lopezanimation\" style=\"height: 368; width: 732\">" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Additions to Game Levels\n", | ||
"\n", | ||
"Adding new animations gives the player new capabilities. For example, drawing sprites for running allows the player to feel as if they are running in the game, rather than walking everywhere. \n", | ||
"\n", | ||
"In our code, running will be based on speed, so there will be different lines in the spritesheet corresponding to different speeds (i.e. row 1 = walking)." | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Step 1\n", | ||
"\n", | ||
"Download this image and change the file path to fit it. \n", | ||
"\n", | ||
"[Spritesheet Linked Here](https://github.com/DeanPhillips24/csse2_individual/blob/main/images/gameimages/lopezanimation.png)\n", | ||
"\n", | ||
"\n", | ||
"The code is very easy to modify with new animations. The biggest change would be the changing of rows and frames, which we will be changing next. \n", | ||
"Under the players section of the var assets, make a new player for Lopez. " | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"vscode": { | ||
"languageId": "javascript" | ||
} | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"players: {\n", | ||
" lopez: {\n", | ||
" src: \"/filepath/lopezanimation.png\", // Modify this to match your file path\n", | ||
" width: 46,\n", | ||
" height: 52.5,\n", | ||
" idle: { row: 6, frames: 1, idleFrame: {column: 1, frames: 0} },\n", | ||
" a: { row: 1, frames: 4, idleFrame: { column: 1, frames: 0 } }, // Right Movement\n", | ||
" d: { row: 2, frames: 4, idleFrame: { column: 1, frames: 0 } }, // Left Movement \n", | ||
" runningLeft: { row: 5, frames: 4, idleFrame: {column: 1, frames: 0} },\n", | ||
" runningRight: { row: 4, frames: 4, idleFrame: {column: 1, frames: 0} },\n", | ||
" s: {}, // Stop the movement \n", | ||
" }\n", | ||
" }," | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Step 2\n", | ||
"Make a new level in the oop-game-levels.md file by adding this to the game level section.\n", | ||
"Ensure that your tags are all the same, otherwise it will not work (i.e. player: assets.players.lopez)." | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"vscode": { | ||
"languageId": "javascript" | ||
} | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"new GameLevel( {tag: \"lopez\", background: assets.backgrounds.avenida, platform: assets.platforms.grass, scaffold: assets.scaffolds.brick, player: assets.players.lopez, enemy: assets.enemies.goomba, callback: testerCallBack } );" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Step 3\n", | ||
"\n", | ||
"Create a copy of Player.js titled Lopez.js. Add the speedLimit here. " | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"vscode": { | ||
"languageId": "javascript" | ||
} | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"export class Lopez extends Character {\n", | ||
" // constructors sets up Character object \n", | ||
" constructor(canvas, image, speedRatio, playerData, speedLimit) { // Add speedLimit\n", | ||
" super(canvas, image, speedRatio, playerData.width, playerData.height);" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Step 4\n", | ||
"\n", | ||
"Add this property of speedLimit just under your event listeners." | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"vscode": { | ||
"languageId": "javascript" | ||
} | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"// Additional Property for Speed Limit\n", | ||
" this.speedLimit = speedLimit;\n", | ||
" this.currentSpeed = 0;\n", | ||
" this.acceleration = 0.11; // Adjust based on preference\n", | ||
" this.deceleration = 0.1; // Adjust based on preference " | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Step 5\n", | ||
"\n", | ||
"Apply the speedLimit under the update function. " | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"vscode": { | ||
"languageId": "javascript" | ||
} | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"// Player updates\n", | ||
" update() {\n", | ||
" // Adjust speed based on pressed keys\n", | ||
" if (this.pressedKeys['a'] && this.movement.left) {\n", | ||
" this.currentSpeed -= this.acceleration;\n", | ||
" } else if (this.pressedKeys['d'] && this.movement.right) {\n", | ||
" this.currentSpeed += this.acceleration;\n", | ||
" } else {\n", | ||
" // Decelerate when no movement keys are pressed\n", | ||
" this.currentSpeed *= (1 - this.deceleration);\n", | ||
" }\n", | ||
"\n", | ||
" // Apply speed limit\n", | ||
" if (Math.abs(this.currentSpeed) > this.speedLimit) {\n", | ||
" this.currentSpeed = this.currentSpeed > 0 ? this.speedLimit : -this.speedLimit;\n", | ||
" }" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Step 6\n", | ||
"\n", | ||
"Now we will be adding code so that the character transitions from moving left and right to smoothly moving into a running animation. The first thing you want to do is add a threshold so that when the character reaches a certain speed the sprite image switches to that sprite row.\n", | ||
"\n", | ||
"This will go under where it says the\n", | ||
" //Player update\n", | ||
" update(){" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"vscode": { | ||
"languageId": "javascript" | ||
} | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"// Apply speed limit\n", | ||
" if (Math.abs(this.currentSpeed) > this.speedLimit) {\n", | ||
" this.currentSpeed = this.currentSpeed > 0 ? this.speedLimit : -this.speedLimit;\n", | ||
" }\n", | ||
"\n", | ||
" // Update player position based on speed\n", | ||
" this.x += this.currentSpeed;\n", | ||
"\n", | ||
" // Check for speed threshold to change sprite sheet rows\n", | ||
" const walkingSpeedThreshold = 1; // Walking speed threshold\n", | ||
" const runningSpeedThreshold = 5; // Running speed threshold\n" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Step 7\n", | ||
"Next we need to add code so that it can switch rows on the sprite sheet picture based on which direction you are moving." | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"vscode": { | ||
"languageId": "javascript" | ||
} | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"if (Math.abs(this.currentSpeed) >= runningSpeedThreshold) {\n", | ||
" // Change sprite sheet row for running\n", | ||
" if (this.currentSpeed > 0) {\n", | ||
" this.setFrameY(this.playerData.runningRight.row);\n", | ||
" } else {\n", | ||
" this.setFrameY(this.playerData.runningLeft.row);\n", | ||
" }\n", | ||
" } else if (Math.abs(this.currentSpeed) >= walkingSpeedThreshold) {\n", | ||
" // Change sprite sheet row for walking\n", | ||
" if (this.currentSpeed > 0) {\n", | ||
" this.setFrameY(this.playerData.d.row);\n", | ||
" } else {\n", | ||
" this.setFrameY(this.playerData.a.row);\n", | ||
" }\n", | ||
" } else {\n", | ||
" // Revert to normal animation if speed is below the walking threshold\n", | ||
" this.setFrameY(this.playerData.idle.row);\n", | ||
" }\n", | ||
"\n", | ||
" // Perform super update actions\n", | ||
" super.update();\n", | ||
" }" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"This piece of code goes right under the previous code that we just did.\n", | ||
"Be sure to add Lopez imports to necessary JS files so it applies to different game levels. " | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Homework\n", | ||
"\n", | ||
"1. Implement running animations to Lopez sprite. \n", | ||
"2. Adjust speed thresholds to your preference.\n", | ||
"\n", | ||
"Challenges (not required):\n", | ||
"Apply running animations to other characters. \n", | ||
"Make the punching animation binded to a key and make it kill an enemy. \n", | ||
"\n", | ||
"If there are any problems, please check our Lopez.js file linked [here.](https://github.com/DeanPhillips24/csse2_oop_game/blob/main/assets/js/platformer/Lopez.js)" | ||
] | ||
} | ||
], | ||
"metadata": { | ||
"language_info": { | ||
"name": "python" | ||
}, | ||
"orig_nbformat": 4 | ||
}, | ||
"nbformat": 4, | ||
"nbformat_minor": 2 | ||
} |
Oops, something went wrong.