1.效果图


艺术与规划说他想与我合作在全国率先主角光环加,椭圆形走动。

cocos2d自带没有,參考网上的写了一个。

2.椭圆数学知识

有关椭圆的数学知识我已经忘光了。网上找了点资料:
a是椭圆的长半轴,b是椭圆的短半轴。

o是角度,范围是[0, 2π]。

我们须要知道椭圆上的位置,能够用以下的公式:

3.直接代码了..

OvalActionInterval.h
#ifndef __JumpGame__OvalInterval__
#define __JumpGame__OvalInterval__ #include "CCActionInterval.h"//包括系统延时类动作头文件 using namespace cocos2d; // 定义一个结构来包括确定椭圆的參数
typedef struct OvalConfig {
//中心点坐标
Vec2 centerPosition;
//椭圆a长半轴
float a;
//椭圆b短半轴
float b;
//是否逆时针运动
bool moveInAnticlockwise;
//two zOrder
std::pair<int, int> zOrder;
} lOvalConfig; /**
以椭圆方式移动
*/ class CC_DLL MoveOvalBy : public ActionInterval{
public:
MoveOvalBy();
//用“动作持续时间”和“椭圆控制參数”初始化动作
bool initWithDuration(float t, const OvalConfig& c);
virtual MoveOvalBy* clone() const override;
virtual MoveOvalBy* reverse() const override;
virtual void update(float t);//利用update函数来不断的设定坐标
virtual void startWithTarget(Node *target) override;
public:
//用“动作持续时间”和“椭圆控制參数”创建动作
static MoveOvalBy *create(float t, const OvalConfig& c); protected:
OvalConfig _config; //x = a * cos(t) t = [0, 2Pi]
inline float getPositionXAtOval(float t ){//返回X坐标
//參数方程
if(_config.moveInAnticlockwise == false){
return _config.a * cos(6.2831852 * (1 - t));
}else{
return _config.a * cos(6.2831852 * t);
} }
//y = b * sin(t) t = [0, 2Pi]
inline float getPositionYAtOval(float t ){//返回Y坐标
//參数方程
if(_config.moveInAnticlockwise == false){
return _config.b * sin(6.2831852 * (1 - t));
}else{
return _config.b * sin(6.2831852 * t);
}
}
private:
CC_DISALLOW_COPY_AND_ASSIGN(MoveOvalBy);
}; #endif

OvalActionInterval.cpp

#include "OvalActionInterval.h"

MoveOvalBy::MoveOvalBy(){

}

//
//MoveOvalBy
//
MoveOvalBy* MoveOvalBy::create(float t, const OvalConfig& c){//利用之前定义的椭圆的參数初始化椭圆
MoveOvalBy *action = new MoveOvalBy();
action->initWithDuration(t, c);
action->autorelease(); return action;
} bool MoveOvalBy::initWithDuration(float t, const OvalConfig& c){
if (ActionInterval::initWithDuration(t)){
_config = c;
return true;
} return false;
}
void MoveOvalBy::update(float t){
//t [0, 1]
//log("t:%f", t);
if (_target){
float x = getPositionXAtOval(t);//调用之前的坐标计算函数来计算出坐标值
float y = getPositionYAtOval(t);
_target->setPosition(_config.centerPosition + Vec2(x, y));//因为我们画计算出的椭圆你做值是以原点为中心的。所以须要加上我们设定的中心点坐标 if(t <= 0.5){
_target->setLocalZOrder(_config.zOrder.first);
}else{
_target->setLocalZOrder(_config.zOrder.second);
}
}
} MoveOvalBy* MoveOvalBy::clone() const{
auto action = new MoveOvalBy();
action->initWithDuration(_duration, _config);
action->autorelease();
return action;
} MoveOvalBy* MoveOvalBy::reverse() const{
OvalConfig newConfig;
newConfig.centerPosition = _config.centerPosition;
newConfig.a = _config.a;
newConfig.b = _config.b;
newConfig.moveInAnticlockwise = !_config.moveInAnticlockwise;
newConfig.zOrder = _config.zOrder;
return MoveOvalBy::create(_duration, newConfig);
} void MoveOvalBy::startWithTarget(Node *target){
ActionInterval::startWithTarget(target);
}

參考:http://blog.csdn.net/ufolr/article/details/7447773

我这里还加上了zOrder。这样有透视效果。

a等于b的时候就是圆形了。

有时候在游戏中略微用上点数学知识感觉非常爽。
调用例如以下:

auto size = this->getContentSize();

    auto ball = Sprite::createWithSpriteFrameName("defenceBall.png");
this->addChild(ball);
ball->setPosition(Vec2(size.width * 0.5, size.height * 0.5) + Vec2(0, 10)); OvalConfig config;
config.a = 100;
config.b = 20;
config.centerPosition = ball->getPosition();
config.moveInAnticlockwise = true;
config.zOrder = make_pair(-1, 0);
auto moveAction = MoveOvalBy::create(1.0, config); ball->runAction(RepeatForever::create(moveAction));

http://www.waitingfy.com/archives/1343

最新文章

  1. Linux系统GCC常用命令和GCC编译过程描述
  2. 基于ReactCSSTransitionGroup实现react-router过渡动画
  3. git-----------------git:如何让git识别我修改了文件夹名字和文件名字的大小写问题。
  4. Gridview实现删除弹出提示信息
  5. Oracle 如何对时间进行简单加减运算
  6. JSP 使用框架frame
  7. 关闭utorrent的广告
  8. BZOJ 1503 郁闷的出纳员
  9. iOS 8 新特性
  10. windows下安装Django
  11. js验证身份证号码
  12. 【原创】-- C# 点滴积累 -- String
  13. spring中WebApplicationContextUtils类说明
  14. mysql创建表及插入数据操作步骤及注意要点
  15. 将php脚本加入开机启动
  16. TortoiseSVN 1.9.5安装 与 Eclipse4.4.2及以上版本中安装SVN插件
  17. .net WinForm 的数据绑定
  18. redis内部数据结构和外部数据结构揭秘
  19. 图片Bitmap在本地的存储与读取 File
  20. MSSQL段落还原脚本

热门文章

  1. Swift - 单例模式的实现
  2. js数组基础整理
  3. Android学习之一:Cygwin简介
  4. windows lwp 乱码问题
  5. 14.10.1 InnoDB Disk I/O
  6. 引用iscroll的一个封装方法
  7. ubuntu12.04 安装 opencv 2.4.8(非源代码编译)
  8. UIGestureRecognizer在多层视图中的触发问题
  9. S3C6410 纯粹的裸机启动,自己写的SD BOOT启动
  10. 延迟函数 比sleep效果好