转自:http://blog.csdn.net/ljxfblog/article/details/26136773

最近准备做一个聊天系统,开始准备使用cocos2dx的UIRichText控件来显示聊天内容,结果在使用的时候才发现,cocos2dx的RichText功能非常有限,完全不具备实现聊天的功能,只实现了加入文本、图像和自定义控件的功能,支持不同字体、颜色、字号。

我个人认为,一个RichText控件应该具备以下基本功能:

1、多样化的文本显示功能,包括字体、颜色、字号的设置。

2、能显示图片以及一些特殊元素。

3、应该支持图片文字的超链接功能。

4、能够支持滚动的效果。

5、能够有很方便的换行功能,最好能设置行间距。

如果能够更好的实现聊天的功能,我觉得还需要加入以下功能:

1、文本特效:描边,下划线,阴影,发光等功能。

2、支持设置控件最大显示行数。

3、支持数据的分类显示,用于分频道显示聊天内容。

cocos2dx只实现了基础的1和2功能,所以考虑之后还是决定自己写一个RichText控件。UIRichText的框架还是不错的,实现了文本分行显示的技术。在他的基础上很容易扩展。

首先,扩展RichItem,用来支持多样化的文本需求。

其次,扩展Label控件,用于支持特殊的文字效果。

再次,需要实现滚动功能,控件继承UIScrollView。

最后,还需要对lua进行支持,包括使用功能以及超链接点击事件的注册。

以上是我实现控件的思路,这里就不贴代码了,很多,我会把我的控件代码共享给大家,大家在使用中有什么问题也可以向我咨询。

源代码在这里,cocos2dx-3.0功能强大的richText控件

最后贴一下使用的代码和效果图吧!

使用代码如下,我是在lua里面使用的,大家可以参考一下:

  1. function ChatUI:initRichEdit()
  2. local widget = self:getWidget()
  3. if widget then
  4. --创建小喇叭控件
  5. self._richBugle = ui.RichTextUI:create()
  6. self._richBugle:setSize(cc.size(940, 35))
  7. self._richBugle:setAnchorPoint(cc.p(0, 0))
  8. self._richBugle:setPosition(cc.p(100, 510))
  9. self._richBugle:setMaxLine(1)
  10. --创建聊天控件
  11. self._richChat= ui.RichTextUI:create()
  12. self._richChat:setSize(cc.size(940, 420))
  13. self._richChat:setAnchorPoint(cc.p(0, 0))
  14. self._richChat:setPosition(cc.p(20, 70))
  15. widget:addChild(self._richBugle)
  16. widget:addChild(self._richChat)
  17. local function callback(sender, eventType)
  18. if eventType == ui.RICHTEXT_ANCHOR_CLICKED then
  19. print(">>>>>>>>>>>addEventListenerRichText")
  20. end
  21. end
  22. self._richChat:addEventListenerRichText(callback)
  23. end
  24. end
  25. function ChatUI:addChatMsg(channel, roleName, chatMsg, signs)
  26. local richText = (channel == Channel_ID_Bugle) and self._richBugle or self._richChat
  27. if richText and channel and roleName and chatMsg then
  28. local ChannelNameSwitch =
  29. {
  30. [Channel_ID_Team] = "【队伍】",
  31. [Channel_ID_Privacy] = "【私聊】",
  32. [Channel_ID_Faction] = "【帮会】",
  33. [Channel_ID_World] = "【世界】",
  34. [Channel_ID_System] = "【系统】"
  35. }
  36. local ChannelColor =
  37. {
  38. [Channel_ID_Team] = Color3B.ORANGE,
  39. [Channel_ID_Privacy] = Color3B.ORANGE,
  40. [Channel_ID_Faction] = Color3B.ORANGE,
  41. [Channel_ID_World] = Color3B.ORANGE,
  42. [Channel_ID_System] = Color3B.WHITE,
  43. [Channel_ID_Bugle] = Color3B.ORANGE
  44. }
  45. local linkColor = Color3B.YELLOW
  46. local linklineColor = Color4B.YELLOW
  47. local outlineColor = Color4B.BLACK
  48. if channel == Channel_ID_Bugle then
  49. richText:insertNewLine()
  50. end
  51. if ChannelNameSwitch[channel] then
  52. local rc = ui.RichItemText:create(channel, ChannelColor[channel], 255, strg2u(ChannelNameSwitch[channel]), "DFYuanW7-GB2312.ttf", 25)
  53. rc:enableOutLine(outlineColor, 2)
  54. richText:insertElement(rc)
  55. end
  56. if channel ~= Channel_ID_System then
  57. local rcn = ui.RichItemText:create(channel, linkColor, 255, strg2u(roleName), "DFYuanW7-GB2312.ttf", 25)
  58. rcn:enableLinkLine(linklineColor, 1)
  59. rcn:enableOutLine(outlineColor, 2)
  60. richText:insertElement(rcn)
  61. chatMsg = ":" .. chatMsg
  62. end
  63. local rcm = ui.RichItemText:create(channel, ChannelColor[channel], 255, strg2u(chatMsg), "DFYuanW7-GB2312.ttf", 25)
  64. richText:insertElement(rcm)
  65. if channel ~= Channel_ID_Bugle then
  66. richText:insertNewLine()
  67. end
  68. end
  69. end
  70. function ChatUI:initComponent()
  71. self:addChatMsg(Channel_ID_Bugle, "王小二", "This is Bugle Msg")
  72. self:addChatMsg(Channel_ID_System, "", "This is System Msg")
  73. self:addChatMsg(Channel_ID_Team, "王小二", "This is Team Msg")
  74. self:addChatMsg(Channel_ID_World, "王小二", "This is World Msg")
  75. self:addChatMsg(Channel_ID_Faction, "王小二", "This is Faction Msg")
  76. self._channel = Channel_ID_World
  77. self:showChannel(Channel_ID_All)
  78. local btnChannel = self:getChild("Button_Channel")
  79. if btnChannel then
  80. btnChannel:setTitleText(strg2u("世界"))
  81. end
  82. end

最后是效果图:

cocos2dx实现功能强大的RichText控件的更多相关文章

  1. Cocos2dx 把 glview 渲染到 Qt 控件上(Mac 环境)

    本文原链接:http://www.cnblogs.com/zouzf/p/4423256.html 环境:Mac 10.9.2   Xcode5.1.1  Qt5.3  cocos2dx-2.2.4 ...

  2. .Net强大的列表控件XPTable [转]

    .Net强大的列表控件XPTable http://blog.csdn.net/bodybo/article/details/7359531 XPTable的大名,想必C#开发的人都有所耳闻,使用下来 ...

  3. SharePoint 2013 新功能探索 之 标注控件

    SharePoint 2013 引入了新的UI,同时也跟进了网络潮流,把应用最广泛的标注控件也引入到了SharePoint,先看两个应用    以上是两个开发当中经常会用到,下面就介绍一下如何开发相同 ...

  4. jsp日期插件My97DatePicker 强大的日期控件 使用方便简单

    本文属转载(希望对编程爱好者有所帮助)详情请访问官方网站 http://www.my97.net/dp/index.asp 一. 简介 1. 简介 目前的版本是:4.7 2. 注意事项 My97Dat ...

  5. 多功能版vue日历控件

    下载地址:https://pan.baidu.com/s/1nvpx0tB5cIvvqHuApz_MpQ 之前写了一个简单的vue日历控件:https://www.cnblogs.com/mrzhu/ ...

  6. jsp日期插件My97DatePicker 强大的日期控件 使用方便简单(转)

    本文属转载(希望对编程爱好者有所帮助)详情请访问官方网站 http://www.my97.net/dp/index.asp 一. 简介 1. 简介 目前的版本是:4.7 2. 注意事项 My97Dat ...

  7. Flutter 强大的MediaQuery控件

    注意:无特殊说明,Flutter版本及Dart版本如下: Flutter版本: 1.12.13+hotfix.5 Dart版本: 2.7.0 MediaQuery 通常情况下,不会直接将MediaQu ...

  8. js非常强大的日历控件fullcalendar.js, 日期时间库: moment.js

    日历控件: https://fullcalendar.io/docs/ https://fullcalendar.io/docs/event_data/events_function/ https:/ ...

  9. 动态创建的文本框想要加上jQuery的datepicker功能变成日期选择控件该怎么办?

    通常页面输入控件想得到日期选择功能,借助jQuery是这样实现的: 1.载入css和js <script src="jqueryui/jquery-ui.js" type=& ...

随机推荐

  1. STL笔记(3) copy()之绝版应用

    STL笔记(3) copy()之绝版应用 我选用了一个稍稍复杂一点的例子,它的大致功能是:从标准输入设备(一般是键盘)读入一些整型数据,然后对它们进行排序,最终将结果输出到标准输出设备(一般是显示器屏 ...

  2. Itext导出PDF,word,图片案例

    iText导出pdf.word.图片 一.前言 在企业的信息系统中,报表处理一直占比较重要的作用,本文将介绍一种生成PDF报表的Java组件--iText.通过在服务器端使用Jsp或JavaBean生 ...

  3. JSAPI微信支付返回错误:fail_no permission to execute

    问题描述 fail_no permission to execute 一定是授权目录出问题了,因为没有权限. 开发环境及可能造成的原因 这次的微信开发是用的Mvc4,支付的封装代码不会有问题(用过很多 ...

  4. 浅谈网络爬虫爬js动态加载网页(二)

    没错,最后我还是使用了Selenium,去实现上一篇我所说的问题,别的没有试,只试了一下firefox的引擎,总体效果对我来说还是可以接受的. 继续昨天的话题,既然要实现上篇所说的问题,那么就需要一个 ...

  5. ios协议调起app

    function openIos(url, callback) { if (!url) { return; } var node = document.createElement('iframe'); ...

  6. AIX 第4章 指令记录

    root@db:/#lsdev -Cc disk --查看磁盘设备信息   -C customized -c class hdisk0       Available 00-08-00 SAS Dis ...

  7. Heritrix源码分析(七) Heritrix总体介绍(转)

    本博客属原创文章,欢迎转载!转载请务必注明出处:http://guoyunsky.iteye.com/blog/642794         本博客已迁移到本人独立博客: http://www.yun ...

  8. phonegap配置启动动画

    以下有2种方式 1 主Active中 onCreate函数里添加代码 2 config.xml文件进行配置(对通过命令行模式下cordova命令行生成的可行) 确保自己安装了SplashScreen插 ...

  9. mongo 安装

    mongo 安装: 1.按照 https://docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat/ 安装 2.安装成功后创建用户 d ...

  10. Php 笔记3-----php与 asp的等价关系

    对比asp.net 与 php的对比  ,有助于进一步理解 php. 1  输出. asp.net 输出    Response.Write(str);    // 将string 写入到 服务器向浏 ...