Html连环跳跃网页,html <canvas/>+js实现马里奥走动,跳跃

本文介绍了一个简单的马里奥游戏角色动画实现方案,通过JavaScript绘制到HTML5 Canvas中实现角色的左右移动及跳跃效果,并利用键盘事件触发不同动作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

6d57c7b7d91476c75e90830900acc6c4.png

直接贴代码:

马里奥走动跳跃

//定义数组图片集合

var marios = new Array("1.png", "2.png", "3.png");

var mario = new Image();

var canvas = document.getElementById("mycanvas");

var ctx = canvas.getContext("2d");

var i = 0;

var num = 0;

var isRight = true;

function init() {

draw(10)

}

function reset() {

if (i === 3) {

i = 0;

}

if (num > 1000) {

num = 0;

}

if (num < 0) {

num = 1000;

}

}

function draw(number) {

mario.src = marios[i];

ctx.clearRect(0, 0, 1000, 500)

ctx.drawImage(mario, num, 420);

num += number;

i++;

reset();

}

function up() {

var h = 420

var ss = setInterval(function () {

h -= 5;

if (isRight) {

num += 2;

} else {

num -= 2;

}

reset();

mario.src = marios[i];

ctx.clearRect(0, 0, 1000, 500)

ctx.drawImage(mario, num, h);

if (h === 100) {

clearInterval(ss)

var dd = setInterval(function () {

h += 5;

console.log(isRight)

if (isRight) {

num += 2;

} else {

num -= 2;

}

reset();

mario.src = marios[i];

ctx.clearRect(0, 0, 1000, 500)

ctx.drawImage(mario, num, h);

if (h === 420) {

clearInterval(dd)

}

}, 10)

}

}, 10)

i++;

}

document.onkeydown = keyDown;

function keyDown() {

if (event.keyCode == 38) {

// 上

up()

}

if (event.keyCode == 40) {

// 下

}

if (event.keyCode == 37) {

// 左

draw(-10)

isRight = false

}

if (event.keyCode == 39) {

// 右

isRight = true

draw(10)

}

if (event.keyCode == 32) {

// 空格

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值