【玩转cocos2d-x之十六】滚动字幕和公告
来源:互联网 发布:左程云算法视频百度云 编辑:程序博客网 时间:2024/04/30 08:15
滚动字幕和公告是游戏中经常使用到的元素,本文大致写一下实现方法,至于例子中具体的坐标值,请不要纠结。。。这和美工关系还是蛮大的。我PS技术太搓了。。。
1.原理
其实它们的实现都是简单的通过调用update来更新位置达到的移动效果,和背景滚动有点类似,一旦滚动结束就重置为起点,开始新的滚动。只是为了达到在某个区域内滚动而不至于超出这个区域,有时候会用一些前景图来做遮盖,所以这个时候其实字幕或者公告是有在后面滚动的,但是被遮住了,因此看起来就像是只在某个区域内滚动。以垂直字幕滚动为例说明,如下图。
2.实现
不要纠结以下各精灵的坐标位置:)
- bool CTestLayer::init()
- {
- bool bRet=false;
- do
- {
- CC_BREAK_IF(!CCLayer::init());
- CCSize visibleSize=CCDirector::sharedDirector()->getVisibleSize();
- CCSpriteFrameCache::sharedSpriteFrameCache()->addSpriteFramesWithFile("ui_serverlist.plist");
- //垂直滚动字幕
- CCSprite* listbase=CCSprite::createWithSpriteFrame(CCSpriteFrameCache::sharedSpriteFrameCache()->spriteFrameByName("login_listbase.png"));//bottom底图
- listbase->setPosition(ccp(visibleSize.width/2,visibleSize.height/2+10));
- this->addChild(listbase);
- text1=CCLabelTTF::create("1.Hi! Welcome to JackyStudio,\nMy Blog is\nblog.csdn.net/jackystudio!\n2.Hi! Welcome to JackyStudio,\nMy Blog is\nblog.csdn.net/jackystudio!\n3.Hi! Welcome to JackyStudio,\nMy Blog is\nblog.csdn.net/jackystudio!\n4.Hi! Welcome to JackyStudio,\nMy Blog is\nblog.csdn.net/jackystudio!","Arial",12);//middle文本
- text1->setHorizontalAlignment(kCCTextAlignmentLeft);//左对齐
- text1->setAnchorPoint(ccp(0.5,1));
- text1->setPosition(ccp(visibleSize.width/2,visibleSize.height/2-55));
- this->addChild(text1);
- CCSprite* fg=CCSprite::create("fg.png");//top前景
- fg->setPosition(ccp(visibleSize.width/2,visibleSize.height/2));
- this->addChild(fg);
- //水平滚动公告
- CCSprite* textbase=CCSprite::createWithSpriteFrame(CCSpriteFrameCache::sharedSpriteFrameCache()->spriteFrameByName("login_textbase.png"));
- textbase->setPosition(ccp(visibleSize.width/2,50));
- textbase->setScaleX(2.5f);
- this->addChild(textbase);
- text2=CCLabelTTF::create("Hi! Welcome to JackyStudio,My Blog is blog.csdn.net/jackystudio!","Arial",12);
- text2->setPosition(ccp(visibleSize.width+text2->getContentSize().width/2,50));
- text2->setColor(ccc3(255,0,0));//红色字体
- this->addChild(text2);
- this->scheduleUpdate();//执行更新
- bRet=true;
- } while (0);
- return bRet;
- }
- void CTestLayer::update(float delta)
- {
- CCSize visibleSize=CCDirector::sharedDirector()->getVisibleSize();
- int newY=text1->getPositionY()+1;
- if (newY==500)//如果滚动到这个位置,重置
- {
- newY=visibleSize.height/2-55;
- }
- text1->setPositionY(newY);
- int newX=text2->getPositionX()-1;
- if (newX<=-text2->getContentSize().width/2)//如果滚动到这个位置,重置
- {
- newX=visibleSize.width+text2->getContentSize().width/2;
- }
- text2->setPositionX(newX);
- }
3.效果
这个效果有点小bug,就是文字覆盖到边框上了,这是因为没有把边框做在top层上导致的,实际使用注意这个问题即可。
4.源码下载
http://download.csdn.net/detail/jackyvincefu/6434549
转载自 http://blog.csdn.net/jackystudio/article/details/12991977
- 【玩转cocos2d-x之十六】滚动字幕和公告
- 【玩转cocos2d-x之十六】滚动字幕和公告
- 玩转cocos2d-x之十六】滚动字幕和公告
- 【玩转cocos2d-x之十六】滚动字幕和公告
- cocos2d-x之CCClippingNode实现滚动字幕
- 【玩转cocos2d-x之二十六】数据结构CCDictionary
- 【玩转cocos2d-x之二十六】数据结构CCDictionary
- 【玩转cocos2d-x之二十六】数据结构CCDictionary
- 【cocos2d-x笔记】滚动字幕
- 公告字幕滚动开发
- cocos2d-x利用CCClippingNode实现滚动字幕
- 【玩转cocos2d-x之二】游戏和引擎构成
- 【玩转cocos2d-x之三十四】绘图:CCDrawingPrimitives和CCDrawNode
- 【玩转cocos2d-x之二】游戏和引擎构成
- 【玩转cocos2d-x之三十四】绘图:CCDrawingPrimitives和CCDrawNode
- Cocos2d-x显示中文与字幕滚动--之游戏开发《赵云要格斗》(14)
- 【玩转cocos2d-x之二十八】cocos2d-x的消息和数据传递
- [置顶]【玩转cocos2d-x之二十八】cocos2d-x的消息和数据传递
- Velocity语法
- 浏览器的标准模式和怪异模式
- Oracle 修改SGA后启动不了 且没有备份 ORA-27102: out of memory
- android二级listview列表
- [Python] modify *.c -> *.java script
- 【玩转cocos2d-x之十六】滚动字幕和公告
- java基础
- 移植apache2 ARM版 - 交叉编译pcre-8.33
- Hibernate中Criteria的完整用法
- Ubuntu下常用文本编辑器
- 报表不能运行的解决办法(空白,rsProcessingAborted)
- EXT.NET的代码触发事件,函数
- iOS 瀑布流布局 加载网络图片
- eclipse快捷键