首页 > 作文

HTML5 Canvas编写五彩连珠(6):试玩

更新时间:2023-04-03 02:05:31 阅读: 评论:0

上节中讲了如何寻路,在和朋友们讨论时都反应有时走的不太对,绕远路了,其实代码主要是大方向的判断 比如目标在右上,那应该是先右还是先上 这个并没有做处理,如果这个做了处理,效果会更好一些,但也难免会走弯路。 贪心就是这样,不是最优,接近最优。也希望其他的同学有意见的可以讨论下。我这也只是个人想法。

  既然可以走动了,那就可以判断是否可以消除同样颜色的行、列或斜线了。只要>=5个同样的色球,就清除他们,并且可以继续移动。如果不可以清除,那就再增加3个球。

[javascript]
clearline: function (x1, y1, color, isclick) { if (this.impty(x1, y1))
{ if (isclick) game.ready.flyin();
return;
};
//给定一个坐标,看是否有满足的line可以被消除 //4根线 一 | / \
var current = this.getbubble(x1, y1);
if (!current.color) { console.log(current); }
var arr1, arr2, arr3, arr4; arr1 = this.bubbles[y1];
//横线很简单,就是数组的一项,现成的 arr2 = [];
for (var y = 0;
y < game.cellcount;
y++) arr2.push(this.getbubble(x1, y));
//竖线就是一列。
arr3 = [current];
arr4 = [current];
for (var i = 1;
i < game.cellcount ;
i++) { if (x1 – i >= 0 && y1 – i >= 0)
//\斜线的上半部分… arr3.unshift(this.getbubble(x1 – i, y1 – i));
if (x1 + i < game.cellcount && y1 + i < game.cellcount)
//\斜线的下半部分 arr3.push(this.getbubble(x1 + i, y1 + i));
if (x1 – i >= 0 && y1 + i < game.cellcount)
// /斜线的下半部分 arr4.push(this.getbubble
(x1 – i, y1 + i));
if (x1 + i < game.cellcount && y1 – i >= 0)
// /斜线的上班部分 arr4.unshift(this.getbubble(x1 + i, y1 – i));
}
var line1 = getline(arr1);
var line2 = getline(arr2);
var line3 = getline(arr3);
var line4 = getline(arr4);
var line = line1.concat(line2).concat(line3).concat(line4);
if (line.length < 5) {
if (isclick) game.ready.flyin();
return; }
el {
var me = this;
var i = 0;
game.play(“clearline”, function ()
{
if (i == line.length)
{ game.score.addscore(line.length); game.stop(“clearline”);
me.ismoving = fal;
//game.ready.flyin();
return;
} me.ismoving = true;
var p = line[i];
me.tbubble(p.x, p.y, null);
i++; },
100);
} function getline(bubbles) { var line = [];
for (var i = 0;
i < bubbles.length; i++) { var b = bubbles[i];
if (b.color == color)
{ line.push({ “x”: b.x, “y”: b.y });
} el {
if (line.length < 5) line = [];
el return line;
}
}
if (line.length < 5) return [];
return line;
}
},

clearline: function (x1, y1, color, is外资撤离中国的原因click) {
if (this.impty(x1, y1)) {
if (isclick) game.ready.flyin();
return;
};
//给定一个坐标,看是否有满足的line可以被消除
//4根线 一 | / \
var current = this.getbubble(x1, y1);
if (!current.color) { console.log(current);
} var arr1, arr2, arr3, arr4; arr1 = this.bubbles[y1];
//横线很简单,就是数组的一项,现成的 arr2 = [];
for (var y = 0;
y < game.cellcount;
y++) arr2.push(this.getbubble(x1, y));
//竖线就是一列。
arr3 = [current];
arr4 = [current];
for (var i = 1;
i < game.cellcount ;
i++) { if (x1 – i >= 0 && y1 – i >= 0)
//\斜线的上半部分… arr3.unshift(this.getbubble(x1 – i, y1 – i));
if (x1 + i < game.cellcount && y1 + i < game.cellcount)
//\斜线的下半部分 arr3.push(this.getbubble(x1 + i, y1 + i));
if (x1 – i >= 0 && y1 + i < game.cellcount)
// /斜线的下半部分 arr4.push(this.getbubble(x1 – i, y1 + i));
if (x1 + i < game.cellcount && y1 – i >= 0)
// /斜线的上班部分 arr4.unshift(this.getbubble(x1 + i, y1 – i));
}
var line1 = getline(arr1);
var line2 = getline(arr2);
var line3 = getline(arr3);
var line4 = getline(arr4);
var line = line1.concat(line2).concat(line3).concat(line4);
if (line.length < 5) { if (isclick) game.ready.flyin();
return;
} el {
var me = this;
var i = 0; game.play(“clearline”, function () {
if (i == line.length) { game.score.addscore(line.length);
game.stop(“clearline”);
me.ismoving = fal;
//game.ready.flyin公元前211年();
return;
} me.ismoving = true;
var p = line[i];
me.tbubble(p.x, p.y, null);
i++;
}, 100);
} function getline(bubbles)
{ var line = [];
for (var i = 0;
i < bubbles.length;
i++) { var b = bubbles[i];
if (b.color == color) {
line.push({ “x”: b.x, “y”: b.y });
} el { if (line.length < 5) line = [];
el return li贡菊杭白菊ne;
}
}
if (line.length < 5) return [];
return line;
}
},
大家可以看看代码,主要有两点 1、或许需要处理的 横竖斜线 4个数组,然后看这4个数组是否有连续的。判断是否连续只需要一个状态数组来维持就可以了。
由于考虑到同时消除多行的情况,所以要把连续的line 连接在一起,并在结算得分时考虑奖励。
isclick参数主要用于判断是否是用户点击进行消行的还是新泡泡飞入产生的。 如果达不到消行条件并且是飞入的,那就不能再调用飞入了,否则死循环了。

满足的消行代码也比较简单,就是播放一个消行动画,其实这个动画真心没劲,要想设计好些可以做个渐变偏移消除。 现在我发现起初没有设计一个数组来维护状态有些不太明智,因为还有奖励的星星和炸弹要绘制,挺麻烦的。。 那么,把积分显示出来吧。 这样就可以先试玩起来了:)

[javascript]
game.score = { basic: 0, oper对人的评价ate: 0, star1: 0, star2: 0, boom: 0, draw: function ()
{ var startx = game.cellwidth * 10 + game.map.startx;
var starty = game.map.starty;
var ctx = game.ctx; ctx.save();
ctx.translate(startx, starty);
ctx.clearrect(0, 0, 150, 400);
ctx.strokestyle = “#456”;
//ctx.strokerect(0, 0, 150, 200);
ctx.font = “24px 微软雅黑”;
ctx.fillstyle = “#fefefe”;
ctx.filltext(“score:” + (this.basic * 5 + this.star1 * 8 + this.star2 初二物理电学题* 10 + this.boom * 20), 0, 30); ctx.stroke();
ctx.restore();
}, addscore: function (length) { switch (length) { ca 5: this.basic++; break;
ca 6: this.star1++;
break;
ca 7: this.star2++;
break;
default: this.boom++;
break;
} this.draw();
console.log(this.score);
},
};

game.score = { basic: 0, operate: 0, star1: 0, star2: 0, boom: 0, draw: function () {
var startx = game.cellwidth * 10 + game.map.startx;
var starty = game.map.starty;
var ctx = game.ctx; ctx.save();
ctx.translate(startx, starty);
ctx.clearrect(0, 0, 150, 400);
ctx.strokestyle = “#456”;
//ctx.strokerect(0, 0, 150, 200); ctx.font = “24px 微软雅黑”;
ctx.fillstyle = “#fefefe”;
ctx.filltext(“score:” + (this.basic * 5 + this.star1 * 8 + this.star2 * 10 + this.boom * 20), 0, 30); ctx.stroke();
ctx.restore();
}, addscore: function (length)
{ switch (length)
{ ca 5: this.basic++;
break;
ca 6: this.star1++;
break;
ca 7: this.star2++;
break; default: this.boom++;
break;
} this.draw();
console.log(this.score);
},
};

第三节在设计里谈到了 百搭星和炸弹,我太懒了,不打算讲了,因为这些处理也没有什么复杂的,html5 canvas的的基础学习也算可以了。后面应该学一些更深入的东西,比如如何处理性能、物体碰撞、运动学神马的。。。

现在游戏应该还有bug,大家可以看看代码发现吧,这个系列就到这了,谢谢大家。

下载:

摘自 君之蘭

本文发布于:2023-04-03 02:05:29,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/f54464659243edb15080e8b53fe983e0.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:HTML5 Canvas编写五彩连珠(6):试玩.doc

本文 PDF 下载地址:HTML5 Canvas编写五彩连珠(6):试玩.pdf

标签:斜线   数组   半部   竖线
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图