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

PopStar(消灭星星)游戏源代码下载、分析及跨平台移植—第一篇(界面)

阅读更多

背景:

来自星星的你电视剧很火,消灭星星游戏也很火,好像星星都很火,笔者就以星星为主题开始这篇博文。消除类的游戏挺受欢迎的,从2013年度app store最赚钱的游戏–粉碎糖果传奇,到总是可以在游戏排行版看见身影的–消灭星星;玩消除类的游戏好像挺难的,开发这样的游戏是不是巨难?笔者想告诉你的是,开发比玩容易多了。这个PopStar系列总共有五篇,包括(界面,算法,分数,关卡,移植)这五个主题;

ps:

1 这是一个系列博文,代码不会一下子全部放出来,每写一篇放出相应的代码。因为笔者也是抽空编一点程序,然后写一篇博文,断断续续的,没有整块时间;

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

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

 

源代码下载:

请到代码集中营下载:http://blog.makeapp.co/?p=319

 

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

 

       

 

代码分析:

消灭星星包括两个场景:StartLayer和MainLayer;我们先实现开始界面;首先在StartLayer.ccbx设计场景,这个很简单无需解释,功能上主要包括:

 1 点击New Game按钮进入主游戏场景 

StartLayer.prototype.onStartClicked = function () {
    this.newGame.runAction(cc.ScaleTo.create(0.1, 1.2));
    cc.BuilderReader.runScene("", "MainLayer");
}

 2 创建背景的烟花粒子效果,有两个粒子,leaf_open和quanquan

StartLayer.prototype.onEnter = function () {
    this.star.setZOrder(11);
    this.pop.setZOrder(11);
    if (sys.platform != 'browser') {
        if (this.isFirst) {
            this.createBgParticle(200, 800, "leaf_open");
            this.createBgParticle(600, 1000, "quanquan");
            // this.createBgParticle(470, 900, "spark");
            this.isFirst = false;
        }
    }
}

StartLayer.prototype.createBgParticle = function (x, y, name) {
    var particle = cc.ParticleSystem.create("Resources/particles/" + name + ".plist");
    particle.setAnchorPoint(cc.p(0.5, 0.5));
    particle.setPosition(cc.p(x, y));
    particle.setZOrder(10);
    this.rootNode.addChild(particle);
    return particle;
}

 
接着进入了游戏主场景,主场景如何设计也不解释了。随机创建10*10表格的星星群,星星从顶部掉落下来的动画

1 创建随机星星,并单个星星加入掉落动画

MainLayer.prototype.getRandomStar = function (colIndex, rowIndex) {
    this.starSize = 72;
    var stars = PS_MAIN_TEXTURE.STARS;
    var randomStar = stars[getRandom(stars.length)];
    var starSprite = cc.Sprite.createWithSpriteFrameName(randomStar);
    starSprite.setAnchorPoint(cc.p(0.5, 0.5));
    starSprite.setPosition(cc.p(36 + colIndex * this.starSize,
        1300));
    starSprite.starData = {name: randomStar, indexOfColumn: colIndex, indexOfRow: rowIndex};
    starSprite.setZOrder(100);

    var flowTime = rowIndex / 10;
    var fallAction = cc.MoveTo.create(flowTime, cc.p(36 + colIndex * this.starSize,
        36 + rowIndex * this.starSize));
    starSprite.runAction(fallAction);
    return starSprite;
}

2 根据表格位置初始化10*10星星群

MainLayer.prototype.initStarTable = function () {
    this.starTable = new Array(this.numX);
    for (var i = 0; i < this.numX; i++) {
        var sprites = new Array(this.numY);
        for (var j = 0; j < this.numY; j++) {
            var pSprite0 = this.getRandomStar(i, j);
            if (pSprite0 != null) {
                this.rootNode.addChild(pSprite0);
            }

            sprites[j] = pSprite0;
        }
        this.starTable[i] = sprites;
    }
}

在主场景可以点击单个星星,星星进行缩放,这里是为下一篇算法做准备,当前博文代码还不能消除;

 for (var i = 0; i < this.starTable.length; i++) {
        var sprites = this.starTable[i];
        for (var j = 0; j < sprites.length; j++) {
            var pSprite0 = sprites[j];
            if (pSprite0) {
                var ccRect = pSprite0.getBoundingBox();
                if (isInRect(ccRect, this.ccTouchBeganPos)) {
                    this.pSelectedSprite = pSprite0;
                    var scaleAction = cc.Sequence.create(
                        cc.ScaleTo.create(0.2, 1.2), cc.DelayTime.create(0.25), cc.ScaleTo.create(0.2, 1))
                    this.pSelectedSprite.runAction(scaleAction);
                    break;
                }
            }
        }
    }

最后在主场景加入暂停悬浮层,点击右上角的暂停按钮,显示悬浮层,按钮resume点击可以隐藏悬浮层,按钮save&exit点击可以返回到开始界面

MainLayer.prototype.onPauseClicked = function () {
    this.pauseNode.setVisible(true);
}

MainLayer.prototype.onResumeClicked = function () {
    this.pauseNode.setVisible(false);
}

MainLayer.prototype.onSaveExitClicked = function () {
    cc.BuilderReader.runScene("", "StartLayer");
}

到这里,消灭星星的基本框架和界面就完成了;

 

开发工具(2013-02-14 已更新到1.0Beta):

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

cocos2d-x editor 下载,介绍和教程:http://blog.csdn.net/touchsnow/article/details/19070665

cocos2d-x  editor 官方博客:http://blog.makeapp.co/

 

PopStar博文系列:

PopStar(消灭星星)游戏源代码下载、分析及跨平台移植—第一篇(界面) 

PopStar(消灭星星)游戏源代码下载、分析及跨平台移植—第二篇(算法)  ——将写——

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

PopStar(消灭星星)游戏源代码下载、分析及跨平台移植—第四篇(关卡)  ——将写——

PopStar(消灭星星)游戏源代码下载、分析及跨平台移植—第五篇(移植)  ——将写——

 

                                                                          微博关注地址:
 

  • 大小: 24.3 KB
1
0
分享到:
评论

相关推荐

    消灭星星popstar

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

    VC版消灭星星(PopStar)

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

    消灭星星源码 - Pop Star

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

    PopStar源码,消灭星星源码

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

    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...

    消灭星星游戏源码.zip

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

    消灭星星 Qt 源代码

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

    Cocos2d-x 消灭星星源码 PopStar

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

    消灭星星小游戏C++版

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

    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...

    PopStar_java.rar_PopStar_popstar java_popstarJAVA

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

    cocos2dx 消灭星星源码-popStar

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

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

    Cocos2d-X是一款跨平台的游戏开发框架,广泛应用于2D游戏的制作,它基于C++,支持多种编程语言,包括JavaScript、Lua等。本篇将深入探讨利用Cocos2d-X v3.3版本开发的“简易消灭星星”游戏源码,帮助开发者了解游戏...

    PopStar.rar

    "PopStar.rar"是一个包含源代码的压缩包,其中涵盖了两种不同的编程语言实现的自动搜索算法,用于解决“消灭星星”这个游戏的策略问题。这个压缩包的两个核心部分是C++和C#版本的搜索算法,它们都是针对同一游戏目标...

    MFC实现PopStar小游戏

    本篇文章将深入探讨如何利用MFC来实现一个PopStar风格的小游戏。PopStar,又称消除星星,是一款流行的益智游戏,其核心玩法是通过消除相同颜色的方块来得分。 首先,我们需要理解MFC的基本结构。MFC应用通常基于...

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

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

    消灭星星源码全部工程文件

    《消灭星星》是一款广受欢迎的休闲游戏,其源码对于学习和理解游戏开发,特别是Cocos2d-x框架的应用,具有很高的参考价值。Cocos2d-x是一个开源的2D游戏开发框架,基于C++,并支持iOS、Android等多个平台。在Xcode...

    js小游戏 pop star

    JavaScript(简称JS)小游戏“Pop Star”是一款深受玩家喜爱的休闲娱乐项目,它通常采用HTML5、CSS3和JavaScript技术构建,提供一个简单的界面和趣味性的玩法。在这款游戏中,玩家需要消除同色的星星以得分,达到...

Global site tag (gtag.js) - Google Analytics