用HTML5来开发一款Android本地游戏---宝石碰碰

2024-02-28 03:10

本文主要是介绍用HTML5来开发一款Android本地游戏---宝石碰碰,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文来自:http://blog.csdn.net/lufy_legend/article/details/8724621,看后真心觉得不错,用HTML5开发Android游戏,比较新颖,不失为开发Android应用的又一条出路。

 

本次来说一说如何利用lufylegend.js引擎制作一款HTML5游戏后,将其转换为android本地化的App应用,转换过程其实很简单,下面一步步来做说明。

首先来开发一个类似于对对碰的游戏,不过此游戏玩法为在下原创,如有雷同,纯属巧合,游戏界面如下


游戏操作:上下左右划动屏幕,来操作宝石向不同的方向移动。

游戏规则:当有三个一样的宝石相邻则消除,被消除过一次的宝石会变成半透明,当所有宝石都被消除一次后,则进入下一关。

游戏测试连接:

http://lufylegend.com/demo/GemGem

制作开始

一,准备

首先,需要下载lufylegend.js引擎,下面是我在博客的lufylegend-1.7.0发布帖

http://blog.csdn.net/lufy_legend/article/details/8719768

二,游戏开发

引擎lufylegend1.7.0中扩展了LLoadManage静态类,可以读取图片,js文件以及文本文件,本次游戏开发就来体验一下这个新功能,首先看下面数组

代码清单1

[javascript] view plain copy print ?
  1. var loadData = [  
  2. {path:"../jquery.js",type:"js"},  
  3. {path:"./js/share.js",type:"js"},  
  4. {path:"./js/Social.js",type:"js"},  
  5. {path:"./js/GameRanking.js",type:"js"},  
  6. {path:"./js/GameLogo.js",type:"js"},  
  7. {path:"./js/GameClear.js",type:"js"},  
  8. {path:"./js/Gem.js",type:"js"},  
  9. {path:"./js/Stage.js",type:"js"},  
  10. {path:"./js/Clock.js",type:"js"},  
  11. {path:"./js/Point.js",type:"js"},  
  12. {path:"./js/GetPoint.js",type:"js"},  
  13. {path:"./js/Bullet.js",type:"js"},  
  14. {path:"./js/Event.js",type:"js"},  
  15. {path:"./js/function.js",type:"js"},  
  16. {path:"./js/GameBody.js",type:"js"},  
  17. {name:"num.+",path:"./images/plus.png"},  
  18. {name:"num.0",path:"./images/0.png"},  
  19. {name:"num.1",path:"./images/1.png"},  
  20. {name:"num.2",path:"./images/2.png"},  
  21. {name:"num.3",path:"./images/3.png"},  
  22. {name:"num.4",path:"./images/4.png"},  
  23. {name:"num.5",path:"./images/5.png"},  
  24. {name:"num.6",path:"./images/6.png"},  
  25. {name:"num.7",path:"./images/7.png"},  
  26. {name:"num.8",path:"./images/8.png"},  
  27. {name:"num.9",path:"./images/9.png"},  
  28. {name:"back",path:"./images/back.png"},  
  29. {name:"line",path:"./images/line.png"},  
  30. {name:"clear",path:"./images/clear.png"},  
  31. {name:"gem01",path:"./images/gem01.png"},  
  32. {name:"gem02",path:"./images/gem02.png"},  
  33. {name:"gem03",path:"./images/gem03.png"},  
  34. {name:"gem04",path:"./images/gem04.png"},  
  35. {name:"gem05",path:"./images/gem05.png"},  
  36. {name:"gem06",path:"./images/gem06.png"},  
  37. {name:"gem07",path:"./images/gem07.png"},  
  38. {name:"gem08",path:"./images/gem08.png"},  
  39. {name:"gem09",path:"./images/gem09.png"},  
  40. {name:"ico_sina",path:"./images/ico_sina.gif"},  
  41. {name:"ico_qq",path:"./images/ico_qq.gif"},  
  42. {name:"ico_facebook",path:"./images/ico_facebook.png"},  
  43. {name:"ico_twitter",path:"./images/ico_twitter.png"}  
  44. ];  
var loadData = [
{path:"../jquery.js",type:"js"},
{path:"./js/share.js",type:"js"},
{path:"./js/Social.js",type:"js"},
{path:"./js/GameRanking.js",type:"js"},
{path:"./js/GameLogo.js",type:"js"},
{path:"./js/GameClear.js",type:"js"},
{path:"./js/Gem.js",type:"js"},
{path:"./js/Stage.js",type:"js"},
{path:"./js/Clock.js",type:"js"},
{path:"./js/Point.js",type:"js"},
{path:"./js/GetPoint.js",type:"js"},
{path:"./js/Bullet.js",type:"js"},
{path:"./js/Event.js",type:"js"},
{path:"./js/function.js",type:"js"},
{path:"./js/GameBody.js",type:"js"},
{name:"num.+",path:"./images/plus.png"},
{name:"num.0",path:"./images/0.png"},
{name:"num.1",path:"./images/1.png"},
{name:"num.2",path:"./images/2.png"},
{name:"num.3",path:"./images/3.png"},
{name:"num.4",path:"./images/4.png"},
{name:"num.5",path:"./images/5.png"},
{name:"num.6",path:"./images/6.png"},
{name:"num.7",path:"./images/7.png"},
{name:"num.8",path:"./images/8.png"},
{name:"num.9",path:"./images/9.png"},
{name:"back",path:"./images/back.png"},
{name:"line",path:"./images/line.png"},
{name:"clear",path:"./images/clear.png"},
{name:"gem01",path:"./images/gem01.png"},
{name:"gem02",path:"./images/gem02.png"},
{name:"gem03",path:"./images/gem03.png"},
{name:"gem04",path:"./images/gem04.png"},
{name:"gem05",path:"./images/gem05.png"},
{name:"gem06",path:"./images/gem06.png"},
{name:"gem07",path:"./images/gem07.png"},
{name:"gem08",path:"./images/gem08.png"},
{name:"gem09",path:"./images/gem09.png"},
{name:"ico_sina",path:"./images/ico_sina.gif"},
{name:"ico_qq",path:"./images/ico_qq.gif"},
{name:"ico_facebook",path:"./images/ico_facebook.png"},
{name:"ico_twitter",path:"./images/ico_twitter.png"}
];
将需要的js文件和图片文件都加到数组内,如果需要加载文件为js文件时,需要指定type为js,如果加载的文件为图片,则type可以不设定。

读取过程与之前用法完全一样

代码清单2

[javascript] view plain copy print ?
  1. function main(){  
  2.     loadingLayer = new LoadingSample3();  
  3.     addChild(loadingLayer);   
  4.     LLoadManage.load(  
  5.         loadData,  
  6.         function(progress){  
  7.             loadingLayer.setProgress(progress);  
  8.         },  
  9.         function(result){  
  10.             LGlobal.setDebug(true);  
  11.             datalist = result;  
  12.             removeChild(loadingLayer);  
  13.             loadingLayer = null;  
  14.             gameInit();  
  15.         }  
  16.     );  
  17. }  
function main(){
loadingLayer = new LoadingSample3();
addChild(loadingLayer);	
LLoadManage.load(
loadData,
function(progress){
loadingLayer.setProgress(progress);
},
function(result){
LGlobal.setDebug(true);
datalist = result;
removeChild(loadingLayer);
loadingLayer = null;
gameInit();
}
);
}

下面来向游戏中添加8行8列64块宝石,具体做法如下

代码清单3

[javascript] view plain copy print ?
  1. function addGem(){  
  2.     stage.setStage(stage.num + 1);  
  3.     gemLayer.removeAllChild();  
  4.     list = [];  
  5.     //添加宝石   
  6.     for(i=0;i<8;i++){  
  7.         list.push([]);  
  8.         for(var j=0;j<8;j++){  
  9.             num = (Math.random()*9 >>> 0)+1;  
  10.             g = new Gem(num);  
  11.             g.x = j*60;  
  12.             g.y = i*60+120;  
  13.             gemLayer.addChild(g);  
  14.             list[i].push(g);  
  15.         }  
  16.     }  
  17.     //检验可消除宝石   
  18.     do{  
  19.         clearList = checkClear();  
  20.         if(clearList.length > 0){  
  21.             for(i=0;i<clearList.length;i++){  
  22.                 g = clearList[i];  
  23.                 num = (Math.random()*9 >>> 0)+1;  
  24.                 g.change(num);  
  25.             }  
  26.         }  
  27.     }while(clearList.length > 0);  
  28. }  
function addGem(){
stage.setStage(stage.num + 1);
gemLayer.removeAllChild();
list = [];
//添加宝石
for(i=0;i<8;i++){
list.push([]);
for(var j=0;j<8;j++){
num = (Math.random()*9 >>> 0)+1;
g = new Gem(num);
g.x = j*60;
g.y = i*60+120;
gemLayer.addChild(g);
list[i].push(g);
}
}
//检验可消除宝石
do{
clearList = checkClear();
if(clearList.length > 0){
for(i=0;i<clearList.length;i++){
g = clearList[i];
num = (Math.random()*9 >>> 0)+1;
g.change(num);
}
}
}while(clearList.length > 0);
}
上面代码中的Gem对象是一个宝石类,完整代码如下

代码清单4

[javascript] view plain copy print ?
  1. function Gem(num){  
  2.     var self = this;  
  3.     base(self,LSprite,[]);  
  4.     self.num = num;  
  5.     self.bitmap = new LBitmap(new LBitmapData(datalist["gem0"+num]));  
  6.     self.bitmap.x=self.bitmap.y=10;  
  7.     self.addChild(self.bitmap);  
  8.       
  9. }  
  10. Gem.prototype.change = function (num){  
  11.     var self = this;  
  12.     self.num = num;  
  13.     self.bitmap.bitmapData = new LBitmapData(datalist["gem0"+num]);  
  14. }  
function Gem(num){
var self = this;
base(self,LSprite,[]);
self.num = num;
self.bitmap = new LBitmap(new LBitmapData(datalist["gem0"+num]));
self.bitmap.x=self.bitmap.y=10;
self.addChild(self.bitmap);
}
Gem.prototype.change = function (num){
var self = this;
self.num = num;
self.bitmap.bitmapData = new LBitmapData(datalist["gem0"+num]);
}
Gem类继承自LSprite,内部包含一个LBitmap对象来显示宝石图片。

代码清单3中调用了checkClear函数,来检验是否有可消除宝石,检测方法为先进行横向检索,然后进行纵向检索。

代码清单5

[javascript] view plain copy print ?
  1. clearList = [];  
  2.     //横向检索   
  3.     for(i=0;i<8;i++){  
  4.         checkList = [list[i][0]];  
  5.         for(j=1;j<8;j++){  
  6.             if(checkList[checkList.length - 1].num == list[i][j].num){  
  7.                 checkList.push(list[i][j]);  
  8.             }else{  
  9.                 clearList = addClearList(clearList,checkList);  
  10.                 checkList = [list[i][j]];  
  11.             }  
  12.         }  
  13.         clearList = addClearList(clearList,checkList);  
  14.     }  
  15.     //纵向检索   
  16.     for(i=0;i<8;i++){  
  17.         checkList = [list[0][i]];  
  18.         for(j=1;j<8;j++){  
  19.             if(checkList[checkList.length - 1].num == list[j][i].num){  
  20.                 checkList.push(list[j][i]);  
  21.             }else{  
  22.                 clearList = addClearList(clearList,checkList);  
  23.                 checkList = [list[j][i]];  
  24.             }  
  25.         }  
  26.         clearList = addClearList(clearList,checkList);  
  27.     }  
clearList = [];
//横向检索
for(i=0;i<8;i++){
checkList = [list[i][0]];
for(j=1;j<8;j++){
if(checkList[checkList.length - 1].num == list[i][j].num){
checkList.push(list[i][j]);
}else{
clearList = addClearList(clearList,checkList);
checkList = [list[i][j]];
}
}
clearList = addClearList(clearList,checkList);
}
//纵向检索
for(i=0;i<8;i++){
checkList = [list[0][i]];
for(j=1;j<8;j++){
if(checkList[checkList.length - 1].num == list[j][i].num){
checkList.push(list[j][i]);
}else{
clearList = addClearList(clearList,checkList);
checkList = [list[j][i]];
}
}
clearList = addClearList(clearList,checkList);
}
addClearList函数作用是将可消除宝石压入clearList数组,做法如下

代码清单6

[javascript] view plain copy print ?
  1. function addClearList(clearList,checkList){  
  2.     if(checkList.length >= 3){  
  3.         clearList = clearList.concat(checkList)  
  4.     }  
  5.     return clearList;  
  6. }  
function addClearList(clearList,checkList){
if(checkList.length >= 3){
clearList = clearList.concat(checkList)
}
return clearList;
}
游戏操作需要划动屏幕,但是在lufylegend.js引擎中,是没有划动屏幕的事件的,所以我通过下面MOUSE_DOWN,MOUSE_UP获取点击时和点击后的位置,来模拟一下划动事件。

代码清单7

[javascript] view plain copy print ?
  1. backLayer.addEventListener(LMouseEvent.MOUSE_DOWN,onDown);  
  2. backLayer.addEventListener(LMouseEvent.MOUSE_UP,onUp);  
	backLayer.addEventListener(LMouseEvent.MOUSE_DOWN,onDown);
backLayer.addEventListener(LMouseEvent.MOUSE_UP,onUp);
再来看看具体做法,先是onDown函数。

代码清单8

[javascript] view plain copy print ?
  1. function onDown(e){  
  2.     if(mouse_down_obj.isMouseDown)return;  
  3.     continuous = 0;  
  4.     mouse_down_obj.x = e.offsetX;  
  5.     mouse_down_obj.y = e.offsetY;  
  6.     mouse_down_obj.time = new Date().getTime();  
  7.     mouse_down_obj.cx = e.offsetX/60 >>> 0;  
  8.     mouse_down_obj.cy = (e.offsetY - 120)/60 >>> 0;  
  9.     mouse_down_obj.isMouseDown = true;  
  10.     list[mouse_down_obj.cy][mouse_down_obj.cx].graphics.drawRect(1,"black",[0, 0, 60, 60],true,"#000000");  
  11. }  
function onDown(e){
if(mouse_down_obj.isMouseDown)return;
continuous = 0;
mouse_down_obj.x = e.offsetX;
mouse_down_obj.y = e.offsetY;
mouse_down_obj.time = new Date().getTime();
mouse_down_obj.cx = e.offsetX/60 >>> 0;
mouse_down_obj.cy = (e.offsetY - 120)/60 >>> 0;
mouse_down_obj.isMouseDown = true;
list[mouse_down_obj.cy][mouse_down_obj.cx].graphics.drawRect(1,"black",[0, 0, 60, 60],true,"#000000");
}
通过e.offsetX和e.offsetY来获取点击位置,通过getTime()来获取点击时刻的时间。

在来看看onUp函数。

代码清单9

[javascript] view plain copy print ?
  1. function onUp(e){  
  2.     list[mouse_down_obj.cy][mouse_down_obj.cx].graphics.clear();  
  3.     if(new Date().getTime() - mouse_down_obj.time > 500){  
  4.         mouse_down_obj.isMouseDown = false;  
  5.         return;  
  6.     }  
  7.     var mx = e.offsetX - mouse_down_obj.x;  
  8.     var my = e.offsetY - mouse_down_obj.y;  
  9.     if(Math.abs(mx) > Math.abs(my)){  
  10.         if(mx > 50){  
  11.             move("right");  
  12.             return;  
  13.         }else if(mx < -50){  
  14.             move("left");  
  15.             return;  
  16.         }  
  17.     }else{  
  18.         if(my > 50){  
  19.             move("down");     
  20.             return;  
  21.         }else if(my < -50){  
  22.             move("up");  
  23.             return;  
  24.         }  
  25.     }  
  26.     mouse_down_obj.isMouseDown = false;  
  27. }  
function onUp(e){
list[mouse_down_obj.cy][mouse_down_obj.cx].graphics.clear();
if(new Date().getTime() - mouse_down_obj.time > 500){
mouse_down_obj.isMouseDown = false;
return;
}
var mx = e.offsetX - mouse_down_obj.x;
var my = e.offsetY - mouse_down_obj.y;
if(Math.abs(mx) > Math.abs(my)){
if(mx > 50){
move("right");
return;
}else if(mx < -50){
move("left");
return;
}
}else{
if(my > 50){
move("down");	
return;
}else if(my < -50){
move("up");
return;
}
}
mouse_down_obj.isMouseDown = false;
}
函数中通过同样的方法得到点击结束时的位置和时间,然后与点击时刻做比较,最后计算划动的方向,然后根据划动的方向来调用move函数,让宝石移动。
move函数如下:

代码清单10

[javascript] view plain copy print ?
  1. function move(dir){  
  2.     direction = dir;  
  3.     var m = moveGem(dir,8);  
  4.     var mx = m[0],my = m[1];  
  5.     var obj,fun;  
  6.     for(var i=0;i<8;i++){  
  7.         if(mx == 0){  
  8.             obj = list[i][mouse_down_obj.cx];  
  9.         }else{  
  10.             obj = list[mouse_down_obj.cy][i];  
  11.         }  
  12.         if(i < 7){  
  13.             fun = null;  
  14.         }else{  
  15.             fun = function(){  
  16.                 hiddenObj.visible = true;  
  17.                 checkClear();  
  18.             };  
  19.         }  
  20.         LTweenLite.to(obj,0.3,  
  21.         {   
  22.             x:obj.x+mx,  
  23.             y:obj.y+my,  
  24.             onComplete:fun,  
  25.             ease:Strong.easeOut  
  26.         });  
  27.       
  28.     }  
  29. }  
function move(dir){
direction = dir;
var m = moveGem(dir,8);
var mx = m[0],my = m[1];
var obj,fun;
for(var i=0;i<8;i++){
if(mx == 0){
obj = list[i][mouse_down_obj.cx];
}else{
obj = list[mouse_down_obj.cy][i];
}
if(i < 7){
fun = null;
}else{
fun = function(){
hiddenObj.visible = true;
checkClear();
};
}
LTweenLite.to(obj,0.3,
{ 
x:obj.x+mx,
y:obj.y+my,
onComplete:fun,
ease:Strong.easeOut
});
}
}
下面以向右移动为例来说明一下move函数的处理过程,如下

先将最左边的一个宝石H移到最左边,然后再利用LTweenLite缓动类将整个一行8个宝石,向右缓动一个单位。向左的话正好相反,向上向下也是同样的原理。

每次缓动结束,要调用一次checkClear函数,来判断一下是否有可消除的宝石,如果有则开始消除宝石,如何来消除宝石呢?

我依然以向右划动来举例说明,看下面图片,假设D1,D2,D3可消除,E4,F4,G4可消除


那么首先将D1,D2,D3移到左边边界外,E4,F4,G4也移到边界外,表示被消除,之后对每一行的宝石进行位置判定,如每行的第一个宝石的x坐标应该是60,第二个为120,以此类推。如果他们不在自己的相应位置上,那么将其向左移动到规定位置就可以了,写成代码的话,如下。

代码清单11

[javascript] view plain copy print ?
  1. function moveList(){  
  2.     var gem,time,maxTime,mx,my,fun;  
  3.     maxTime = 0;  
  4.     switch(direction){  
  5.         case "left":  
  6.             for(i=0;i<8;i++){  
  7.                 for(j=0;j<8;j++){  
  8.                     gem = list[i][j];  
  9.                     mx = 60*j;  
  10.                     if(gem.x > mx){  
  11.                         time = 0.3*((gem.x-mx) / 60 >>> 0);  
  12.                         if(maxTime < time)maxTime = time;  
  13.                         fun = null;  
  14.                         if(gem.x > 420){  
  15.                             fun = function(gem){  
  16.                                 if(gem.x <= 420)gem.visible = true;  
  17.                             }  
  18.                         }  
  19.                         LTweenLite.to(gem,time,  
  20.                         {   
  21.                             x:mx,  
  22.                             onUpdate:fun,  
  23.                             onComplete:fun,  
  24.                             ease:Strong.easeOut  
  25.                         });  
  26.                     }  
  27.                 }  
  28.             }  
  29.             break;  
  30.         case "right":  
  31.             for(i=0;i<8;i++){  
  32.                 for(j=0;j<8;j++){  
  33.                     gem = list[i][j];  
  34.                     mx = 60*j;  
  35.                     if(gem.x < mx){  
  36.                         time = 0.3*((mx-gem.x) / 60 >>> 0);  
  37.                         if(maxTime < time)maxTime = time;  
  38.                         fun = null;  
  39.                         if(gem.x < 0){  
  40.                             fun = function(gem){  
  41.                                 if(gem.x >= 0)gem.visible = true;  
  42.                             }  
  43.                         }  
  44.                         LTweenLite.to(gem,time,  
  45.                         {   
  46.                             x:mx,  
  47.                             onUpdate:fun,  
  48.                             onComplete:fun,  
  49.                             ease:Strong.easeOut  
  50.                         });  
  51.                     }  
  52.                 }  
  53.             }  
  54.             break;  
  55.         case "up":  
  56.             for(i=0;i<8;i++){  
  57.                 for(j=0;j<8;j++){  
  58.                     gem = list[j][i];  
  59.                     my = 120+60*j;  
  60.                     if(gem.y > my){  
  61.                         time = 0.3*((gem.y-my) / 60 >>> 0);  
  62.                         if(maxTime < time)maxTime = time;  
  63.                         fun = null;  
  64.                         if(gem.y > 560){  
  65.                             fun = function(gem){  
  66.                                 if(gem.y <= 560)gem.visible = true;  
  67.                             }  
  68.                         }  
  69.                         LTweenLite.to(gem,time,  
  70.                         {   
  71.                             y:my,  
  72.                             onUpdate:fun,  
  73.                             onComplete:fun,  
  74.                             ease:Strong.easeOut  
  75.                         });  
  76.                     }  
  77.                 }  
  78.             }  
  79.             break;  
  80.         case "down":  
  81.             for(i=0;i<8;i++){  
  82.                 for(j=0;j<8;j++){  
  83.                     gem = list[j][i];  
  84.                     my = 120+60*j;  
  85.                     if(gem.y < my){  
  86.                         time = 0.3*((my-gem.y) / 60 >>> 0);  
  87.                         if(maxTime < time)maxTime = time;  
  88.                         fun = null;  
  89.                         if(gem.y < 120){  
  90.                             fun = function(gem){  
  91.                                 if(gem.y >= 120)gem.visible = true;  
  92.                             }  
  93.                         }  
  94.                         LTweenLite.to(gem,time,  
  95.                         {   
  96.                             y:my,  
  97.                             onUpdate:fun,  
  98.                             onComplete:fun,  
  99.                             ease:Strong.easeOut  
  100.                         });  
  101.                     }  
  102.                 }  
  103.             }  
  104.             break;  
  105.     }  
  106.     LTweenLite.to({},maxTime*1.5,  
  107.     {   
  108.         onComplete:checkStageClear,  
  109.         ease:Strong.easeOut  
  110.     });  
  111. }  
function moveList(){
var gem,time,maxTime,mx,my,fun;
maxTime = 0;
switch(direction){
case "left":
for(i=0;i<8;i++){
for(j=0;j<8;j++){
gem = list[i][j];
mx = 60*j;
if(gem.x > mx){
time = 0.3*((gem.x-mx) / 60 >>> 0);
if(maxTime < time)maxTime = time;
fun = null;
if(gem.x > 420){
fun = function(gem){
if(gem.x <= 420)gem.visible = true;
}
}
LTweenLite.to(gem,time,
{ 
x:mx,
onUpdate:fun,
onComplete:fun,
ease:Strong.easeOut
});
}
}
}
break;
case "right":
for(i=0;i<8;i++){
for(j=0;j<8;j++){
gem = list[i][j];
mx = 60*j;
if(gem.x < mx){
time = 0.3*((mx-gem.x) / 60 >>> 0);
if(maxTime < time)maxTime = time;
fun = null;
if(gem.x < 0){
fun = function(gem){
if(gem.x >= 0)gem.visible = true;
}
}
LTweenLite.to(gem,time,
{ 
x:mx,
onUpdate:fun,
onComplete:fun,
ease:Strong.easeOut
});
}
}
}
break;
case "up":
for(i=0;i<8;i++){
for(j=0;j<8;j++){
gem = list[j][i];
my = 120+60*j;
if(gem.y > my){
time = 0.3*((gem.y-my) / 60 >>> 0);
if(maxTime < time)maxTime = time;
fun = null;
if(gem.y > 560){
fun = function(gem){
if(gem.y <= 560)gem.visible = true;
}
}
LTweenLite.to(gem,time,
{ 
y:my,
onUpdate:fun,
onComplete:fun,
ease:Strong.easeOut
});
}
}
}
break;
case "down":
for(i=0;i<8;i++){
for(j=0;j<8;j++){
gem = list[j][i];
my = 120+60*j;
if(gem.y < my){
time = 0.3*((my-gem.y) / 60 >>> 0);
if(maxTime < time)maxTime = time;
fun = null;
if(gem.y < 120){
fun = function(gem){
if(gem.y >= 120)gem.visible = true;
}
}
LTweenLite.to(gem,time,
{ 
y:my,
onUpdate:fun,
onComplete:fun,
ease:Strong.easeOut
});
}
}
}
break;
}
LTweenLite.to({},maxTime*1.5,
{ 
onComplete:checkStageClear,
ease:Strong.easeOut
});
}

当然,游戏是有时间限制的,看下面的Clock类。

代码清单12

[javascript] view plain copy print ?
  1. function Clock(){  
  2.     var self = this;  
  3.     base(self,LSprite,[]);  
  4.     self.timer = 0;  
  5.     self.addTimer = 0.05;  
  6.     self.graphics.drawArc(5,"#333333",[0,0,70,0,2*Math.PI]);  
  7.       
  8. }  
  9. Clock.prototype.onframe = function (){  
  10.     var self = this;  
  11.     self.timer += self.addTimer;  
  12.     self.graphics.clear();  
  13.     self.graphics.drawArc(10,"#333333",[0,0,70,0,2*Math.PI]);  
  14.     self.graphics.drawArc(5,"#ffffff",[0,0,70,-Math.PI*0.5,Math.PI*self.timer/180-Math.PI*0.5]);  
  15. }  
function Clock(){
var self = this;
base(self,LSprite,[]);
self.timer = 0;
self.addTimer = 0.05;
self.graphics.drawArc(5,"#333333",[0,0,70,0,2*Math.PI]);
}
Clock.prototype.onframe = function (){
var self = this;
self.timer += self.addTimer;
self.graphics.clear();
self.graphics.drawArc(10,"#333333",[0,0,70,0,2*Math.PI]);
self.graphics.drawArc(5,"#ffffff",[0,0,70,-Math.PI*0.5,Math.PI*self.timer/180-Math.PI*0.5]);
}
首先将Clock加载到游戏中,然后再利用ENTER_FRAME时间轴事件,来不断调用Clock的onframe不断的绘制圆弧,当timer的数值大于等于360的时候代表画完了整个圆弧,那么游戏结束。

以上,游戏的主要原理都介绍完了,下面看看如何来把游戏转化为本地App

三,发布本地化App

首先,用Eclipse新建一个Android Project



注:如何搭建Android环境,我就不说了,网上教程多得是,随便百度一下吧。

然后,填写项目名称,并选择相应的sdk版本,这里我选了2.2


接着是填写相应数据,这个随自己心情就可以了。


接着,重点来了,在工程下的assets文件夹下,简历一个www文件夹(名字自己随意),然后把刚才开发好的游戏复制到这个文件夹下,当然,lufylegend引擎也必须复制过来。


接着修改res/layout/main.xml文件,添加webView,如下

[html] view plain copy print ?
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="fill_parent"  
  4.     android:layout_height="fill_parent"  
  5.     android:orientation="vertical" >  
  6.     <WebView  
  7.         android:id="@+id/webView1"  
  8.         android:layout_width="match_parent"  
  9.         android:layout_height="match_parent" />  
  10. </LinearLayout>  
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<WebView
android:id="@+id/webView1"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
最后,修改Main.java文件,利用webView来显示html网页,如下

[java] view plain copy print ?
  1. public class Main extends Activity {  
  2.     /** Called when the activity is first created. */  
  3.     @Override  
  4.     public void onCreate(Bundle savedInstanceState) {  
  5.         super.onCreate(savedInstanceState);  
  6.         setContentView(R.layout.main);  
  7.         WebView webview = (WebView )findViewById(R.id.webView1);  
  8.         webview.getSettings().setJavaScriptEnabled(true);  
  9.         webview.setVerticalScrollbarOverlay(true);  
  10.         webview.loadUrl("file:///android_asset/www/index.html");  
  11.     }  
  12. }  
public class Main extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
WebView webview = (WebView )findViewById(R.id.webView1);
webview.getSettings().setJavaScriptEnabled(true);
webview.setVerticalScrollbarOverlay(true);
webview.loadUrl("file:///android_asset/www/index.html");
}
}
好了,运行程序吧。


画面如下:


最后,想要发布游戏为.apk文件的话,build一下就好了。

发布后的apk文件。

结束了,简单吧?

四,源码

最后给出本次游戏的源代码

http://lufylegend.com/lufylegend_download/GemGem.rar

注:只含游戏源码,lufylegend.js引擎请自己到官网下载

这篇关于用HTML5来开发一款Android本地游戏---宝石碰碰的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/754285

相关文章

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

使用JavaScript操作本地存储

《使用JavaScript操作本地存储》这篇文章主要为大家详细介绍了JavaScript中操作本地存储的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录本地存储:localStorage 和 sessionStorage基本使用方法1. localStorage

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超