cocos2d-x 3.0 Armature jsb 初体验
有段时间没有写游戏代码了,这回来主要任务是要用jsb构建一个aprg动作游戏,看到3.0官方已经绑定好了armature的js函数,先来体验一把
3.0新建项目比2.2方便了很多,在终端运行tools下的create_project.py, 出现新建项目的图形界面! 赞
新建好一个js项目,像住场景添加一个龙骨动画:(记得在appdelegate.cpp中导入相关的绑定头文件,然后register...)
ccs.ArmatureDataManager.getInstance().addArmatureFileInfo("res/d3.png", "res/d3.plist", "res/d3.xml");
armature = ccs.Armature.create("demo");
...
this.addchild(armature);
ok,龙骨的动画显示出来了;
一个点击播放一个动作,手有点生了,点击响应要先在layer的继承类的ctor中:this.setTouchEnabled(true);
然后就可以在类中使用 onTouchesBegan和onTouchesEnded函数了;
Armature的基本使用:
ccs.ArmatureDataManager.getInstance().addArmatureFileInfo() 当导入cocostudio类型文件时(只需一个.ExportJson文件参数),当导入龙骨时(三个参数, png, plist, xml)
create(class_name) 传入类名来生成动画实例
getAnimation().playWithIndex(n) 从第n个动作开始播放;
++i; i = i% armature.getAnimation().getMovementCount(); armature.getAnimation().playWithIndex(i,10);在点击事件中用这个方法可以逐个播放所有动作:
getAnimation().setSpeedScale(f) 设置动画的播放速度
armature.init("Knight_f/Knight"); 等同与create+playerWithIndex ?
setZOrder(n) 改变动画的所在层级;
getAnimation().play(name,n) 播放动作名为name的动作, n参数很有用,设置两个动作间自动补间的帧数,让动作看起来更平滑;
Armature可以监听动作事件,设置某个动作事件时触发回调动作,例如:
getAnimation().setMovementEventCallFunc(this.animationEvent,this); //为Armature添加一个事件监听
animationEvent:function (armature, movementType, movementID) { //当事件loopComplete发生时触发下一个动作;
if (movementType == ccs.MovementEventType.loopComplete) {
if (movementID == "Fire") {...}}}
几个预定义的事件: boneFrameEvent/complete/loopComplete/movementChange/movementFameEvent/start
Armature也可以监听帧事件,设置某个帧事件时候触发回调动作,例如:
armature.getAnimation().setFrameEventCallFunc(this.onFrameEvent, this);
onFrameEvent: function (bone, evt, originFrameIndex, currentFrameIndex) {
}
添加骨骼,这里我们可以添加一个骨骼,设置它的表现(比如粒子光效),然后把它绑定在某个已有的骨骼上,这样光效就会跟随骨骼移动了
var p1 = cc.ParticleSystem.create("res/Particles/LavaFlow.plist"); //创建粒子
p1.setTotalParticles(50);var bone = ccs.Bone.create("p1"); //创建一个新的骨骼p1
bone.addDisplay(p1, 0); //为新骨骼添加一个表现
bone.changeDisplayWithIndex(0, true); //显示新骨骼的表现
bone.setIgnoreMovementBoneData(true); //?
bone.setZOrder(100);
bone.setScale(1.2);
this.armature.addBone(bone, "effect"); //将新的骨骼绑定到armature上的effect骨骼上,让新骨骼随effect骨骼运动;
修改骨骼的表现,实现换装效果
for (var i = 0; i < 7; i++) {
var skin = ccs.Skin.createWithSpriteFrameName(weapon[i]); //创建skin对象
this.armature.getBone("weapon").addDisplay(skin, i); //将skin对象添加到某个骨骼对象上
}
...
this.armature.getBone("weapon").changeDisplayWithIndex(this.displayIndex, true); //切换骨骼外观
3.0的绘图使用了新的api, 绘制出armature的碰撞边缘:
init:function(){
...
this.shape = cc.DrawNode.create(); //创建新画板
this.addChild(this.shape, 10);
this.schedule(this.draw,2); //jsb下,draw函数是不会自动运行的
}
draw:function () {
this.shape.clear(); //清楚上一帧的绘制
var size = cc.Director.getInstance().getWinSize();
var rect = this.armature.getBoundingBox(); //获取armature的边界
var rectArr = [ //将边界转为drawPoly所用的坐标
cc.p(rect.x, cc.rectGetMaxY(rect)),
cc.p(rect.x, rect.y),
cc.p(cc.rectGetMaxX(rect), rect.y),
cc.p(cc.rectGetMaxX(rect), cc.rectGetMaxY(rect))
];
this.shape.drawPoly(rectArr, cc.c4f(0,0,0,0), 1, cc.c4f(0, 1, 0, 1)); //绘制图形,点与点之间顺序相连,第二个参数是填充,第三个是线粗细,第四个是边框
}
来张效果图:

cocos2d-x 3.0 Armature jsb 初体验的更多相关文章
- vue.js2.0 自定义组件初体验
理解 组件(Component)是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码.在较高层面上,组件是自定义元素, Vue.js 的编译器为它添加特殊功能.在有些情况 ...
- 阿里百川HotFix2.0热修复初体验
博客原地址:http://blog.csdn.net/allan_bst/article/details/72904721 一.什么是热修复 热修复说白了就是"打补丁",比如你们公 ...
- AutoIt 3.0 操作之初体验(第一个脚本hello world)
AutoIt 目前最新是v3 版本,它是一个使用类似BASIC 脚本语言的免费软件,它被设计用来进行Windows GUI(图形用户界面)的自动化测试.它利用模拟键盘按键,鼠标移动和窗口/控件的组合来 ...
- 【腾讯Bugly干货分享】基于 Webpack & Vue & Vue-Router 的 SPA 初体验
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57d13a57132ff21c38110186 导语 最近这几年的前端圈子,由于 ...
- 基于 Webpack & Vue & Vue-Router 的 SPA 初体验
基于 Webpack & Vue & Vue-Router 的 SPA 初体验 本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com ...
- ASP.NET2.0组件控件开发视频 初体验
原文:ASP.NET2.0组件控件开发视频 初体验 ASP.NET2.0组件控件开发视频 初体验 录了视频,质量不是很好,大家体验下.我会重新录制的 如果不清楚,可以看看http://v.youku. ...
- ASP.NET Core 3.0 上的gRPC服务模板初体验(多图)
早就听说ASP.NET Core 3.0中引入了gRPC的服务模板,正好趁着家里电脑刚做了新系统,然后装了VS2019的功夫来体验一把.同时记录体验的过程.如果你也想按照本文的步骤体验的话,那你得先安 ...
- (一)SpringBoot2.0基础篇- 介绍及HelloWorld初体验
1.SpringBoot介绍: 根据官方SpringBoot文档描述,BUILD ANYTHING WITH SPRING BOOT (用SPRING BOOT构建任何东西,很牛X呀!),下面是官方文 ...
- Django3.0 异步通信初体验
此前博主曾经写过一篇博文,介绍了Django3.0的新特性,其中最主要的就是加入对ASGI的支持,实现全双工的异步通信. 2019年12月2日,Django终于正式发布了3.0版本.怀着无比的期待,我 ...
随机推荐
- 气死人不偿命,Q_OBJECT导致的C++报错,而且还看不明白(#ifdef没控制好,导致什么都不认识了)
为了代码可以同时适应VC++和MingW编译器,我改动了我的代码,变成: #ifdef _MSC_VER #pragma comment(lib, "crypt32.lib") / ...
- Android:双层嵌套ViewPager并添加单击事件
仿网易新闻: 实现原理: 上面的导航栏是一个自定义的ViewGroup(类似ActionBar) 中间内容层是ViewPager套fragment实现左右切换滑动 fragment里面的布局是一个Li ...
- BZOJ_1620_[Usaco2008_Nov]_Time_Management_时间管理_(二分+贪心)
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1620 N个工作,每个工作其所需时间,及完成的Deadline,问要完成所有工作,最迟要什么时候 ...
- Nagios ’status.cgi‘文件权限许可和访问控制漏洞
漏洞名称: Nagios ’status.cgi‘文件权限许可和访问控制漏洞 CNNVD编号: CNNVD-201307-013 发布时间: 2014-02-21 更新时间: 2014-02-21 危 ...
- Linux Kernel ‘exitcode_proc_write()’函数本地缓冲区溢出漏洞
漏洞名称: Linux Kernel ‘exitcode_proc_write()’函数本地缓冲区溢出漏洞 CNNVD编号: CNNVD-201311-061 发布时间: 2013-11-07 更新时 ...
- iOS添加自定义字体方法
1:获取字体文件 从各种渠道下载字体文件ttf, 网站或者从别的ipa里扣出来.(以fzltxh.ttf为例) 2:将fzltxh.ttf文件拷贝到工程中 3:在Info.plist中添加项: Fon ...
- Android学习之路——简易版微信为例(三)
最近好久没有更新博文,一则是因为公司最近比较忙,另外自己在Android学习过程和简易版微信的开发过程中碰到了一些绊脚石,所以最近一直在学习充电中.下面来列举一下自己所走过的弯路: (1)本来打算前端 ...
- C#读取设置Cookie
设置: HttpCookie cookie = new HttpCookie("cookieName"); cookie.Value = "name1" Htt ...
- openlayer调用geoserver发布的地图实现地图的基本功能
转自:http://starting.iteye.com/blog/1039809 主要实现的功能有放大,缩小,获取地图大小,平移,线路测量,面积测量,拉宽功能,显示标注,移除标注,画多边形获取经纬度 ...
- Selenium IDE初探
系列教程: http://www.cnblogs.com/hyddd/archive/2009/05/30/1492536.html 使用过程中,出现了一些问题.