Cocos2d-x加速度计实例:运动的小球

下面我们通过一个实例介绍一下如果通过层加速度计事件实现访问加速度计。该实例场景如下图所示,场景中有一个小球,当我们把移动设备水平放置,屏幕向上,然后左右晃动移动设备来改变小球的位置。

下面我们再看看具体的程序代码,首先看一下HelloWorldScene.h文件,它的代码如下:

[html] view plaincopy

  1. #ifndef __HELLOWORLD_SCENE_H__
  2. #define __HELLOWORLD_SCENE_H__
  3. #include "cocos2d.h"
  4. #define kBall_Tag                 100                                                                                                          ①
  5. #define SPEED                      30.0                                                                                                        ②
  6. class HelloWorld : public cocos2d::Layer
  7. {
  8. public:
  9. static cocos2d::Scene* createScene();
  10. virtual bool init();
  11. virtual void onEnter();
  12. virtual void onExit();
  13. virtual voidonAcceleration(cocos2d::Acceleration* acc, cocos2d::Event *unused_event);         ③
  14. CREATE_FUNC(HelloWorld);
  15. };
  16. #endif // __HELLOWORLD_SCENE_H__

上述代码第①行定义宏kBall_Tag,它是小球精灵的标签Tag数值。第②行定义宏SPEED,它表示小球运动的速度。第③行代码声明了onAcceleration函数,。

HelloWorldScene.cpp文件,它的主要代码如下:

[html] view plaincopy

  1. bool HelloWorld::init()
  2. {
  3. if( !Layer::init() )
  4. {
  5. returnfalse;
  6. }
  7. SizevisibleSize = Director::getInstance()->getVisibleSize();
  8. Pointorigin = Director::getInstance()->getVisibleOrigin();
  9. //贴图的纹理图片宽高必须是2的n次幂,128x128
  10. autobg = Sprite::create("BackgroundTile.png",
  11. Rect(0,0, visibleSize.width, visibleSize.height));
  12. //贴图的纹理参数,水平重复平铺,垂直重复平铺
  13. Texture2D::TexParamstp = {GL_LINEAR, GL_LINEAR, GL_REPEAT, GL_REPEAT};
  14. bg->getTexture()->setTexParameters(tp);
  15. bg->setPosition(origin+ Point(visibleSize.width/2, visibleSize.height/2));
  16. addChild(bg,0);
  17. autoball = Sprite::create("Ball.png");
  18. ball->setPosition(origin+Point(visibleSize.width/2,visibleSize.height/2));
  19. addChild(ball,10, kBall_Tag);
  20. returntrue;
  21. }
  22. void HelloWorld::onEnter()
  23. {
  24. Layer::onEnter();
  25. log("HelloWorldonEnter");
  26. setAccelerometerEnabled(true);                                                                                                      ①
  27. }
  28. void HelloWorld::onAcceleration(Acceleration*acc, Event *unused_event)
  29. {
  30. log("{x = %f, y = %f}", acc->x,acc->y);
  31. Size visibleSize = Director::getInstance()->getVisibleSize();
  32. Sprite* ball = (Sprite*)this->getChildByTag(kBall_Tag);                                                  ②
  33. Size s = ball->getContentSize();                                                                                                    ③
  34. Point p0 = ball->getPosition();                                                                                                      ④
  35. float p1x =  p0.x + acc->x *SPEED ;                                                                                  ⑤
  36. if ((p1x - s.width/2) <0) {                                                                                                       ⑥
  37. p1x = s.width/2;                                                                                                               ⑦
  38. }
  39. if ((p1x + s.width / 2) > visibleSize.width) {                                                                                   ⑧
  40. p1x = visibleSize.width - s.width / 2;                                                                             ⑨
  41. }
  42. float p1y =  p0.y + acc->y *SPEED ;
  43. p1y = p1y < 0 ? -p1y : p1y;
  44. if ((p1y - s.height/2) < 0) {
  45. p1y = s.height/2;
  46. }
  47. if ((p1y + s.height/2) > visibleSize.height) {
  48. p1y = visibleSize.height - s.height/2;
  49. }
  50. ball->runAction(Place::create(Point( p1x, p1y)));                                                                       ⑩
  51. }
  52. void HelloWorld::onExit()
  53. {
  54. Layer::onExit();
  55. log("HelloWorldonExit");
  56. }

上述代码①行开启加速计设备,这个代码是在HelloWorld::onEnter()函数中,意味着在进入层的时候就开启加速度计设备。

在第②行代码是通过标签属性获得小球精灵对象。第③行代码ball->getContentSize()获得小球尺寸大小。第④行代码ball->getPosition()是获得小球的位置。第⑤行代码是p0.x + acc->x * SPEED是获得小球的x轴方向移动的位置,但是需要考虑左右超出屏幕的情况,第⑥行代码是 (p1x - s.width/2) <0是判断超出左边屏幕,这种情况下我们需要通过第⑦行代码p1x = s.width/2重新设置它的x轴坐标。第⑧行代码(p1x+ s.width / 2) > visibleSize.width是判断超出右边屏幕,这种情况下我们需要通过第⑨行代码p1x = visibleSize.width - s.width / 2重新设置它的x轴坐标。类似的判断y轴也需要,代码就不再解释了。

重新获得小球的坐标位置后,通过第⑩行代码ball->runAction(Place::create(Point( p1x, p1y)))是执行一个动作使小球移动到新的位置。

更多内容请关注Cocos2d-x系列图书《Cocos2d-x实战(卷Ⅰ):C++开发》

本书交流讨论网站:http://www.cocoagame.net

欢迎加入cocos2d-x技术讨论群:257760386、327403678

Cocos2d-x加速度计实例:运动的小球,布布扣,bubuko.com

时间: 2024-12-24 00:44:04

Cocos2d-x加速度计实例:运动的小球的相关文章

JavaScript实例:运动的小球

本篇博文通过制作一个小球运动动画的实例,来学习在HTML5的画布上实现动画制作的方法,同时理解面向对象程序设计的基本思想. 1.绘制小球 先在HTML页面中设置一个画布. <canvas id="myCanvas" width="400" height="300" style="border:3px double #996633;"> </canvas> 再将小球画在canvas(画布)上面. 可编写如

自定义View,随着手指运动的小球

这个实例是自定的view的初步介绍,要设计的是一个随着手指运动的小球.原理是随时获取手指的坐标,然后在这个坐标上面实时改变自定义view的坐标.这个view仅仅是画了一个圆形而已. 自定义的view DrawView.java package com.kale.drawview; import android.annotation.SuppressLint; import android.content.Context; import android.graphics.Canvas; impor

Cocos2d入门--3--小球运动

本章直接上源代码.内容不难,主要就是 HelloWorldScene.h文件: 1 #ifndef __HELLOWORLD_SCENE_H__ 2 #define __HELLOWORLD_SCENE_H__ 3 4 #include "cocos2d.h" 5 6 class HelloWorld : public cocos2d::Layer 7 { 8 protected: 9 float _angle; 10 cocos2d::Vec2 _vec; 11 public: 12

运动的小球自动变键盘控制

<!DOCTYPE html>,<html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"> .box{ width: 400px;height: 400px;border: 1px solid black;position: relative;} .ball{width: 30px;heig

链式运动实例 运动框架应用 微博

源代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Con

运动的小球

1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title></title> 6 <style type="text/css"> 7 #box{width: 500px;height: 500px;border: 1px solid black;position: relative;} 8 #ball{w

Windows Store App JavaScript 开发:小球运动示例

通过前面内容的学习,相信读者已经对开发基于JavaScript的Windows应用商店应用有了一定的了解,本小节通过一个小球运动的示例来介绍如何新建一个JavaScript的Windows应用商店项目,以及怎样向项目中添加功能实现代码. 首先启动Visual Studio 2012集成开发工具,打开"文件"菜单,选择其中的"新建项目"菜单项后会弹出"新建项目"窗口.在"新建项目"窗口左侧的JavaScript模板分类中选择&q

Cocos2d-JS加速度计与加速度事件

在很多移动设备的游戏使用到了加速度计,Cocos2d-JS引擎提供了访问加速度计传感器的能力.本节我们首先介绍一下加速度计传感器,然后再介绍如何在Cocos2d-JS中访问加速度计.加速度计加速度计是一种能够感应设备一个方向上线性加速度的传感器.广泛用于航空.航海.宇航及武器的制导与控制中.线加速度计的种类很多,在iOS等移动设备中目前采用的是三轴加速度计,可以感应设备上X.Y.Z轴方向上线性加速度的变化.如下图所示,iOS和Android等设备三轴加速度计的坐标系是右手坐标系,即:设备竖直向上

笔记-2.带尾巴小球弹跳

先说尾巴跟随: 尾巴跟随是典型的运动跟随,随着根部的运动,尾巴的每部分自然而柔软地跟随运动,中间帧不能出现直挺挺的尾巴这种不自然的状态,也不能出现僵硬的运动. 具体实现: 可以通过一个个中间帧调节尾巴不同部分来达到自然柔软的效果,但对于尾巴跟随运动最简单的是拖帧法,即从根部到尾部按顺序少选一个控制器,将关键帧依次向后拖动几帧(就是让尾巴从根部向尾部的运动变化依次向后慢几帧出现). 运动曲线是这样的: 可以拖动曲线让根部摆动幅度小些: 同理可以再做出尾巴其他方向的摆动 --------------