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. 微软官方的.net命令行参数库

    虽然现在是图形化大行其道的时代,但让程序支持命令行启动对于专业的领域还是有不少需求的..net本身并没有内置对命令行解析的支持,我之前就写过一篇文章让.Net程序支持命令行启动介绍了几个第三方的命令行 ...

  2. NVIDIA-docker报错:docker-ce (= 5:18.09.0~3-0~ubuntu-xenial) but 18.06.0~ce~3-0~ubuntu is to be installed

    报错: The following packages have unmet dependencies: nvidia-docker2 : Depends: docker-ce (= 5:18.09.0 ...

  3. 【Spark】榨干Spark性能-driver、exector内存突破256M

    榨干Spark性能-driver.exector内存突破256M spark driver memory 256m_百度搜索 Spark executor.memory - CSDN博客 sparkd ...

  4. 原创:vsphere概念深入系列四:Nic Teaming若干问题

    参考文档:http://www.hyper-v.nu/archives/marcve/2013/01/lbfo-hyper-v-switch-qos-and-actual-performance-pa ...

  5. M1 卡技术规范

    射频卡简单来讲就是卡的一种工作方式,通过感应的方式来工作,也能够把全部的感应卡都统称为射频卡. IC卡的范围比較广.芯片外露的接触式IC卡.芯片内置的感应式IC卡和双界面IC卡都可统称为IC卡.IC卡 ...

  6. java command line error opening registry key 'Software\JavaSoft\Java Runtime Environment' java.dll

    C:\Users\huxxxxchan>javaError: opening registry key 'Software\JavaSoft\Java Runtime Environment'E ...

  7. InnoDB 存储引擎的主要知识点介绍

    本文转载自:Draveness,略有修改 原文链接:『浅入浅出』MySQL 和 InnoDB · 面向信仰编程 作为一名开发人员,在日常的工作中会难以避免地接触到数据库,无论是基于文件的 sqlite ...

  8. (原)ubuntu中使用conda安装tensorflow-gpu

    转载请注明出处: https://www.cnblogs.com/darkknightzh/p/9834567.html 参考网址: https://www.anaconda.com/blog/dev ...

  9. 安装babel遇到的异常

    Error: Requires Babel "^7.0.0-0", but was loaded with "6.26.3". If you are sure ...

  10. Python多进程库multiprocessing中进程池Pool类的使用[转]

    from:http://blog.csdn.net/jinping_shi/article/details/52433867 Python多进程库multiprocessing中进程池Pool类的使用 ...