canvas实现万圣节的猫和蝙蝠跳跃小游戏代码
代码语言:html
所属分类:游戏
代码描述:canvas实现万圣节的猫和蝙蝠跳跃小游戏代码,按鼠标左键或空格键进行跳跃避开红色的物体。
代码标签: canvas 万圣节 猫 蝙蝠 跳跃 小游戏 代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html> <html lang="en" > <head> <meta charset="UTF-8"> <style> @import url("https://fonts.googleapis.com/css2?family=Oxygen:wght@700&family=Work+Sans:wght@300;500&display=swap"); body { margin: 0; overflow: hidden; font-family: "Work Sans", sans-serif; background: radial-gradient( circle, rgba(7, 73, 71, 1) 2%, rgb(14, 44, 42) 90% ); } canvas { display: block; background-color: #f0f0f0; max-height: calc(100vh - 100px); margin: 50px auto; } .footer { position: fixed; bottom: 10px; right: 10px; color: white; font-size: 12px; text-align: right; font-family: monospace; } .footer a { color: white; text-decoration: none; } </style> </head> <body > <canvas id="gameCanvas"></canvas> <div class="footer"> Made with ❤️ by Marcus | Visit <a href="" target="_blank">Shopblocks</a> </div> <script id="rendered-js" > let debugMode = false; let currentTime = Date.now(); let score = 0; // Initialize the score let highScore = 0; // Initialize the high score const canvas = document.getElementById("gameCanvas"); const ctx = canvas.getContext("2d"); // Set canvas size canvas.width = window.innerWidth; canvas.height = window.innerHeight; const spriteSheet = new Image(); spriteSheet.src = ""; const gravity = 0.25; // Gravity force (adjust as needed) const airResistance = 0.14; // Air resistance to slow down the cat in mid-air const scale = 3; // Scale factor for the cat const catWidth = 32; // Width of each frame const catHeight = 32; // Height of each frame const initialObstacleSpeed = 2; let currentObstacleSpeed = initialObstacleSpeed; // Variable to track the current obstacle speed let isGameOver = false; const cat = { x: 16 * scale, // Initial x position (just off the left-hand side) y: canvas.height - canvas.height * 0.1 - catHeight * scale, // Initial y position (10% from the bottom) width: catWidth, // Width of each frame height: catHeight, // Height of each frame frameX: 0, // Current frame X coordinate frameY: 0, // Current frame Y coordinate speed: 5, // Cat movement speed jumpPower: -9, // Jump power (initial upward velocity) isJumping: false, // Is the cat currently jumping canDoubleJump: true, // Flag to indicate if the cat can double jump velocityY: 0, // Vertical velocity for jump jumpCount: 0, // Number of jumps in the air maxJumpCount: 2, // Maximum number of jumps allowed in the air (2 for double jump) onGround: true // Flag to indicate whether the cat is on the ground }; let animationId; let lastFrameUpdateTime = 0; const frameDuration = 100; // Duration in milliseconds for each frame (moved to global scope) const jumpCooldown = 300; // Milliseconds let lastJumpTime = 0; let lastCatX = cat.x; ctx.imageSmoothingEnabled = false; const obstacles = []; let obstacleSpeed = 2; // Adjust the speed as needed let gameStarted = false; // Flag to indicate if the game has started function generateObstacle() { const minObstacleHeight = 32; // Minimum obstacle height const maxObstacleHeight = 128; // Maximum obstacle height const minDistanceBetweenObstacles = 100; // Minimum distance between obstacles const maxDistanceBetweenObstacles = 300; // Maximum distance between obstacles const obstacleWidth = 32; // Adjust the width as needed const obstacleHeight = Math.floor( Math.random() * (maxObstacleHeight - minObstacleHeight + 1) + minObstacleHeight); const obstacleX = canvas.width + Math.floor( Math.random() * (maxDistanceBetweenObstacles - minDistanceBetweenObstacles + 1) + minDistanceBetweenObstacles); obstacles.push({ x: obstacleX, y: canvas.height - obstacleHeight, // Position on the floor width: obstacleWidth, height: obstacleHeight }); } function drawScore() { ctx.fillStyle = "white"; ctx.font = "20px monospace"; // Display the score in the top right corner ctx.textAlign = "right"; ctx.fillText("Score: " + score, canvas.width - 10, 30); // Display the high score if it's higher than 0 if (highScore > 0) { ctx.textAlign = "le.........完整代码请登录后点击上方下载按钮下载查看
网友评论0