文档章节

渲染--笔记(2)

 悠米海
发布于 2014/06/12 22:25
字数 968
阅读 9
收藏 0

CCLayer函数定义:

游戏需要很多图层来实现功能,比如菜单层(CCMenu)、颜色显示层(CCColorLayer)

颜色层用于烘托背景,开发者可以填充RGB颜色,设置图层的透明度,移动、闪烁或者渐变。类继承自CCLayerCCRGBAProtocol(颜色控制)CCBlendProtocol(混合控制)定义如下:

CCColorLayer有一个子类CCLayerGradient:颜色渐变效果的颜色图层,参数是2个颜色,初始色(透明度)和最终色(透明度)

CCMenu菜单图层:

存放CCMenuItem及其子类。

CCLayer还有其它子类:UILayerCCControlCCScrollViewCCBProxy

精灵类(CCSprite)

继承关系:

classCC_DLLCCSprite : publicCCNodeRGBApublicCCTextureProtocol

classCC_DLLCCNodeRGBA : publicCCNodepublicCCRGBAProtocol

classCC_DLLCCTextureProtocol : publicCCBlendProtocol

继承CCNode和两个处理精灵纹理图片的类(颜色管理和纹理图片管理),类自有属性如下:

创建方法如下:

创建纹理对象方法:

CCTextureCache::sharedTextureCache()->addImage(path)

创建精灵帧方法:

集合:CCSpriteBatchNode::create(path,num)

缓冲:CCSpriteFrameCache::sharedSpriteFrameCache()->addSpriteFramesWithFile(path)

精灵对象:CCSprite::createWithSpriteFrameName(path)

集合和缓冲是提升游戏性能准备的。

 

精灵集合类(CCSpriteBatchNode)

子类:CCLabelBMFont(字体类)CCTMXLayer(地图背景类)

对应的纹理图片很丰富,一张图片包含多种文字和许多图块和图片

 

OpenGLES渲染器的运行原理:把必要的信息传递给图形处理硬件,然后将整个或部分图片渲染。使用精灵集合类,一个集合中的精灵都使用同一张渲染贴图,在绘制的时候就不需要频繁传递贴图信息给图形硬件,提升效率。一个精灵集合绘制的对象出于同一个画面层次,纹理大小存在限制(IOS:1024*1024),并且必须是2N次方大小。

精灵集合创建方法:

 

精灵帧缓冲(CCSpriteFrameCache)

存放精灵帧(CCSpriteFrame)对象的缓冲池,CCSpriteFrame直接继承自CCObject,不是CCNode的子类,不能绘制于加入节点链表,作用在于持有一个纹理对象,为精灵对象提供动画支持。

精灵帧的属性:

创建函数:

支持使用纹理创建精灵帧,与创建精灵类似。通过使用精灵帧可以方便的创建精灵对象不用考虑内存,所以精灵帧缓冲包含了游戏所用的精灵帧,纹理来自组合的纹理图片或者是多个单独的纹理图片。精灵帧缓冲支持加载多个精灵帧对象,使用plist描述文件,加载方法如下:

plist文件+问题图片or纹理对象

可以使用Zwoptex纹理编辑器制作纹理

一个实例:

2、文字与字体:

Cocoss2dx3个文字处理类:CCLabelAtlasCCLabelBMFontCCLabelTTF(TTF字体)都继承了CCLabelProtocol协议。如下:

都继承自CCNodeCCLabelTTF继承关系:

继承CCSprite,因此CCTextFieldTTFCCLabelTTF可以当做精灵对象使用。

CCLabelTTF的创建函数:

参数说明:文字内容,字体名称,字体尺寸,标签尺寸,文字水平对齐方式,文字竖直对齐方式

实例可以参考:samples\Cpp\TestCpp\Classes\FontTest\FontTest.cpp showFont函数

 

BMFont标签类(CCLabelBMFont)

继承关系:

继承自CCSpriteBatchNode(精灵集合),使用自定义文字,开发者可以自定义字体,

使用BMFont(http://www.angelcode.com/products/bmfont/)编辑器编辑字体图集。

实例:samples\Cpp\TestCpp\Classes\LabelTest\LabelTest.cpp Atlas3

方法为:CCLabelBMFont::create(文字内容,字体路径)

 

Atlas标签类(CCLabelAtlas)

继承关系:

继承自CCNode,与TTF不同的是不生成纹理图片,直接使用源纹理图片,因此开发人员可以自定义字体和显示内容。

创建函数:

参数:文字内容,纹理path,宽度,高度,起始位置

 

3、菜单按钮:

容器CCMenu,节点CCMenuItem,继承关系:

实例:samples\Cpp\TestCpp\Classes\MenuTest\MenuTest.cpp MenuLayerMainMenu对象

 

4、几何绘制(DRawPrimitives)

CCDrawingPrimitives.h/cpp提供的绘制函数:

© 著作权归作者所有

共有 人打赏支持
上一篇: 动作
下一篇: 渲染--笔记(1)
粉丝 12
博文 94
码字总数 37254
作品 0
浦东
程序员
私信 提问
Unity Shader入门精要学习笔记 - 第3章 Unity Shader 基础

Unity Shader入门精要学习笔记 - 第3章 Unity Shader 基础 本系列为UnityShader入门精要读书笔记总结, 原作者博客链接:http://blog.csdn.net/candycat1992/article/ 书籍链接:http://prod...

wwlcsdn000
2017/12/26
0
0
啦啦啦哈利路亚/laravel_biji

采用Laravel5.1框架的在线笔记系统 演示地址 http://120.27.102.104/auth/login 项目介绍 基于Laravel+Bootstrap+MariaDB开发系统架构 功能说明 在线笔记系统基于B/S结构的社区性质的协调信息...

啦啦啦哈利路亚
2017/03/08
0
0
react-native 入门之 helloworld

简介 在网上找了一篇很不错的例子,推荐给大家边学边做 helloworld 首先,我们先创建一个项目,它的原始代码如下,可以看出来主要分为样式和功能两部分,没什么值得留意的 显示效果是这样的 ...

邪人君子
01/20
0
0
VNote 2.1, 更好的解析粘贴

1. 解析并粘贴,VNote现在能做得更多 1.1. 自动下载网络图片并替换 1.2. 从容应对知乎公式 1.3. 支持更多的表格 2. 缩放插入图片 3. 其他 拖拽文件到编辑区域,可以直接将该文件添加为附件,...

tamlok
10/30
0
0
OpenGL学习笔记 2 让正方形动起来

在笔记1里面我记录下来渲染一个最基本的小三角形需要哪些准备工作以及程序的主要框架,这一节我继续跟上蓝宝书的脚步,试着理解二维动画怎么做出来的。这个笔记主要记录了 消息相应应该用什么...

yuquan87
05/28
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Go 使用channel控制并发

前言 channel一般用于协程之间的通信,channel也可以用于并发控制。比如主协程启动N个子协程,主协程等待所有子协程退出后再继续后续流程,这种场景下channel也可轻易实现。 场景示例 总结 ...

恋恋美食
22分钟前
1
0
Apache Flink 漫谈系列 - 持续查询(Continuous Queries)

摘要: 实际问题 我们知道在流计算场景中,数据是源源不断的流入的,数据流永远不会结束,那么计算就永远不会结束,如果计算永远不会结束的话,那么计算结果何时输出呢?本篇将介绍Apache Fl...

阿里云官方博客
26分钟前
3
0
斐波那契堆的理解,节点mark属性和势函数

斐波那契堆 看了好多博客,都是照搬算法导论的内容,没有自己的理解,比如为什么有mark属性,势函数的作用,以及为什么叫斐波那契堆,下面说说鄙人的理解。 势函数 势函数是根节点个数加上2...

杨喆
27分钟前
2
0
NIO源码详解

阻塞io和无阻塞io: 阻塞io是指jdk1.4之前版本面向流的io,服务端需要对每个请求建立一堆线程等待请求,而客户端发送请求后,先咨询服务端是否有线程相应,如果没有则会一直等待或者遭到拒 ...

沉稳2018
32分钟前
0
0
如何把已经提交的commit, 从一个分支放到另一个分支

在本地master提交了一个commit(8d85d4bca680a5dbcc3e5cfb3096d18cd510cc9f),如何提交的test_2分之上? git checkout test_2git cherry-pick 8d85d4bca680a5dbcc3e5cfb3096d18cd510cc9f......

stephen_wu
35分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部