`
makeapp628
  • 浏览: 44992 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

PopStar(消灭星星)游戏源代码下载、分析及跨平台移植---第三篇(分数)

阅读更多

背景:

   经过消灭星星第二篇算法,最高的山峰已经过去了,剩下的都是小沟小河,没什么难度了。这一节笔者继续完成消灭星星的分数篇,这节主要包括:触摸提示得分 比如4 blocks 80 points,然后产生单个星星分数并移动到总分上,最后保存最高分; 

ps:

1 CocosEditor已发布新版本,现在提供6个实战demo学习,包括flappy ,popstar ,fruitninja,moonwarroris,fruitattack,testjavascript;

2 代码是基于javascript语言,cocos2d-x游戏引擎,cocos2d-x editor手游开发工具完成的;

3 运行demo需要配置好CocosEditor,暂不支持其他工具。demo是跨平台的,可移植运行android,ios,html5网页等。

 

 

源代码下载:

请到代码集中营下载(第三四篇合并  分数和关卡):http://blog.makeapp.co/?p=319

 

 

不同平台下的效果图:(windows、html5、android)

 

window平台


 

 

mac平台

 

 

html5网页平台


 

android平台

 

          

 

代码分析:

 

1  进入MainLayer.js在onEnter函数里面,我们需要获取数据库里面的最高分,在cocos里面我们一般通过sys.localStorage.getItem 和sys.localStorage.setItem来获取和存储简单的数值;

 

[javascript] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. this.bestScore = sys.localStorage.getItem("starBestScore");  
  2.     if (this.bestScore != null && this.bestScore != undefined) {  
  3.         this.bestScore = Number(this.bestScore);  
  4.     }  
  5.     else {  
  6.         this.bestScore = 0;  
  7.     }  
  8.     this.bestScoreFont.setString(this.bestScore + "");  



 

2  定义分数规则

我们先定义分数规则,选择的星星越多,分数越高,所以规则是一个二次函数 score=length*length*5;比如选择4个星星 分数就是4*4*5=80,如果选择10个星星 分数就是10*10*5=500;然后触摸星星的时候,如果相同星星的数量大于1时 提示获取的分数

 

[javascript] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. if (this.sameColorList.length > 1) {  
  2.   cc.AudioEngine.getInstance().playEffect(PS_MAIN_SOUNDS.select, false);  
  3.   this.showScoreTip();  
  4. }  
  5. else {  
  6.   this.scoreTipLabel.setVisible(false);}  

 

 
提示分数函数showScoreTip;
[javascript] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. MainLayer.prototype.showScoreTip = function ()  
  2. {  
  3.     this.scoreTipLabel.setVisible(true);  
  4.     var length = this.sameColorList.length;  
  5.     var tip = length + " blocks " + length * length * 5 + " points";  
  6.     this.scoreTipLabel.setString(tip);  
  7. }  


3  确定删除相同颜色星星的时候,找到removeSameColorStars,在for循环里面给每个星星加入分数字体;
cc.StarLabel.createScore是笔者自定义的创建文字函数,startScoreSprite从创建位置MoveTo到总分数位置,然后CleanUp,最后有一个回调函数cc.CallFunc.create,这个函数用的很多,读者必须深刻理解它。回调里面主要处理分数的添加,还有一个判断是否达到目标分数的处理this.isClear;
 
[javascript] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. var starScoreSprite = cc.StarLabel.createScore(this.rootNode, cc.p((36 + col * this.starSize), (36 + row * this.starSize)), this.oneStarScore + "");  
  2.            starScoreSprite.runAction(cc.Sequence.create(  
  3.                    cc.MoveTo.create(0.3 + k / 20, this.scoreFont.getPosition()),  
  4.                    cc.CleanUp.create(starScoreSprite),  
  5.                    cc.CallFunc.create(function ()  
  6.                    {  
  7.                        this.totalScore += this.oneStarScore;  
  8.                        this.scoreFont.setString(this.totalScore + "");  
  9.                        if (this.totalScore >= this.targetScore) {  
  10.                            if (this.isClear == false) {  
  11.                                this.isClear = true;  
  12.                                this.tipLabel.setVisible(true);  
  13.                                this.tipLabel.setString("Clear!");  
  14.                                this.tipLabel.runAction(cc.Sequence.create(cc.DelayTime.create(1),  
  15.                                        cc.MoveTo.create(1, cc.p(110, 1000))  
  16.                                ));  
  17.                                cc.AudioEngine.getInstance().playEffect(PS_MAIN_SOUNDS.stageclear);  
  18.                            }  
  19.                        }  
  20.                    }, this)  
  21.            ));  
 
 
 
4 死局时候根据剩余的星星给不同的分值。剩的越少,给分数越高;
[javascript] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. if (deadCount < 10) {  
  2.                       if (deadCount == 0) {  
  3.                           this.totalScore += 1000;  
  4.                           this.scoreFont.setString(this.totalScore + "");  
  5.                       }  
  6.   
  7.                       this.oneDeadStarScore = Math.floor((1000 - deadCount * 100) / deadCount);  
  8.                       this.oneDeadStarScore = this.oneDeadStarScore - this.oneDeadStarScore % 10;  
  9.                       var starScoreSprite = cc.StarLabel.createScore(this.rootNode,  
  10.                               cc.p((36 + ii * this.starSize), (36 + jj * this.starSize)), this.oneDeadStarScore + "");  
  11.                       starScoreSprite.runAction(cc.Sequence.create(  
  12.                               cc.ScaleTo.create(0, 0),  
  13.                               cc.DelayTime.create(delay), cc.ScaleTo.create(0, 1),  
  14.                               cc.MoveTo.create(0.3 + jj / 20, this.scoreFont.getPosition()),  
  15.                               cc.CleanUp.create(starScoreSprite),  
  16.                               cc.CallFunc.create(function ()  
  17.                               {  
  18.                                   this.totalScore += this.oneDeadStarScore;  
  19.                                   this.scoreFont.setString(this.totalScore + "");  
  20.                               }, this)  
  21.                       ));  
  22.                   }  



5 游戏结束,当前得到的游戏分数如果大于最高分,存储最高分;
[javascript] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. if (this.totalScore > this.bestScore) {  
  2.        sys.localStorage.setItem("starBestScore"this.totalScore + "");  
  3.    }  
 
6 自定义函数,有些函数用的很普遍,笔者一般都会在Main.js定义好,比如下面一些
[javascript] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. cc.CleanUp = {};  
  2. cc.CleanUp.create = function (sprite)  
  3. {  
  4.     return cc.CallFunc.create(function ()  
  5.     {  
  6.         sprite.cleanuped = true;  
  7.         sprite.removeFromParent(true);  
  8.     });  
  9. }  
  10.   
  11. cc.StarParticle = {};  
  12. cc.StarParticle.create = function (node, x, y, name)  
  13. {  
  14.     var particle = cc.ParticleSystem.create("Resources/particles/" + name + ".plist");  
  15.     particle.setAnchorPoint(cc.p(0.5, 0.5));  
  16.     particle.setPosition(cc.p(x, y));  
  17.     particle.setZOrder(120);  
  18.     node.addChild(particle);  
  19.     return particle;  
  20. };  
  21.   
  22. cc.StarLabel = {};  
  23. cc.StarLabel.createScore = function (node, p, message)  
  24. {  
  25.     var label = cc.LabelTTF.create(message, "Arial", 30);  
  26.     label.setPosition(p);  
  27.     label.setColor(cc.c3b(255, 255, 255));  
  28.     label.setZOrder(10000);  
  29.     node.addChild(label);  
  30.     return label;  
  31. };  
  32.   
  33. cc.StarLabel.createTip = function (node, p, message)  
  34. {  
  35.     var label = cc.LabelTTF.create(message, "Arial", 30);  
  36.     label.setPosition(p);  
  37.     label.setColor(cc.c3b(255, 255, 255));  
  38.     label.setZOrder(10000);  
  39.     node.addChild(label);  
  40.     return label;  
  41. };  
  42.   
  43. cc.Toast = {};  
  44. cc.Toast.create = function (node, message, delay)  
  45. {  
  46.     cc.log("toast");  
  47.     var director = cc.Director.getInstance();  
  48.     var size = director.getWinSize();  
  49.     var label = cc.LabelTTF.create(message, "Arial", 40);  
  50.     label.setPosition(size.width / 2, size.height / 2 + 100);  
  51.     label.setColor(cc.c3b(255, 255, 255));  
  52.     label.setZOrder(10000);  
  53.     node.addChild(label);  
  54.     label.runAction(cc.Sequence.create(cc.DelayTime.create(delay), cc.CleanUp.create(label)));  
  55.     return label;  
  56. };  
  57.   
  58. cc.rectCreate = function (p, area)  
  59. {  
  60.     return  cc.rect(p.x - area[0], p.y - area[1], area[0] * 2, area[1] * 2);  
  61. }  
  62.   
  63.   
  64. function getRandom(maxSize)  
  65. {  
  66.     return Math.floor(Math.random() * maxSize) % maxSize;  
  67. }  

很简单,笔者感觉没写什么。。。
 
 
cocos2d-x跨平台游戏引擎
 
cocos2d-x是全球知名的游戏引擎 ,引擎在全球范围内拥有众多开发者,涵盖国内外各知名游戏开发商。目前Cocos2d-x引擎已经实现横跨ios、Android、Bada、MeeGo、BlackBerry、Marmalade、Windows、Linux等平台。编写一次,到处运行,分为两个版本 cocos2d-c++和cocos2d-html5 本文使用了后者;
cocos2d-x 官网:http://cocos2d-x.org/
cocos2d-x 资料下载  http://cocos2d-x.org/download

 

 

 

CocosEditor开发工具:

CocosEditor,它是开发跨平台的手机游戏工具,运行window/mac系统上,javascript脚本语言,基于cocos2d-x跨平台游戏引擎, 集合代码编辑,场景设计,动画制作,字体设计,还有粒子,物理系统,地图等等的,而且调试方便,和实时模拟;

CocosEditor 下载,介绍和教程:http://blog.csdn.net/touchsnow/article/details/19070665

CocosEditor官方博客:http://blog.makeapp.co/

分享到:
评论

相关推荐

    消灭星星popstar

    "消灭星星Popstar"是一款经典的休闲消除类游戏,源自于移动平台并广受玩家喜爱。在PC版本中,这款游戏的源代码是用VB.NET(Visual Basic .NET)编写的,这是一种面向对象的编程语言,属于.NET框架的一部分。VB.NET...

    消灭星星源码 - Pop Star

    《Pop Star》是一款广受欢迎的消除类休闲游戏,其源码使用了AndEngine这个专门为Android平台设计的游戏开发框架,以Java编程语言实现。AndEngine是一个轻量级且高效的2D游戏引擎,它允许开发者通过简单易用的API快速...

    PopStar源码,消灭星星源码

    PopStar,即“消灭星星”,是一款广受欢迎的休闲益智游戏,它的核心玩法是通过消除同色方块来得分。本篇文章将深入探讨使用cocos2d-x3.2引擎开发的PopStar源码,帮助读者理解游戏的实现机制,以及如何运用cocos2d-x...

    VC版消灭星星(PopStar)

    《VC版消灭星星(PopStar):MFC游戏开发初探》 消灭星星(PopStar)是一款广受欢迎的休闲益智游戏,以其简洁的游戏规则和趣味性吸引了大量玩家。在这个项目中,我们将会探讨如何使用Microsoft Foundation Classes (MFC...

    PopStar(一起消灭星星)_210.zip源码cocos creator游戏项目源码下载

    PopStar(一起消灭星星)_210.zip源码cocos creator游戏项目源码下载PopStar(一起消灭星星)_210.zip源码cocos creator游戏项目源码下载 1.适合个人学习技术做项目参考 2.适合学生毕业设计项目参考 3.适合小公司开发...

    PopStar(一起消灭星星)_210.rar小游戏源码CocosCreator源码下载料下载

    PopStar(一起消灭星星)_210.rar小游戏源码CocosCreator源码下载料下载PopStar(一起消灭星星)_210.rar小游戏源码CocosCreator源码下载料下载PopStar(一起消灭星星)_210.rar小游戏源码CocosCreator源码下载料下载Pop...

    Cocos2d-x 消灭星星源码 PopStar

    Cocos2d x 消灭星星源码 PopStar @更多@ http: cleopard download csdn net 13份WPF经典开发教程 http: download csdn net album detail 1115 C#资料合辑二[C#桌面编程入门篇] ...C#资料合辑一[C#入门篇] ...

    iOS游戏应用源代码——andresbonilla-Balloon-Pop-Fever.zip

    此游戏源代码可能基于Swift或Objective-C编写,这两种语言都是Apple官方推荐的iOS开发语言。Swift以其简洁的语法和强大的功能深受开发者喜爱,而Objective-C则在历史中积累了丰富的库和资源。源代码中的文件名...

    消灭星星游戏源码.zip

    《消灭星星游戏源码分析与学习指南》 “消灭星星”是一款广受欢迎的休闲消除类游戏,其简单易上手的操作和丰富的关卡设计深受玩家喜爱。本篇将基于提供的c#开发的“消灭星星”游戏源码进行深入剖析,旨在帮助初学者...

    消灭星星 Qt 源代码

    Qt 4.7的工程 和 android 手机 上消灭星星原理一样。QT 代码简短 易懂。

    PopStar-java.rar_Pop star java game_PopStar_java popstar_popstar

    《PopStar-java.rar》是一个包含Java编程语言实现的流行游戏——PopStar(消灭星星)的源代码包。这个游戏是基于Java平台的小型应用程序,展示了Java在开发轻量级游戏方面的应用。下面我们将深入探讨Java语言在游戏...

    cocos2dx PopStar

    本篇文章将聚焦于利用Cocos2d-x开发的一款经典消除游戏——PopStar(消灭星星),通过解析其代码结构和技术细节,为读者提供一个深入理解Cocos2dx游戏开发的窗口。 一、Cocos2d-x基础 1. Cocos2d-x介绍:Cocos2d-x...

    消灭星星小游戏C++版

    "Test_Popstar"很可能是这个游戏的源代码文件或者测试文件,它可能包含了游戏的核心算法,比如如何生成随机的星星布局,如何检查和消除相连的同色星星,以及如何计算得分。源代码分析是学习这个项目的关键,通过阅读...

    cocos2dx 消灭星星源码-popStar

    cocos2dx 消灭星星源码-popStar cocos精品小游戏源码 , 完整项目源码 是整个项目的压缩包 , 新建空项目直接导入到项目里面就可以运行了,无需其他操作。 适合二次开发和学习使用,都是经典游戏,需要其他游戏源码包...

    Cocos2d-X游戏源码 简易消灭星星游戏源码.7z

    本篇将深入探讨利用Cocos2d-X v3.3版本开发的“简易消灭星星”游戏源码,帮助开发者了解游戏的基本结构和关键实现。 首先,源码中的"PopStar"文件夹很可能包含了整个游戏的所有资源和代码。在Cocos2d-X项目中,通常...

    cocos2d-x实现一个PopStar(消灭星星)游戏的逻辑分析及源码-附件资源

    cocos2d-x实现一个PopStar(消灭星星)游戏的逻辑分析及源码-附件资源

    Pop-Star--main.zip

    《Pop-Star--main.zip》是一个基于Qt框架开发的游戏项目,主要围绕着“消灭星星”这一游戏主题进行。Qt是一款跨平台的应用程序开发框架,广泛应用于桌面、移动和嵌入式设备,支持C++语言,提供了丰富的图形用户界面...

    消灭星星Windows-api

    "消灭星星Windows-api"是一个基于Windows API开发的休闲游戏,其核心玩法借鉴了流行的"PopStar! 消灭星星"。Windows API是微软为开发者提供的一个接口集合,它允许程序员直接与操作系统进行交互,实现各种功能,如...

    PopStar_java.rar_PopStar_popstar java_popstarJAVA

    在这个"PopStar_java.rar"压缩包中,包含的是一个用Java语言实现的PopStar小游戏的源代码。这个Java版本的PopStar游戏实现了随机算法来寻找并消除星星,从而在实际运行中能够达到平均每局约4800分的成绩。 首先,...

Global site tag (gtag.js) - Google Analytics