Enemy类在Enemy.js中,类Enemy类继承自PhysicsSprite,以便于可以使用物理引擎中的一些特性。

原版的Enemy.js:

 var Enemy = cc.PhysicsSprite.extend({//PhysicsSprite
enemyType: 0, //敌人类型
initialHitPoints: 0, //初始的生命值
hitPoints: 0, //当前的生命值
velocity: null, //速度
space: null, //所在物理空间
ctor: function (enemyType, space) {
//精灵帧
var enemyFramName = EnemyName.Enemy_Stone;
//得分值
var hitPointsTemp = 0;
//速度
var velocityTemp = cc.p(0, 0);
switch (enemyType) {
case EnemyTypes.Enemy_Stone:
enemyFramName = EnemyName.Enemy_Stone;
hitPointsTemp = Enemy_initialHitPoints.Enemy_Stone;
velocityTemp = Sprite_Velocity.Enemy_Stone;
break;
case EnemyTypes.Enemy_1:
enemyFramName = EnemyName.Enemy_1;
hitPointsTemp = Enemy_initialHitPoints.Enemy_1;
velocityTemp = Sprite_Velocity.Enemy_1;
break;
case EnemyTypes.Enemy_2:
enemyFramName = EnemyName.Enemy_2;
hitPointsTemp = Enemy_initialHitPoints.Enemy_2;
velocityTemp = Sprite_Velocity.Enemy_2;
break;
case EnemyTypes.Enemy_Planet:
enemyFramName = EnemyName.Enemy_Planet;
hitPointsTemp = Enemy_initialHitPoints.Enemy_Planet;
velocityTemp = Sprite_Velocity.Enemy_Planet;
break;
} this._super("#" + enemyFramName);
this.setVisible(false); this.initialHitPoints = hitPointsTemp;
this.velocity = velocityTemp;
this.enemyType = enemyType; this.space = space; var shape; if (enemyType == EnemyTypes.Enemy_Stone || enemyType == EnemyTypes.Enemy_Planet) {
this.body = new cp.Body(10, cp.momentForCircle(1, 0, this.getContentSize().width / 2 - 5, cp.v(0, 0)));
shape = new cp.CircleShape(this.body, this.getContentSize().width / 2 - 5, cp.v(0, 0));
} else if (enemyType == EnemyTypes.Enemy_1) {
var verts = [
-5, -91.5,
-59, -54.5,
-106, -0.5,
-68, 86.5,
56, 88.5,
110, -4.5
];
this.body = new cp.Body(1, cp.momentForPoly(1, verts, cp.vzero));
shape = new cp.PolyShape(this.body, verts, cp.vzero);
} else if (enemyType == EnemyTypes.Enemy_2) {
var verts = [
2.5, 64.5,
73.5, -9.5,
5.5, -63.5,
-71.5, -6.5
];
this.body = new cp.Body(1, cp.momentForPoly(1, verts, cp.vzero));
shape = new cp.PolyShape(this.body, verts, cp.vzero);
} this.space.addBody(this.body); shape.setElasticity(0.5);
shape.setFriction(0.5);
shape.setCollisionType(Collision_Type.Enemy);
this.space.addShape(shape);
//this.setBody(this.body);
this.body.data = this; this.scheduleUpdate();
}, update: function (dt) {
//设置陨石和行星旋转.
switch (this.enemyType) {
case EnemyTypes.Enemy_Stone:
this.setRotation(this.getRotation() - 0.5);
break;
case EnemyTypes.Enemy_Planet:
this.setRotation(this.getRotation() + 1);
break;
}
//计算移动位置
var newX = this.body.getPos().x + this.velocity.x * dt;
var newY = this.body.getPos().y + this.velocity.y * dt; this.body.setPos(cc.p(newX, newY)); //超出屏幕重新生成敌人
if (this.body.getPos().y + this.getContentSize().height / 2 < 0) {
this.spawn();
}
},
spawn: function () {
var yPos = winSize.height + this.getContentSize().height / 2;
var xPos = cc.random0To1() * (winSize.width - this.getContentSize().width) + this.getContentSize().width / 2;
this.body.setPos(cc.p(xPos, yPos));
this.hitPoints = this.initialHitPoints;
this.setVisible(true);
}
});

第44行:初始化敌人所在的物理空间,使用物理空间引入物理引擎,进行碰撞检测。
第49~80行:将敌人对象添加物理引擎支持,使之能够利用物理引擎精确检测碰撞。
(当然不适用物理引擎,也可以检测碰撞,一般情况下只能检测简单的矩形碰撞,不够精准)
第49行:是在敌人类型是陨石和行星情况下创建物理对象,cp.momentForCircle函数是创建圆形物理惯性力矩,其中第一个参数是质量,1是经验值;第二个参数是圆形内径;第三个参数是圆形外径;第四个参数是偏移量。
第50行:为物体添加圆形形状,其中this.getContentSize().width/2是半径,-5是修正值。
第52行:使用verts坐标数组创建物体。
第61行:为物体添加多边形形状,这是针对飞机形状的敌人。
提示:由于底层封装了Chipmunk引擎,Chipmunk要求多边形定点数据必须是按照顺时针,必须是凸多边形。如果遇到凹多边形,则可以把它分割成为几个凸多边形。另外,顶点坐标的原点在图形的中心,OpenGL坐标。
第73行:this.space.addBody(this.body)是将上面定义好的物体对象添加到物理空间中。
第75行:shape.setElasticity(0.5)是为形状设置弹性系数。
第76行:shape.setFriction(0.5)是为形状设置摩擦系数。
第77行:通过shape.setCollisionType(Collision_Type.Enemy)语句为形状设置碰撞检测类型。
第78行:this.space.addShape(shape)语句将形状添加到物理空间中。
第80行:this.body.data=this是把精灵放到物体的data数据成员中,这样在碰撞发生的时候可以通过下面的语句从物体取出精灵对象。

LostRoutes项目日志——敌人精灵Enemy解析的更多相关文章

  1. LostRoutes项目日志——玩家飞机精灵Fighter解析

    Fighter类的定义在Fighter.js中,Fighter类继承与PhysicsSprite. 原版的Fighter.js: var Fighter = cc.PhysicsSprite.exte ...

  2. LostRoutes项目日志——在main.js中添加多分辨率适配

    初始的Cocos2d-JS项目中的main.js代码的内容为: /** * A brief explanation for "project.json": * Here is th ...

  3. LostRoutes项目日志——编辑project.json

    第一个Scene编译后运行会报错: Uncaught TypeError: Cannot read property 'style' of null 这是因为没有在project.json中包含已经编 ...

  4. springmvc 项目完整示例06 日志–log4j 参数详细解析 log4j如何配置

    Log4j由三个重要的组件构成: 日志信息的优先级 日志信息的输出目的地 日志信息的输出格式 日志信息的优先级从高到低有ERROR.WARN. INFO.DEBUG,分别用来指定这条日志信息的重要程度 ...

  5. 大数据学习day39----数据仓库02------1. log4j 2. 父子maven工程(子spring项目的创建)3.项目开发(埋点日志预处理-json数据解析、清洗过滤、数据集成实现、uid回补)

    1. log4j(具体见log4j文档) log4j是一个java系统中用于输出日志信息的工具.log4j可以将日志定义成多种级别:ERROR  /  WARN  /  INFO  /  DEBUG ...

  6. 学习Coding-iOS开源项目日志(二)

    继续前篇:<学习Coding-iOS开源项目日志(一)>,接着本第二篇<学习Coding-iOS开源项目日志(二)>讲解Coding-iOS开源项目. 前言:作为初级程序员,想 ...

  7. 学习Coding-iOS开源项目日志(五)

    继续,接着前面第四篇<学习Coding-iOS开源项目日志(四)>讲解Coding-iOS开源项目. 前 言:作为初级程序员,想要提高自己的水平,其中一个有效的学习方法就是学习别人好的项目 ...

  8. 学习Coding-iOS开源项目日志(一)

    前言:作为初级程序员,想要提高自己的水平,其中一个有效的学习方法就是学习别人好的项目.本篇开始会陆续更新本人对github上开源的一个很不错的项目的一点点学习积累.也就是,探究着别人写的源码,我学到了 ...

  9. 学习Coding-iOS开源项目日志(三)

    继续前两篇,接着本第三篇<学习Coding-iOS开源项目日志(三)>讲解Coding-iOS开源项目. 前 言:作为初级程序员,想要提高自己的水平,其中一个有效的学习方法就是学习别人好的 ...

随机推荐

  1. android常用工具收集

    1.脱壳工具 https://github.com/DrizzleRisk/drizzleDumper

  2. spring cloud: 升级到spring boot 2.x/Finchley.RELEASE遇到的坑

    spring boot2.x已经出来好一阵了,而且spring cloud 的最新Release版本Finchley.RELEASE,默认集成的就是spring boot 2.x,这几天将一个旧项目尝 ...

  3. [原创]Eclipse Memory Analyzer tool(MAT)工个使用介绍

    [原创]Eclipse Memory Analyzer tool(MAT)工个使用介绍

  4. J-Link GDB Server Command

    J-Link GDB Server - SEGGER Hilden, Germany – September 15th, 2011 – SEGGER Microcontroller today ann ...

  5. .Net Core AES加密解密

    一.AES说明 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标准用来替 ...

  6. Android添加全屏启动画面

    有的Android软件需要在启动的时候显示一个启动画面,可以是一张图或者一些设置什么呢,还有一个好处就是,可以趁机在后台加载数据.创建启动画面一般有两种方式:1.建立一个activity,展示启动画面 ...

  7. [Python设计模式] 第1章 计算器——简单工厂模式

    github地址:https://github.com/cheesezh/python_design_patterns 写在前面的话 """ 读书的时候上过<设计模 ...

  8. windows多线程同步--互斥量

    关于互斥量的基本概念:百度百科互斥量 推荐参考博客:秒杀多线程第七篇 经典线程同步 互斥量Mutex 注意:互斥量也是一个内核对象,它用来确保一个线程独占一个资源的访问.互斥量与关键段的行为非常相似, ...

  9. Redis系列--内存淘汰机制(含单机版内存优化建议)

    https://blog.csdn.net/Jack__Frost/article/details/72478400?locationNum=13&fps=1 每台redis的服务器的内存都是 ...

  10. [kubernetes]helm安装

    下载 HELM_VERSION=${K8S_VERSION:-"2.11.0"} HELM="helm-v${HELM_VERSION}-linux-amd64" ...