pbootcms网站模板|日韩1区2区|织梦模板||网站源码|日韩1区2区|jquery建站特效-html5模板网

html5貪吃蛇游戲使用63行代碼完美實現_html5教程技

html5貪吃蛇游戲使用63行代碼完美實現_html5教程技巧HTML5中文學習網,是中國最大的HTML5中文門戶,為廣大HTML5愛好者提供各種HTML5資料,包括HTML5網站、HTML5資訊、HTML5應用、HTML5游戲、HT
點評:貪吃蛇,最主要的功能點:1、蛇的移動2、改變蛇的方向3、放置食物4、增加舍身5、怎么掛的,具體實現如下,簡單實用就60行,感興趣的朋友可以參考下哈,希望對大家有所幫助
以前也很少關注html5,感覺選擇html已經慢慢成為趨勢,想了解下。就找了個游戲學習了,寫完這個游戲感覺html5和js結合很緊密,如果js不是特別好。估計需要先補習下js,這個只是個人的建議,不一定準確。還有一個就是,思維和邏輯要特別清楚,不然寫游戲可能很痛苦。

貪吃蛇,最主要的功能點: 1,蛇的移動 2,改變蛇的方向 3,放置食物 4,增加舍身 5,怎么掛的。

第一次寫游戲,第一次寫html5 感覺還是很吃力的。寫完了,給大家分享下。互相交流.............不懂的或者有建議的,可以留言給我。。。代碼很短,就60行。

不過這個是個半成品,等寫完成了。再更新下

復制代碼
代碼如下:

<!DOCTYPE HTML>
<html>
<body>
<canvas id="myCanvas" width="400" height="400" style="border:1px solid #c3c3c3;"></canvas>
<script type="text/javascript">
var c=document.getElementById("myCanvas");
var time = 160 ; //蛇的速度
var cxt=c.getContext("2d");
var x = y = 8;
var a = 0; //食物坐標
var t = 20; //舍身長
var map = []; //記錄蛇運行路徑
var size = 8; //蛇身單元大小
var direction = 2; // 1 向上 2 向右 0 左 3下
interval = window.setInterval(set_game_speed, time); // 移動蛇
function set_game_speed(){ // 移動蛇
switch(direction){
case 1:y = y-size;break;
case 2:x = x+size;break;
case 0:x = x-size;break;
case 3:y = y+size;break;
}
if(x>400 || y>400 || x<0 || y<0){
alert("你掛了,繼續努力吧!失敗原因:碰壁了.....");window.location.reload();
}
for(var i=0;i<map.length;i++){
if( parseInt(map[i].x)==x && parseInt(map[i].y)==y){
alert("你掛了,繼續努力吧!失敗原因:撞到自己了.....");window.location.reload();
}
}
if (map.length>t) { //保持舍身長度
var cl = map.shift(); //刪除數組第一項,并且返回原元素
cxt.clearRect(cl['x'], cl['y'], size, size);
};
map.push({'x':x,'y':y}); //將數據添加到原數組尾部
cxt.fillStyle = "#006699";//內部填充顏色
cxt.strokeStyle = "#006699";//邊框顏色
cxt.fillRect(x, y, size, size);//繪制矩形
if((a*8)==x && (a*8)==y){ //吃食物
rand_frog();t++;
}
}
document.onkeydown = function(e) { //改變蛇方向
var code = e.keyCode - 37;
switch(code){
case 1 : direction = 1;break;//上
case 2 : direction = 2;break;//右
case 3 : direction = 3;break;//下
case 0 : direction = 0;break;//左
}
}
// 隨機放置食物
function rand_frog(){
a = Math.ceil(Math.random()*50);
cxt.fillStyle = "#000000";//內部填充顏色
cxt.strokeStyle = "#000000";//邊框顏色
cxt.fillRect(a*8, a*8, 8, 8);//繪制矩形
}
// 隨機放置食物
rand_frog();
</script>
</body>
</html>

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。
主站蜘蛛池模板: 匀胶机旋涂仪-声扫显微镜-工业水浸超声-安赛斯(北京)科技有限公司 | 物流公司电话|附近物流公司电话上门取货 | 聚合氯化铝价格_聚合氯化铝厂家_pac絮凝剂-唐达净水官网 | 空调风机,低噪声离心式通风机,不锈钢防爆风机,前倾皮带传动风机,后倾空调风机-山东捷风风机有限公司 | 模型公司_模型制作_沙盘模型报价-中国模型网| 工业冷却塔维修厂家_方形不锈钢工业凉水塔维修改造方案-广东康明节能空调有限公司 | 清洁设备_洗地机/扫地机厂家_全自动洗地机_橙犀清洁设备官网 | 等离子表面处理机-等离子表面活化机-真空等离子清洗机-深圳市东信高科自动化设备有限公司 | 合肥汽车充电桩_安徽充电桩_电动交流充电桩厂家_安徽科帝新能源科技有限公司 | 数字展示在线_数字展示行业门户网站 | 青岛侦探调查_青岛侦探事务所_青岛调查事务所_青岛婚外情取证-青岛狄仁杰国际侦探公司 | 山东氧化铁红,山东铁红-淄博科瑞化工有限公司 | 红外光谱仪维修_二手红外光谱仪_红外压片机_红外附件-天津博精仪器 | 中宏网-今日新闻-财经新闻| 智慧旅游_智慧景区_微景通-智慧旅游景区解决方案提供商 | 管家婆-管家婆软件-管家婆辉煌-管家婆进销存-管家婆工贸ERP | 金库门,金库房,金库门厂家,金库门价格-河北特旺柜业有限公司 | 烟台条码打印机_烟台条码扫描器_烟台碳带_烟台数据采集终端_烟台斑马打印机-金鹏电子-金鹏电子 | 湖南自考_湖南自学考试| 污水/卧式/潜水/钻井/矿用/大型/小型/泥浆泵,价格,参数,型号,厂家 - 安平县鼎千泵业制造厂 | 网优资讯-为循环资源、大宗商品、工业服务提供资讯与行情分析的数据服务平台 | elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 400电话_400电话申请_866元/年_【400电话官方业务办理】-俏号网 3dmax渲染-效果图渲染-影视动画渲染-北京快渲科技有限公司 | 深圳公司注册-工商注册代理-注册公司流程和费用_护航财税 | 比亚迪叉车-比亚迪电动叉车堆垛车托盘车仓储叉车价格多少钱报价 磁力去毛刺机_去毛刺磁力抛光机_磁力光饰机_磁力滚抛机_精密金属零件去毛刺机厂家-冠古科技 | 深圳美安可自动化设备有限公司,喷码机,定制喷码机,二维码喷码机,深圳喷码机,纸箱喷码机,东莞喷码机 UV喷码机,日期喷码机,鸡蛋喷码机,管芯喷码机,管内壁喷码机,喷码机厂家 | 东莞喷砂机-喷砂机-喷砂机配件-喷砂器材-喷砂加工-东莞市协帆喷砂机械设备有限公司 | 辐射仪|辐射检测仪|辐射巡测仪|个人剂量报警仪|表面污染检测仪|辐射报警仪|辐射防护网 | 药品冷藏箱厂家_低温冰箱_洁净工作台-济南欧莱博电子商务有限公司官网 | 培训中心-翰香原香酥板栗饼加盟店总部-正宗板栗酥饼技术 | 电动高尔夫球车|电动观光车|电动巡逻车|电动越野车厂家-绿友机械集团股份有限公司 | 老城街小面官网_正宗重庆小面加盟技术培训_特色面馆加盟|牛肉拉面|招商加盟代理费用多少钱 | 薪动-人力资源公司-灵活用工薪资代发-费用结算-残保金优化-北京秒付科技有限公司 | 桨叶搅拌机_螺旋挤压/方盒旋切造粒机厂家-无锡市鸿诚输送机械有限公司 | 铝板冲孔网,不锈钢冲孔网,圆孔冲孔网板,鳄鱼嘴-鱼眼防滑板,盾构走道板-江拓数控冲孔网厂-河北江拓丝网有限公司 | 胶水,胶粘剂,AB胶,环氧胶,UV胶水,高温胶,快干胶,密封胶,结构胶,电子胶,厌氧胶,高温胶水,电子胶水-东莞聚力-聚厉胶粘 | 专业深孔加工_东莞深孔钻加工_东莞深孔钻_东莞深孔加工_模具深孔钻加工厂-东莞市超耀实业有限公司 | 北京包装设计_标志设计公司_包装设计公司-北京思逸品牌设计 | 盐水蒸发器,水洗盐设备,冷凝结晶切片机,转鼓切片机,絮凝剂加药系统-无锡瑞司恩机械有限公司 | 蓄电池回收,ups电池后备电源回收,铅酸蓄电池回收,机房电源回收-广州益夫铅酸电池回收公司 | 家用净水器代理批发加盟_净水机招商代理_全屋净水器定制品牌_【劳伦斯官网】 |