Cocos2d-JS加速度计与加速度事件,cocos2d-js加速度
在很多移动设备的游戏使用到了加速度计,Cocos2d-JS引擎提供了访问加速度计传感器的能力。本节我们首先介绍一下加速度计传感器,然后再介绍如何在Cocos2d-JS中访问加速度计。加速度计加速度计是一种能够感应设备一个方向上线性加速度的传感器。广泛用于航空、航海、宇航及武器的制导与控制中。线加速度计的种类很多,在iOS等移动设备中目前采用的是三轴加速度计,可以感应设备上X、Y、Z轴方向上线性加速度的变化。如下图所示,iOS和Android等设备三轴加速度计的坐标系是右手坐标系,即:设备竖直向上,正面朝向用户,水平向右为X轴正方向,竖直向上为Y轴正方向,Z轴正方向是从设备指向用户方向。iOS上三轴加速度计提示 有人将加速度计称之为“重力加速度计”,这种观点有错误的。作用于三个轴上的加速度是指所有加速度的总和,包括了由重力产生的加速度和用户移动设备产生的加速度。在设备静止的情况下,这时候的加速度就只是重力加速度。实例:运动的小球下面我们通过一个实例介绍一下如果通过层加速度计事件实现访问加速度计。该实例场景如下图所示,场景中有一个小球,当我们把移动设备水平放置,屏幕向上,然后左右晃动移动设备来改变小球的位置。访问加速度计实例下面我们再看看具体的程序代码,首先看一下app.js文件,它的主要代码如下: var HelloWorldLayer = cc.Layer.extend({
ctor:function () {
this._super();
cc.log("HelloWorld init");
var size = cc.director.getWinSize();
var bg = new cc.Sprite(res.Background_png);
bg.x = size.width/2;
bg.y = size.height/2;
this.addChild(bg, 0, 0);
var ball = new cc.Sprite(res.Ball_png);
ball.x = size.width/2;
ball.y = size.height/2;
this.addChild(ball, 10, SpriteTags.kBall_Tag);
return true;
},
onEnter: function () {
this._super();
cc.log("HelloWorld onEnter");
var ball = this.getChildByTag(SpriteTags.kBall_Tag);
cc.inputManager.setAccelerometerEnabled(true); ①
cc.eventManager.addListener({ ②
event: cc.EventListener.ACCELERATION, ③
callback: function(acc, event){ ④
var size = cc.director.getWinSize(); ⑤
var s = ball.getContentSize(); ⑥
var p0 = ball.getPosition();
var p1x = p0.x + acc.x * SPEED ; ⑦
if ((p1x - s.width/2) <0) { ⑧
p1x = s.width/2; ⑨
}
if ((p1x + s.width / 2) > size.width) { ⑩
p1x = size.width - s.width / 2;