先上图


游戏中常常见到一个富文本的列表,不停地显示游戏相应的消息.每添加一个消息,则向列表底部添加一个项.当消息项超过列表可见区域底部时列表会自动向上移动使最新消息项永远保持在可见区域内.

下面是实现:

var GameMsgList = cc.Node.extend({

ctor : function(view_size) {
this._super();
this.init(view_size);
},
init : function(view_size) {
this._itemData = []; //项数据
this._itemmax = 30; //项上限
this.m_sFonts = "res/fonts/tengxiangyuan.ttf";
this.m_nFontSize = 20;
this.m_pColorDefault = cc.color(255,255,255); //默认颜色
this.m_pColorConfig = {}; //颜色配置,可以外部添加
this.m_pColorConfig.red = cc.color(255,0);
this.m_pColorConfig.green = cc.color(0,0);
this.m_pColorConfig.blue = cc.color(0,255);
this.m_pColorConfig.white = cc.color(255,255);
this.m_pColorConfig.black = cc.color(0,0);
//this.m_pRegExp = new RegExp("<[a-z]+>[\s|\S]+</[a-z]+>");
this.m_pTVSize = view_size;
this.setContentSize(this.m_pTVSize);


this.m_pTView = new ccui.ListView();
this.m_pTView.setDirection(ccui.ScrollView.DIR_VERTICAL);
this.m_pTView.setTouchEnabled(true);
this.m_pTView.setBounceEnabled(true);
this.m_pTView.setItemsMargin(5);
//this.m_pTView.setBackGroundColorType(ccui.Layout.BG_COLOR_SOLID);
//this.m_pTView.setBackGroundColor(cc.color(128,128,128));
//this.m_pTView.setBackGroundColorOpacity(128);
this.m_pTView.setContentSize(this.m_pTVSize);
//this.m_pTView.setScrollBarEnabled(true); //h5 undefined
//this.m_pTView.setScrollBarOpacity(204); //h5 undefined
//this.m_pTView.setScrollBarautoHideEnabled(false); //h5 undefined
//this.m_pTView.setScrollBarWidth(4); //h5 undefined
//this.m_pTView.setScrollBarColor(cc.color(164,160,122)); //h5 undefined
//this.m_pTView.setScrollBarPositionFromCornerForVertical(cc.p(4,4)); //h5 undefined
this.addChild(this.m_pTView);
},
setColorDefault : function (color) {
this.m_pColorDefault = color;
},
setColor : function (key,color) {
this.m_pColorConfig[key] = color;
},
getColor : function (key) {
var color = this.m_pColorConfig[key];
if (!color) {
return this.m_pColorDefault;
}
return color;
},
setFonts : function (file,size) {
this.m_sFonts = file;
this.m_nFontSize = size;
},
reloadData: function(dataSet) {
var _sourceData = !dataSet ? [] : dataSet;
this._itemData = [];
for(var i = 0,len = _sourceData.length; i < this._itemmax && i < len; ++i) {
var temp = _sourceData[len - i - 1];
this._itemData.push(temp);
}
this._itemData.reverse();
this.reloadItems();
},
reloadItems : function () {
this.m_pTView.removeAllItems();
for(var i = 0,s = this._itemData.length; i < s; ++i) {
this.addItem(this._itemData[i],false);
}
this.m_pTView.jumpToBottom();
},
addItem : function (data,tag) {
var richText = new ccui.RichText();
richText.ignoreContentAdaptWithSize(false);
richText.setContentSize(this.m_pTVSize.width,0);
//richText.setAnchorPoint(cc.p(0,0)); //H5版本默认为(0.5,0)
//parse text
var txt_arr = this.parseText(data.toString());
var txt_arr_len = txt_arr.length;
for(var i = 0; i < txt_arr_len; ++i) {
var txt_obj = txt_arr[i];
//每个数据格式 {text:"***",color:"red"}
var r_text_color = this.getColor(txt_obj.color);
//cc.log("txt_obj.text=1#" + txt_obj.text + "#2");
var r_text = new ccui.RichElementText(i,r_text_color,txt_obj.text,this.m_sFonts,this.m_nFontSize);
richText.pushBackElement(r_text);
}
richText.formatText(); //修改引擎RichText::formatRenderers()
this.m_pTView.pushBackCustomItem(richText);
if(tag) {
this._itemData.push(data);
if(this._itemmax < this._itemData.length) {
this._itemData.splice(0,1);
this.m_pTView.removeItem(0);
}
this.m_pTView.jumpToBottom();
}
},
parseText : function (text) {
var txt_arr = [];
var txt_val_temp = text;
var txt_obj;
var txt_str = "";
while(0 < txt_val_temp.length) {
var ret = txt_val_temp.match(/<[a-z]+>/); //开头
if(ret) {
//KKVS.INFO_MSG(ret[0]);
//KKVS.INFO_MSG(ret["index"]);
//KKVS.INFO_MSG(ret["input"]);
var match_str_start = ret[0];
var match_ind_start = ret["index"];
//cc.log("->匹配头:" + match_str_start + " match_ind_start=" + match_ind_start);
if (0 < match_ind_start) {
txt_str += txt_val_temp.slice(0,match_ind_start);
}
txt_val_temp = txt_val_temp.slice((match_ind_start + match_str_start.length));
if (txt_val_temp.length == 0) {
txt_str += match_str_start;
break;
}
var match_str_key = match_str_start.slice(1,(match_str_start.length - 1));
var match_str_end = "</" + match_str_key + ">";
var end_ret = txt_val_temp.match(match_str_end);
if (end_ret) {
//cc.log("->匹配尾:" + match_str_end);
if(0 < txt_str.length) {
txt_obj = {text : txt_str};
txt_arr.push(txt_obj);
}
var match_ind_end = end_ret["index"];
if(0 < match_ind_end) {
txt_str = txt_val_temp.slice(0,match_ind_end);
txt_obj = {text : txt_str,color : match_str_key};
txt_arr.push(txt_obj);
}
txt_str = "";
txt_val_temp = txt_val_temp.slice((match_ind_end + match_str_end.length));
} else {
txt_str += match_str_start + txt_val_temp;
break;
}
} else {
txt_str += txt_val_temp;
break;
}
}
if(0 < txt_str.length) {
txt_obj = {text : txt_str};
txt_arr.push(txt_obj);
}


return txt_arr;
}
});


示例调用:

var gamemsgsize = cc.size(200,100);
var dataSet = [];
dataSet.push("<red>[系统消息]</red>欢迎<green>骨头专用号</green>进入'奖金牛牛'游戏,祝游戏愉快!");
dataSet.push("<red>[系统消息]</red>游戏结算中...");
dataSet.push("玩家<green>带原子弹的皮卡丘</green>输了2000");
dataSet.push("玩家<green>似雨似雾又似风</green>输了1960");
dataSet.push("<red>[系统消息]</red>游戏已经结束.");

this.m_pGameMsgList = new GameMsgList(gamemsgsize);
this.m_pGameMsgList.reloadData(dataSet);
this.m_pGameMsgList.setPosition(10,10);
sysmsg.addChild(this.m_pGameMsgList);
...

this.m_pGameMsgList.addItem("玩家<green>似雨似雾又似风</green>已经准备",false);
this.m_pGameMsgList.addItem("玩家<green>带原子弹的皮卡丘</green>已经准备",true);

当然,你也可以通过调用下面语句来设置字体:

this.m_pGameMsgList.setFonts("res/.../test.ttf",20);

可以修改默认字体颜色:

this.m_pGameMsgList.setColorDefault(cc.color(128,128));

这样的话,上面的"玩家<green>带原子弹的皮卡丘</green>输了2000"中的"玩家"两个字就不再是默认颜色(白色)了,而是cc.color(128,128).

可以修改配置的字体颜色:

this.m_pGameMsgList.setColor("green",cc.color(128,0));

使用上面语句则使用"玩家<green>带原子弹的皮卡丘</green>输了2000"中的"带原子弹的皮卡丘"几个字不再是原先的绿色了,0).

默认配置中存在的颜色有 red,green,blue,white,black,如果这些颜色满足不了需求,这里允许自由增加配置颜色.如想要增加特定的颜色:

this.m_pGameMsgList.setColor("mycolor_1",cc.color(64,0));
this.m_pGameMsgList.setColor("mycolor_2",64,0));
this.m_pGameMsgList.setColor("mycolor_3",64));

...

可自由定义颜色名字,然后像这样使用它:

this.m_pGameMsgList.addItem("颜色样式:<mycolor_1>颜色1</mycolor_1><mycolor_2>颜色2</mycolor_2><mycolor_3>颜色3</mycolor_3>",true);

补充: UIRichText.cpp中443行添加一句:_customSize.height = newContentSizeHeight;

cocos2dx-js 游戏消息列表的更多相关文章

  1. HTML5实现直播间评论滚动效果的代码

    这篇文章主要介绍了HTML5实现直播间评论滚动效果的代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. 前端监听websocket消息并实时弹出(实例代码)

    这篇文章主要介绍了前端监听websocket消息并实时弹出,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. HTML5之消息通知的使用(Web Notification)

    通知可以说是web中比较常见且重要的功能,私信、在线提问、或者一些在线即时通讯工具我们总是希望第一时间知道对方有了新的反馈。本篇文章主要介绍了HTML5之消息通知的使用(Web Notification),感兴趣的小伙伴们可以参考一下

  4. HTML5中的Web Notification桌面通知功能的实现方法

    这篇文章主要介绍了HTML5中的Web Notification桌面通知功能的实现方法,需要的朋友可以参考下

  5. HTML5仿微信聊天界面、微信朋友圈实例代码

    小编最近开发一个基于html5开发的一个微信聊天前端界面,功能很全面,下面小编给大家分享实例代码,需要的朋友参考下

  6. HTML5的postMessage的使用手册

    HTML5提出了一个新的用来跨域传值的方法,即postMessage,这篇文章主要介绍了HTML5的postMessage的使用手册的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  7. ios – Testflight无法安装应用程序

    我有几个测试人员注册了testflight并连接了他们的设备……他们有不同的ios型号……但是所有这些都有同样的问题.当他们从“safari”或“testflight”应用程序本身单击应用程序的安装按钮时……达到约90%并出现错误消息…

  8. xcode找不到匹配的配置文件

    我有一个AdhociOS应用程序,它给了我“在xcode6中找不到匹配的配置文件”,我创建了一个Adhoc配置文件,下载它,双击它并在General–Identity下选择了一个团队.但我接着得到了那条消息,并尝试使用“修复问题”按钮没有帮助.在构建设置–供应配置文件–发布我有“自动”.任何人都可以帮助我,我完全迷失了……

  9. ios – Reactive Cocoa – 以编程方式设置文本时不会调用UITextView的rac_textSignal

    我正在实现一个聊天UI,并使用ReactiveCocoa根据用户的类型调整聊天气泡的大小.目前,我正在基于textview的rac_textSignal更新UI的布局.一切都很好–除了一点:当用户发送消息时,我以编程方式清除文本字段:…我是否需要拥有一个持有currentTypedString的Nsstring,并在该字符串更新时驱动UI更改?

  10. ios – 当我关闭应用程序时,我从调试器获得消息:由于信号15而终止

    我怎么能解决这个问题,我不知道这个链接MypreviousproblemaboutCoredata对我的问题有影响吗?当我cmd应用程序的Q时,将出现此消息.Messagefromdebugger:Terminatedduetosignal15如果谁知道我以前的问题的解决方案,请告诉我.解决方法>来自调试器的消息:每当用户通过CMD-Q(退出)或STOP手动终止应用程序(无论是在iOS模拟器中还是

随机推荐

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

返回
顶部