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. 充实你的素材库!10款免费的 PSD 素材下载

    由于网页设计师没有时间来自己从零开始设计,所以在设计项目中使用网络上已有的设计素材是常见的方式.这就是为什么我们经常会到网上搜索可以免费下载的素材. 今天,我们这里有几套不同的免费的 PSD 素材分享 ...

  2. .Net魔法堂:发个带附件的邮件

    一.前言   由于工作需要最近把邮件发送封装成WebService,现在把代码记录在此,以便日后查阅. 二.二话不说写代码 private void _SendMail(string form, st ...

  3. JavaScript--DOM修改元素的属性

    一旦你获得了要修改的元素,可以有2种方式,来读取和修改它的属性:一种老的方式(它被更多的用户代理所支持)和一种新的DOM方法的方式.老的和新的用户代理都允许你以对象属性的方式获取和设置元素的属性. 先 ...

  4. thread_Disruptor

    转自 知乎 https://zhuanlan.zhihu.com/p/21355046 order从client端传入,decode后进行matching,一旦存在可成交的价格,就要publish到t ...

  5. 双系统Ubuntu无法访问windows磁盘分区解决方法

    为了更好的体验各种操作系统,在电脑中安装双系统是很好的选择,但在使用中难免会遇到这样或那样的问题. 最近总是遇到Ubuntu系统下无法访问windows磁盘分区问题,看了系统日志发现是挂载磁盘出问题了 ...

  6. ECMall如何支持SSL连接邮件服务器的配置

    首先,主要是ecmall使用的phpmailer版本太低,不支持加密连接. 然后,得对相应代码做一定调整. 1. 覆盖phpmailer 请从附件进行下载: http://files.cnblogs. ...

  7. js 倒计时 跳转

    1. setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式. setTimeout() 只执行 code 一次.如果要多次调用,请使用 setInterval() 或者让 code ...

  8. [小北De编程手记] : Lesson 06 - Selenium For C# 之 流程控制

    无论你是用哪一种自动化测试的驱动框架,当我们构建一个复杂应用程序的自动化测试的时候.都希望构建一个测试流程稳定,维护成本较低的自动化测试.但是,现实往往没有理想丰满.而这一篇,我会为大家讲解我们在使用 ...

  9. tomcat filewatchdog but has failed to stop it原因以及解决方法

    停止tomcat,有些时候会报The web application [/XXX] appears to have started a thread named [FileWatchdog] but ...

  10. 【GOF23设计模式】状态模式

    来源:http://www.bjsxt.com/ 一.[GOF23设计模式]_状态模式.UML状态图.酒店系统房间状态.线程对象状态切换 package com.test.state; public ...