Cocos2d vision:  cocos2d-x-3.8.1

万丈高楼,起于累土。对于一个游戏框架的学习,其实在于框架功能的使用积累,学会了如何在cocos2d游戏引擎的基础上使用它提供的各种功能,并灵活运用,

以及学会查阅Cocos2d官方提供的API文档。相信自己也能开发出自己喜爱或者让别人羡慕的游戏。

目录:

1>认识origin和visibleSize以及cocos2d的基础绘画类DrawNode的简单实用

2>认识 CCLOG()

3>有关schedule的使用

4>有关ContentSize和Anchor

5>有关本地坐标转换为世界坐标

===================================================================================================

1、认识origin和visibleSize以及cocos2d的基础绘画类DraNode的简单实用
origin可视区域的出发点坐标,visibleSize可视区域的尺寸

     Size visibleSize = Director::getInstance()->getVisibleSize();
Vec2 origin = Director::getInstance()->getVisibleOrigin();

所以如果要获取屏幕可视区域的位置以及相对宽高,就可以在这两个属性的基础上设置。

实例代码:

      //1、DrawNode对象是cocos2d中比较基础的对象,可以用来绘制一些图形
auto rect = DrawNode::create();
//rect->drawRect(const cocos2d::Vec2 &origin, const cocos2d::Vec2 &destination, const cocos2d::Color4F &color)
//第一个参数是绘制的起点,第二个参数是绘制的距离。第三个参数是颜色,4F表示的是RGBA四个颜色值,另外用F浮点数设置,每个浮点数范围在(0,1)之间
rect -> drawRect(Vec2(,), Vec2(, ), Color4F(1.0, , , 1.0));
addChild(rect); rect -> setPosition(origin.x + visibleSize.width/-,
origin.y + visibleSize.height/-);//设置矩形在可视区域的中间
// rect -> setPosition(origin.x,origin.y);//设置起点位置在可视区域的起点坐标

效果:

 2、认识CCLOG的打印输出。

 CCLOG("X:%f,Y:%f\n",origin.x,origin.y);

类似C语言里的scanf("%d",number)语句。不过CCLOG不用添加换行符号"\n",CCLOG打印字符串之后,会自动打印换行。

 
3、有关schedule的使用
     auto rect = DrawNode::create();
rect -> drawRect(Vec2(,), Vec2(, ), Color4F(1.0, , , 1.0));
addChild(rect);
rect -> setPosition(origin.x + visibleSize.width/,
origin.y + visibleSize.height/);//设置矩形在可视区域的中间
auto dot = DrawNode::create();
dot -> drawDot(Vec2(,), , Color4F(1.0, 1.0, 1.0, 1.0));
addChild(dot);
dot -> setPosition(origin.x + visibleSize.width/ ,origin.y + visibleSize.height/ ); //我们需要让矩形不断的旋转,实用
//schedule(<#const std::function<void (float)> &callback#>, <#const std::string &key#>)
//第一个参数是函数(这里实用...表达式快速定义这个函数,并给float参数,[]是捕获列表,我们捕获dot和rect两个对象),
//第二个参数是时间表中被调用这个操作的名称,我们可以通过这个名称来取消持续的调用。
schedule([dot,rect](float f){
rect -> setRotation(rect->getRotation()+);//选装这个矩形
}, "Test");

效果图:

 
 4、有关ContentSize和Anchor
网上说 ContentSize是逻辑尺寸的意思。

     auto rect = DrawNode::create();
rect -> drawRect(Vec2(,), Vec2(, ), Color4F(1.0, , , 1.0));
addChild(rect);
rect -> setPosition(origin.x + visibleSize.width/,
origin.y + visibleSize.height/);
auto dot = DrawNode::create();
dot -> drawDot(Vec2(,), , Color4F(1.0, 1.0, 1.0, 1.0));
addChild(dot);
dot -> setPosition(origin.x + visibleSize.width/ ,origin.y + visibleSize.height/ ); //现在要把这个rect放置在屏幕的中间
rect -> setContentSize(Size(,));
rect -> setAnchorPoint(Vec2(0.5, 0.5));//这个设置锚点,参数是个比例值, schedule([dot,rect](float f){
rect -> setRotation(rect->getRotation()+);
}, "Test");
return true;

效果图:

 
 5、有关本地坐标转换为世界坐标。
     auto rect = DrawNode::create();
rect -> drawRect(Vec2(,), Vec2(, ), Color4F(1.0, , , 1.0));
addChild(rect);
rect -> setPosition(origin.x + visibleSize.width/,
origin.y + visibleSize.height/);
auto dot = DrawNode::create();
dot -> drawDot(Vec2(,), , Color4F(1.0, 1.0, 1.0, 1.0));
rect->addChild(dot);//这里相对前面的代码实例,原本是场景add(dot),现在改为rect->add(dot)
dot -> setPosition(Vec2(, ));//本地空间 //现在要把这个rect放置在屏幕的中间
rect -> setContentSize(Size(,));
rect -> setAnchorPoint(Vec2(0.5, 0.5));//这个设置锚点,参数是个比例值, schedule([dot,rect](float f){
rect -> setRotation(rect->getRotation()+);
auto p = dot->convertToNodeSpace(Vec2(, ));//本地坐标转换为世界坐标
CCLOG("%f,%f",p.x,p.y);
}, "Test");
return true;

效果:

 
 
 
 

Cocos2d入门--1--初涉相关属性或代码的更多相关文章

  1. 编写高质量代码改善C#程序的157个建议——建议147:重构多个相关属性为一个类

    建议147:重构多个相关属性为一个类 若存在多个相关属性,就应该考虑是否将其重构为一个类.查看如下类: class Person { public string Address { get; set; ...

  2. PyQt(Python+Qt)入门:Designer组件属性编辑界面中QWidget类相关属性详解

    本文适用人员:本文比较长,适合不理解Qt Designer部件属性的人员阅读或资料查找. 声明: 1.如果有人认为本文是简单的复制粘贴+翻译而成,敬请读本文最后的后记: 2.本文为老猿Python学习 ...

  3. 【Cocos2d入门教程二】Cocos2d-x基础篇

    上一章已经学习了环境的搭建.这一章对基础概念进行掌握.内容大概有: 1.导演 2.场景 3.节点 4.层 4.精灵 1.导演(Director) 导演存在的主要作用: a.环境设定(帧率 初始化ope ...

  4. HTML入门基础教程相关知识

    HTML入门基础教程 html是什么,什么是html通俗解答: html是hypertext markup language的缩写,即超文本标记语言.html是用于创建可从一个平台移植到另一平台的超文 ...

  5. Activity Intent Flags及Task相关属性

    转自http://www.cnblogs.com/lwbqqyumidi/p/3775479.html 今天我们来讲一下Activity的task相关内容. 上次我们讲到Activity的四种启动模式 ...

  6. Android总结篇系列:Activity Intent Flags及Task相关属性

    同上文一样,本文主要引用自网上现有博文,并加上一些自己的理解,在此感谢原作者. 原文地址: http://blog.csdn.net/liuhe688/article/details/6761337 ...

  7. IOS开发UI基础UITextFidle相关属性

    UITextFidle相关属性 •    enablesReturnKeyAutomatically默认为No,如果设置为Yes,文本框中没有输入任何字符的话,右下角的返回按钮是disabled的. ...

  8. UILabel的相关属性设置

    在iOS编程中UILabel是一个常用的控件,下面分享一下UILabel的相关属性设置的方法. 很多学习iOS6编程都是从storyboard开始,用到UILabel时是将控件拖到storyboard ...

  9. css margin的相关属性,问题及应用

    by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=48 引言:margin ...

随机推荐

  1. Ladda – 把加载提示效果集成到按钮中,提升用户体验

    Ladda 是一组集成了加载提示的按钮,以弥合行动和反馈之间的时间间隔,提供更好的功能使用体验.主要用于在用户点击提交之后,向用户提供即时的反馈,让他们知道浏览器正在处用户提交的任务. 您可能感兴趣的 ...

  2. 二、中间件(middleware)

    1.      中间件(middleware) Django中的中间件主要实现一些附加功能,在request被用户handler处理前,以及用户handler处理后生存的response进行处理.因此 ...

  3. 安装DRBD的一些问题

    安装DRBD,建议用源代码包先生成rpm包来安装,不要用直接download的rpm包,有可能会用不了,因为这跟系统内核版本有关系,在2.6.33版本以前内核没有集成drbd,   A.先安装一些其它 ...

  4. 0316-复利计算器3.0---release

    目录       一.项目简介       二.Github链接推送       三.客户需求       四.需求分析       五.项目设计       六.完成效果       七.JUnit ...

  5. java:[1,1] 需要class, interface或enum

    状态: cmd编译.java文件时报异常:java:[1,1] 需要class, interface或enum异常原因: 主要原因是java文件的编码问题. 在中文操作系统中,使用一贯的"j ...

  6. JS 将一段文本 每个英文首字母大写

    function replaceStr(str){ // 正则法 str = str.toLowerCase(); var reg = /\b(\w)|\s(\w)/g; // \b判断边界\s判断空 ...

  7. .net接口学习笔记

    1.接口的声明 接口的声明不能包含:数据成员,静态变量:只能包含如下类型的静态成员函数的声明:方法,属性,事件,索引器.声明中不能包含任何实现的代码,而在每个成员成名的主体后,必须使用分号. 接口声明 ...

  8. 如何弹出一定的大小的web窗体?

    如何弹出一定的大小的web窗体?  摘自: http://blog.163.com/hweibin126@126/blog/static/17044246920108413348344/ 一.wind ...

  9. vim 正则替换

    http://www.cppblog.com/kefeng/archive/2010/10/20/130574.html Vim中的正则表达式功能很强大,如果能自由运用,则可以完成很多难以想象的操作. ...

  10. java设计模式--工厂模式

       所谓工厂,就是要造产品,比如一个小型砖瓦厂,只有一个窑,既能造砖又能造瓦,这种叫简单工厂模式.规模稍大一点呢,我多个窑,有的窑专门造砖,有的窑专门造瓦,想造别的,比如瓷砖,我再用个专门的窑,这种 ...