晓石头的博客

邮箱:178673693@qq.com

转载请注明出处,原文连接:http://www.jb51.cc/article/p-oyajubhs-vx.html



效果演示图

一、贝塞尔曲线生成工具

工欲善其事必先利其器,好的工具能让你如虎添翼。Cocos2D中画贝塞尔曲线,最大的难点就是定坐标:起点、控制点一、控制点二、终点。嘿嘿,有了这个工具你就会感觉到神马是面朝大海,春暖花开,一片祥和的景象。进主题,先上图:


啊,你说你木有这个工具,这个好说,工具和源代码都本文末尾。

1.1的左下角是贝塞尔曲线的四个点,对应到图中的

p0:起点

p1:控制点一

p2:控制点二

p3:终点

绿色的线即为绘制的贝塞尔曲线。(心形的一半有木有^_^

这样便得到了坐标点:

p0(280,145);

p1(191,2);

p2(11,189);

p3(271,307);

由于该工具的零点位置设置的是左上角,而我们的Cocos2D零点在左下角,故对Y坐标需要转换下。工具窗口的高为320,用320-YCocos2DY坐标。

转换后的坐标:

p0(280,320-145) -> p1(280,175)

p1(191,320-2) -> p2(191,318)

p2(11,320-189) -> p3(11,131)

p3(271,320-307) -> p4(271,13)

二、代码实现

//创建精灵,设置起始点p0
	CCSprite* sprFlower = CCSprite::create("a1.png");
	sprFlower->setPosition(Point(280,175));//320-145=175
	this->addChild(sprFlower,1,FLOWERTAG);

//配置贝塞尔曲线的p1、p2、p3,因为用BezierBy需要减去p0的坐标,换算成相对位置
//注BezierBy才有reverse(),BezierTo没有。
//其他动作(如Moveto\MoveBy)同样也是By有reverse()而To没有。
	ccBezierConfig bezier;
	bezier.controlPoint_1 = Point(191 - 280,318-175); //320-2=318
	bezier.controlPoint_2 = Point(11 - 280,131-175);//320-189=131
	bezier.endPosition = Point(271 - 280,13-175);//320-307=13
	Action* bezierby = BezierBy::create(4.0f,bezier);

//执行动作
	sprFlower->runAction(bezierby);

//安装定时器,每0.1秒执行一次回调函数
	this->schedule(schedule_selector(HelloWorld::flowerUpdate),0.1f);

void HelloWorld::flowerUpdate(float dt)
{
//产生1-19的随机数
//获得执行贝塞尔曲线的精灵对象
	int i = 1;
	i = CCRANDOM_0_1() * 18 + 1;
	auto sprFlower = this->getChildByTag(FLOWERTAG);

//随机参数不同花瓣的精灵
	CCSprite* sprFlowerTmp = CCSprite::create("a"+Value(i).asstring()+".png");

//将随机参数的花瓣精灵坐标设置为执行贝塞尔曲线精灵的当前坐标
	sprFlowerTmp->setPosition(sprFlower->getPosition());
	this->addChild(sprFlowerTmp);

//执行到贝塞尔曲线终点时取消定时器
	if ( sprFlower->getPositionX() == 271 && sprFlower->getPositionY() == 13)
	{
		this->unschedule(schedule_selector(HelloWorld::flowerUpdate));
	}
}


工具和源代码下载地址:http://download.csdn.net/detail/qiulanzhu/8953021

Cocos2D游戏之旅一:贝塞尔曲线画心形---花瓣桃心的更多相关文章

  1. 基于canvas使用贝塞尔曲线平滑拟合折线段的方法

    这篇文章主要介绍了基于canvas使用贝塞尔曲线平滑拟合折线段的方法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. 使用SVG实现提示框功能的示例代码

    这篇文章主要介绍了使用SVG实现提示框功能的示例代码,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. canvas进阶之贝塞尔公式推导与物体跟随复杂曲线的轨迹运动

    这篇文章主要介绍了canvas进阶之贝塞尔公式推导与物体跟随复杂曲线的轨迹运动,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  4. canvas仿写贝塞尔曲线的示例代码

    这篇文章主要介绍了canvas仿写贝塞尔曲线的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  5. ios – 如何使用渐变颜色填充贝塞尔曲线路径

    我的自定义UIView绘图(_rect:CGRect)函数中有一个UIBezierPath.我想用渐变色填充路径.请任何人都可以指导我如何做到这一点.我需要用渐变颜色填充剪辑,然后用黑色描边路径.SO中有一些帖子无法解决问题.例如Swift:Gradientalongabezierpath(usingCALayers)这篇文章指导如何在UIView中绘制图层,而不是在UIBezierPath中绘制

  6. (Swift+iOS)字符串轨迹转贝塞尔曲线,实现动态写字效果

    前两天下载了一个Swift的HUD提示效果,偶然发现其中的提示效果上面的文字是动态书写的。

  7. 早期Swift中Cocos2D初始化代码的重构

    但是遗憾的是Swift2.2中还是不支持Type的class属性关键字,只能用static,我们期待Swift3的改进吧!

  8. 手把手教你swift项目添加cocos2dx-lua

    去倒杯水吧,这个过程会很久。。。至此,工程已经全部配置完毕,你已经解决一个大Boss了;今天就到这里吧,之后我们再续如何用swift调用lua手把手教你swift项目添加cocos2dx-lua

  9. 手把手教你swift项目集成cocos2dx-js模块

    前几天在swift项目中集成了Lua模块,使得在swift工程中用Lua写游戏逻辑成为了可能,具体工程及配置见手把手教你swift项目添加cocos2dx-lua,由于公司最近要把js做的小游戏集成到iOS原生应用中,于是我们将解锁另外一个场景,好了,下面开始;同样的,首先你得有一个swift项目我们从头开始,建立一个swift项目;我们默认你已经可以自己创建一个全新的swift项目了,这很简单,不是么?

  10. android – 尝试在Cocos2d-X C中设置一个带整数的CCLabelTTF作为它的字符串的一部分

    所以在使用Cocos2d的Objective-C中,我使用带有格式的NSMutableString将变量(得分)放入字符串中.我拿这个字符串并使用cclabel将它放在屏幕上.使用Cocos2D-x,我很难找到获得此结果的方法.一个简单的例子就是很棒.谢谢!

随机推荐

  1. 【cocos2d-x 3.x 学习笔记】对象内存管理

    Cocos2d-x的内存管理cocos2d-x中使用的是上面的引用计数来管理内存,但是又增加了一些自己的特色。cocos2d-x中通过Ref类来实现引用计数,所有需要实现内存自动回收的类都应该继承自Ref类。下面是Ref类的定义:在cocos2d-x中创建对象通常有两种方式:这两中方式的差异可以参见我另一篇博文“对象创建方式讨论”。在cocos2d-x中提倡使用第二种方式,为了避免误用第一种方式,一般将构造函数设为protected或private。参考资料:[1]cocos2d-x高级开发教程2.3节[

  2. 利用cocos2dx 3.2开发消灭星星六如何在cocos2dx中显示中文

    由于编码的不同,在cocos2dx中的Label控件中如果放入中文字,往往会出现乱码。为了方便使用,我把这个从文档中获取中文字的方法放在一个头文件里面Chinese.h这里的tex_vec是cocos2dx提供的一个保存文档内容的一个容器。这里给出ChineseWords,xml的格式再看看ChineseWord的实现Chinese.cpp就这样,以后在需要用到中文字的地方,就先include这个头文件然后调用ChineseWord函数,获取一串中文字符串。

  3. 利用cocos2dx 3.2开发消灭星星七关于星星的算法

    在前面,我们已经在GameLayer中利用随机数初始化了一个StarMatrix,如果还不知道怎么创建星星矩阵请回去看看而且我们也讲了整个游戏的触摸事件的派发了。

  4. cocos2dx3.x 新手打包APK注意事项!

    这个在编译的时候就可以发现了比较好弄这只是我遇到的,其他的以后遇到再补充吧。。。以前被这两个问题坑了好久

  5. 利用cocos2dx 3.2开发消灭星星八游戏的结束判断与数据控制

    如果你看完之前的,那么你基本已经拥有一个消灭星星游戏的雏形。开始把剩下的两两互不相连的星星消去。那么如何判断是GameOver还是进入下一关呢。。其实游戏数据贯穿整个游戏,包括星星消除的时候要加到获得分数上,消去剩下两两不相连的星星的时候的加分政策等,因此如果前面没有做这一块的,最好回去搞一搞。

  6. 利用cocos2dx 3.2开发消灭星星九为游戏添加一些特效

    needClear是一个flag,当游戏判断不能再继续后,这个flag变为true,开始消除剩下的星星clearSumTime是一个累加器ONE_CLEAR_TIME就是每颗星星消除的时间2.连击加分信息一般消除一次星星都会有连击信息和加多少分的信息。其实这些combo标签就是一张图片,也是通过控制其属性或者runAction来实现。源码ComboEffect.hComboEffect.cpp4.消除星星粒子效果消除星星时,为了实现星星爆裂散落的效果,使用了cocos2d提供的粒子特效引擎对于粒子特效不了

  7. 02 Cocos2D-x引擎win7环境搭建及创建项目

    官网有搭建的文章,直接转载记录。环境搭建:本文介绍如何搭建Cocos2d-x3.2版本的开发环境。项目创建:一、通过命令创建项目前面搭建好环境后,怎样创建自己的Cocos2d-x项目呢?先来看看Cocos2d-x3.2的目录吧这就是Cocos2d-x3.2的目录。输入cocosnew项目名–p包名–lcpp–d路径回车就创建成功了例如:成功后,找到这个项目打开proj.win32目录下的Hello.slnF5成功了。

  8. 利用cocos2dx 3.2开发消灭星星十为游戏添加音效项目源码分享

    一个游戏,声音也是非常的重要,其实cocos2dx里面的简单音效引擎的使用是非常简单的。我这里只不过是用一个类对所有的音效进行管理罢了。Audio.hAudio.cpp好了,本系列教程到此结束,第一次写教程如有不对请见谅或指教,谢谢大家。最后附上整个项目的源代码点击打开链接

  9. 03 Helloworld

    程序都有一个入口点,在C++就是main函数了,打开main.cpp,代码如下:123456789101112131415161718#include"main.h"#include"AppDelegate.h"#include"cocos2d.h"USING_NS_CC;intAPIENTRY_tWinMain{UNREFERENCED_ParaMETER;UNREFERENCED_ParaMETER;//createtheapplicationinstanceAppDelegateapp;return

  10. MenuItemImage*图标菜单创建注意事项

    学习cocos2dx,看的是cocos2d-x3.x手游开发实例详解,这本书错误一大把,本着探索求知勇于发现错误改正错误的精神,我跟着书上的例子一起调试,当学习到场景切换这个小节的时候,出了个错误,卡了我好几个小时。

返回
顶部