zoukankan      html  css  js  c++  java
  • cocos2d-js 入门 (主要是HTML5)

    cocos2d-js是cocos2d-x的JavaScript版本,真正跨全平台的游戏引擎,采用原生JavaScript语言,可发布到包括Web平台,iOS,Android,Windows Phone8,Mac,Windows等平台。

    利用cocos2d-js开发HTML5游戏/动画,我们可以通过SDK也可以直接使用js类库:

    l SDK下载:http://cn.cocos2d-x.org/download/

    l js类库:http://www.cocos2d-x.org/filecenter/jsbuilder/

    先说说SDK的开发步骤:

    1、 安装python

    2、 解压SDK,运行setup.py

    3、 运行cmd,新建cocos2d-js项目:cocos new –l js project_name

    4、 使用webStorm等IDE打开项目目录,新建的项目已经有现成HelloWorld例子

    5、 了解一下main.js的说明(关于project.json),然后打开resource.js和app.js阅读代码

    6、 在app.js中正式开始自己的代码编写。当然,这里可以增加新的js文件,需要修改project.json。

    再说说js类库的开发步骤:

    1、 下载类库

    2、 新建HTML页面,引入相应类库

    3、 在onload之后,编写cocos2d-js代码,从cc.game.run()开始。入口代码其实跟SDK开发方式的main.js一样。这里更推荐使用SDK方式,因为可以通过阅读源代码获取API的使用说明。

    开始cocos2d-js开发前,需要洗洗脑,知道cocos2d-js的平面坐标情况。这跟HTML和canvas的布局都不一样。

    wps_clip_image-10616

    在cocos2d-js游戏中,画面的左下角是(0,0),x从左往右递增,而y是从下往上递增的,跟数学的二维坐标系一致。

    Cocos2d-js框架把游戏拆分为很多个场景,当玩家在不同界面切换的时候,框架实际上就是让游戏画面在不同场景中切换。跟Flash一样,cocos2d-js也有最基本的元素——节点Node。节点可以包含子节点,形成树形结构:

    wps_clip_image-1073

    然后,Layer、Sprite继承了节点,实现了更多功能,例如Layer用于表示一个面板一个层,Sprite精灵用于加载图片表示人物。而场景本身也是节点,所以场景中可以添加层,层中可以添加层,也可以添加精灵。

    接着基于刚新建的HelloWorld,做一个简单的例子。

    首先解释一下main.js几行代码。

    cc.game.onStart = function(){
    
        cc.view.adjustViewPort(true); //设置html5的viewport meta属性
    
        cc.view.setDesignResolutionSize(800, 800, cc.ResolutionPolicy.SHOW_ALL); //设置画面尺寸和适配规则
    
        cc.view.resizeWithBrowserSize(true); //设置是否跟随浏览器窗口变化
    
        //load resources
    
        cc.LoaderScene.preload(g_resources, function () {
    
            cc.director.runScene(new GameScene());
    
        }, this);
    
    };
    
    cc.game.run(); //游戏启动

    接着修改app.js:

    var GameLayer = cc.Layer.extend({
    
        ctor: function () {
    
            this._super();
    
            var size = cc.winSize;
    
    //加载背景图
    
            var bg = new cc.Sprite("res/bg.jpg");
    
            this.addChild(bg, 1);
    
            bg.x = size.width/2;
    
            bg.y = size.height/2;
    
    //加载5个小人,不断做旋转和放缩
    
            for (var i = 0; i < 5; i++) {
    
                var man = new cc.Sprite("res/grossini.png");
    
                man.runAction(cc.spawn(cc.rotateBy(1, 360, 360), cc.sequence(cc.scaleTo(1, 2), cc.scaleTo(1, 1))).repeatForever());
    
                this.addChild(man, 2);
    
                man.x = size.width*Math.random();
    
                man.y = size.height*Math.random();
    
            }
    
    //加载5个小人,不断做14帧的动画播放
    
            for (var j = 0; j < 5; j++) {
    
                var man = new cc.Sprite();
    
                var animation = new cc.Animation();
    
                for (var i = 1; i <= 14; i++) {
    
                    animation.addSpriteFrameWithFile("res/grossini_dance_" + (i < 10 ? ("0" + i) : i) + ".png");
    
                }
    
                animation.setDelayPerUnit(1 / 7); //控制动画播放频率
    
                man.runAction(cc.animate(animation).repeatForever());
    
                man.x = size.width*Math.random();
    
                man.y = size.height*Math.random();
    
                this.addChild(man, 3);
    
            }
    
            return true;
    
        }
    
    });
    
    var GameScene = cc.Scene.extend({
    
        onEnter:function () {
    
            this._super();
    
            var layer = new GameLayer();
    
            this.addChild(layer);
    
        }
    
    });

    利用Webstorm的服务器功能,右击index.html使用chrome运行:

    wps_clip_image-14031

    可以看到一堆小人:

    wps_clip_image-10315

    通过这个简单例子,我们对cocos2d-js制作HTML5有了初步印象。后续就可以继续学习官方SDK中附带的samples了,里边的js-tests项目中包含了几乎全部cocos2d-js功能的实例程序,例如:定时器、精灵动作、帧动画、骨骼动画、粒子系统、界面编辑器等等。

    后边,笔者把原来starling的小游戏Hungry hero改造一下,使用cocos2d-js重新实现。这是一个跑酷游戏,玩家需要控制超人不断吃食物,同时避开障碍物。

    wps_clip_image-709wps_clip_image-17852

    演示地址:

    http://kenkozheng.github.io/cocos/hungry_hero/index.html

    代码地址:

    https://github.com/kenkozheng/cocos2d-js/tree/master/hungry_hero

    游戏中使用到:

    1、 基本:鼠标事件、帧动画、声音(cc.audioEngine)

    2、 平行背景(自行实现)

    3、 对象池(cc.pool)

    4、 粒子系统(cc.ParticleSystem)

    5、 位图字体(cc.LabelBMFont)

    6、 批量渲染层(cc.SpriteBatchNode)

    具体的每个知识点就不在这里详细介绍了,具体可以搜索官方SDK samples中的例子。

  • 相关阅读:
    oracle的nvl和sql server的isnull
    Distinct和Group by去除重复字段记录
    shell(2):正则表达式
    一把年纪时,我决定学习区块链
    到这个年纪为什么我还要开始学习理解参与区块链?
    孤荷凌寒自学python第八十六天对selenium模块进行较详细的了解
    孤荷凌寒自学python第八十五天配置selenium并进行模拟浏览器操作1
    孤荷凌寒自学python第八十四天搭建jTessBoxEditor来训练tesseract模块
    孤荷凌寒自学python第八十三天初次接触ocr配置tesseract环境
    孤荷凌寒自学python第八十二天学习爬取图片2
  • 原文地址:https://www.cnblogs.com/kenkofox/p/4153848.html
Copyright © 2011-2022 走看看