CN111199138A - 使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质 - Google Patents

使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质 Download PDF

Info

Publication number
CN111199138A
CN111199138A CN201811364240.4A CN201811364240A CN111199138A CN 111199138 A CN111199138 A CN 111199138A CN 201811364240 A CN201811364240 A CN 201811364240A CN 111199138 A CN111199138 A CN 111199138A
Authority
CN
China
Prior art keywords
characters
text
qml
expression
emoji
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201811364240.4A
Other languages
English (en)
Inventor
魏洪
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Wuhan Douyu Network Technology Co Ltd
Original Assignee
Wuhan Douyu Network Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Wuhan Douyu Network Technology Co Ltd filed Critical Wuhan Douyu Network Technology Co Ltd
Priority to CN201811364240.4A priority Critical patent/CN111199138A/zh
Publication of CN111199138A publication Critical patent/CN111199138A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Processing Or Creating Images (AREA)

Abstract

本发明涉及一种使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质,所述方法通过将Emoji表情字符和普通字符进行分离,为表情字符和普通字符指定不同类型的文本控件,动态创建不同类型的文本控件,且为表情字符和非表情字符设置相同布局,实现了使用Qml中对含Emoji彩色表情弹幕描边。

Description

使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储 介质
技术领域
本发明涉及互联网PC客户端应用开发技术领域,具体涉及一种使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质。
背景技术
自Emoji诞生以来,Emoji极大地丰富了我们的生活和通讯交流,用户越来越习惯于输入Emoji,因此接触Emoji也越来越频繁,Emoj i(绘文字)是一种图形字符,网络中经常用作表情符号。Emoji不是图片,每个Emoji都像文字一样拥有独立编码并且可以存放于字库中。
在Unicode编码中,Emoji主要安排在1号平面第241行至第247行(1F000-1F6FF),以及0号平面第39行和40行(2600-27FF)等位置,同时编码采用的是U+序列的表现形式,同时在UTF-8也给出了具体的表现形式。
给文字加入描边效果,即能增强文字的表现形式,又能增强趣味性,因此文字描边广泛应用于直播弹幕、游戏娱乐以及PPT文字演示中。由于Emoji表情和文字在Windows中统一为String类型的字符,并且统一通过控件Text进行渲染,然而在Windows系统中,彩色表情不允许加入描边,当对含有表情和文字的Text控件直接加描边时,彩色表情Windows在渲染时会出现异常。
当需要对含彩色表情的弹幕加描边时,需要对彩色表情和普通文字分别指定不同渲染方式,并且由于在Windows中彩色表情和普通文字统一通过控件Text进行渲染,因此需要为彩色表情和普通文字单独创建文本控件,并且指定统一布局,才能对含有彩色表情的弹幕加入描边时显示正常。
然而如何区分Emoji字符还是普通字符,又由于Emoji字符可能由两个Unicode字符组成,如何将Emoji字符和普通字符分开,同时在QML中,如何动态创建文本控件并且设置相同的布局均是待解决的问题。
发明内容
鉴于现有技术存在的问题,本发明的目的是提供一种使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质,所述方法通过将Emoji表情字符和普通字符进行分离,为表情字符和普通字符指定不同类型的文本控件,动态创建不同类型的文本控件,且为表情字符和非表情字符设置相同布局,实现了使用Qml中对含Emoji彩色表情弹幕描边。
为了实现上述目的,本发明采用的技术方案为一种使用QML对含Emoji表情弹幕描边方法,所述方法包括以下步骤:
S1、通过表情字符的统一码Unicode区间判断文本字符是否为表情字符;
S2、将找出的表情字符和普通字符进行分离;
S3、将分离后的表情字符指定不加入描边的文本控件,将分离后的普通字符指定加入描边的文本控件,并动态创建表情字符和普通字符相对应的文本控件,并对普通字符进行描边;
S4、设置步骤S3中表情字符和普通字符对应的文本控件中字符为相同布局,使得每个字符高度间距保持一致。
在上述技术方案中,所述步骤S1中,通过正则表达式匹配文本字符,若匹配成功,则文本字符属于所述统一码Unicode区间的表情字符,若匹配失败为普通字符。
在上述技术方案中,所述步骤S2中,分离的方法包括通过QML支持的Split文本分割接口,通过所述Split文本分割接口使用正则表达式匹配文本字符,由此筛选出表情字符,剩下的即为普通字符,并将筛选出的表情字符和普通字符分别放入存储字符列表中。
在上述技术方案中,所述步骤S3中,所述表情字符指定的文本控件为Text.Normal原始风格方式,不加入描边;
所述普通字符指定的文本控件为Text.Outline,为普通字符加入描边。
在上述技术方案中,所述步骤S3中,所述动态创建文本控件的方法包括以下步骤:
S31、QML提供CreateQmlObject函数用于文本控件动态创建,所述函数提供三个参数Qml、Parent和Filepath;
S32、Qml参数提供代码字符串,创建表情字符以及普通字符文本控件;
S33、Parent参数为创建的文本控件提供动态放置的位置;
S34、Filepath参数为创建文本控件时指明表情字符和普通字符的路径。
在上述技术方案中,所述步骤S4中,设置相同布局的方法包括以下步骤:
S41、在所述步骤S33中提供的位置加入Rectangle控件,所述Rectangle控件即为每一个字符画一个矩形;
S42、将表情字符文本控件和普通字符文本控件加入Rectangle控件中,按照Rectangle控件左上角的位置进行对齐。
在上述技术方案中,所述步骤S42中对齐的方法通过计算每个字符的偏移量,并根据步骤S33设定的位置对表情字符及普通字符文本控件进行上下左右对齐。
本发明还公开一种使用QML对含Emoji表情弹幕描边系统,所述系统包括判断模块、分离模块、创建模块和设置模块;
判断模块,用于表情字符的统一码Unicode区间判断文本字符是否为表情字符;
分离模块,用于将找出的表情字符和普通字符进行分离;
创建模块,用于将分离后的表情字符指定不加入描边的文本控件,将分离后的普通字符指定加入描边的文本控件,并动态创建表情字符和普通字符相对应的文本控件,并对普通字符进行描边;
设置模块,用于设置创建模块中表情字符和普通字符对应的文本控件中字符为相同布局,使得每个字符高度间距保持一致。
本发明还公开一种使用QML对含Emoji表情弹幕描边系统的服务器,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述任一项所述一种使用QML对含Emoji表情弹幕描边方法的步骤。
本发明还公开一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现如上述任一项所述一种使用QML对含Emoji表情弹幕描边方法的步骤。
本发明一种使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质,具有以下有益效果:通过所述方法对含彩色表情的弹幕加描边时,对彩色表情和普通文字分别指定不同渲染方式,且在Windows中为彩色表情和普通文字单独创建文本控件,并且指定统一布局,实现了对含有彩色表情的弹幕加入描边的效果,极大地丰富了通讯交流。
附图说明
图1为本发明实施例一提供的一种使用QML对含Emoji表情弹幕描边方法的流程图;
图2本发明实施例二提供一种使用QML对含Emoji表情弹幕描边系统模块图;
图3为本发明实施例三提供的服务器的结构示意图。
具体实施方式
本发明提供一种使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质。
为使得本发明的发明目的、特征、优点能够更加的明显和易懂,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,下面所描述的实施例仅仅是本发明一部分实施例,而非全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其它实施例,都属于本发明保护的范围。
本发明如图1所示实施例一提供一种使用QML对含Emoji表情弹幕描边方法,所述方法包括以下步骤,如图1所示:
S1、通过表情字符的统一码Unicode区间判断文本字符是否为表情字符;
可选的,所述步骤S1中,通过正则表达式匹配文本字符,若匹配成功,则文本字符属于所述统一码Unicode区间的表情字符,若匹配失败为普通字符。
其中,Unicode(统一码、万国码、单一码)是计算机科学领域里的一项业界标准,包括字符集、编码方案等。
正则表达式(Regular Expression)正则表达式的定义包括:用某种模式去匹配一类字符串的公式,它主要是用来描述字符串匹配的工具。描述了一种字符串匹配的模式。可以用来检查字符串是否含有某种子串、将匹配的子串做替换或者从中取出符合某个条件的子串等。由普通字符(a-z)以及特殊字符(元字符)组成的文字模式,正则表达式作为一个模版,将某个字符模式与所搜索的字符串进行匹配。用于描述某些规则的的工具。这些规则经常用于处理字符串中的查找或替换字符串。正则表达式就是记录文本规则的代码。用一个字符串来描述一个特征,然后去验证另一个字符串是否符合这个特征。
其中,由于Unicode官方提供的Emoji字符的Unicode区间为(\ud83c\udf00-\ud83c\udfff]),(\ud83d\udc00-\ud83d\ude4f],(\ud83d\ude80-\ud83d\udeff),(\u2600-\u2b55),可以判断文本字符是否属于此Unicode区间,通过正则表达式匹配对字符串中的文本字符判断。
S2、将找出的表情字符和普通字符进行分离;
可选的,所述步骤S2中,分离的方法包括通过QML支持的Split文本分割接口,通过所述Split文本分割接口使用正则表达式匹配文本字符,由此筛选出表情字符,剩下的即为普通字符,并将筛选出的表情字符与普通字符分别放入存储字符列表中。
其中,QML是一种声明式语言。它提供了一组接口用来描写叙述可视化组件以及他们之间的互动。它是一个高度可读的语言,而且被设计成使组件以一个动态的方式相互连接。同一时候它使组件非常Easy被复用以及创建定制的用户界面。使用QtQuick模块,设计者和开发人员能够非常Easy使用QML建立带有流畅动画的用户界面,并将这些界面连接到后端的C++库上面。
QML是Qt提供的一种描述性的脚本语言,类似于CSS(Cascadin g Style Sheets),可以在脚本里创建图形对象,并且支持各种图形特效,以及状态机等,同时又能跟Qt写的C++代码进行方便的交互,使用起来非常方便。采用QML加插件的方式主要是为了将界面设计与程序逻辑解耦,一般的系统开发中界面设计的变动往往多于后台逻辑,因此采用QML加插件的方式将界面设计与逻辑分离有利于开发人员的分工,加速产品迭代速度,降低后期维护成本。而且QML解释性语言的特性使得其语法更加简单,可以将界面设计部分交给专业的设计人员开发,而不要求设计人员会C++等编程语言。Qt底层对QML做了优化,将会优先使用硬件图形加速器进行界面的渲染,也针对触摸屏应用做了优化,使用QML能够更简单快捷的搭建流畅、优美的界面。QML也支持嵌入Javascript处理逻辑,但是底层逻辑处理使用Qt C++编写插件,能够更好的控制数据结构,数据处理也更加高效,Qt提供了多种方式将C++数据类型导入QML脚本中。QML将界面分解为一个一个小的元素,通过使用QML描述各元素的排列以及对特定事件的响应来搭建一个动态的界面。QML中的元素是以层级的形式进行描述的,子元素继承父元素的坐标系统,子元素的坐标以父元素作为参考,父元素的左上角为子元素的坐标原点,子元素中可以Parent关键字引用父元素。在一个QML文件中,每个元素都可以设定唯一的i d,在其他元素中可以引用id来更改此元素的属性等。QML提供一系列内置的元素类型供开发中快速搭建界面,包括最常用的Rectangle、Image、Text、MouseArea、Item等。元素都有自己内置的属性,比如之前介绍的id,以及用于指定坐标的x、y,和width、height等,同时也支持使用Property关键字自定义属性。
使用Rectangle就可以构建出消息展示框和按钮等大部分的界面元素了,而Text类型可以用于在Rectangle中增加文字信息,Im age可以加载图片,MouseArea提供鼠标/触摸屏事件,组合使用这几个元素就能够快速的搭建基本的交互界面。
其中,Split按照指定的字符分割,如按照";"或"/"等分割。sp lit就是将一字符串以特定的字符分割成多个字符串,Split()方法用于把一个字符串分割成字符串数组。StringObject.split(separa tor,howmany),参数描述Separator必需。字符串或正则表达式,从该参数指定的地方分割StringObject,Howmany可选。该参数可指定返回的数组的最大长度。如果设置了该参数,返回的子串不会多于这个参数指定的数组。如果没有设置该参数,整个字符串都会被分割,不考虑它的长度。一个字符串数组。该数组是通过在Separator指定的边界处将字符串StringObject分割成子串创建的。返回的数组中的字串不包括Separator自身。但是,如果Separator是包含子表达式的正则表达式,那么返回的数组中包括与这些子表达式匹配的字串(但不包括与整个正则表达式匹配的文本)。
S3、将分离后的表情字符指定不加入描边的文本控件,将分离后的普通字符指定加入描边的文本控件,并动态创建表情字符和普通字符相对应的文本控件,并对普通字符进行描边;
可选的,所述步骤S3中,所述表情字符指定的文本控件为Text.Normal原始风格方式,不加入描边;
所述普通字符指定的文本控件为Text.Outline,为普通字符加入描边。
具体的,一种是Text.Normal原始风格方式,不加入描边,另一种是Text.Outline,可加入描边方式。将普通字符Text控件的Sty le设置为Text.Outline即可为普通字符加入描边,同时通过Style提供的StyleColor接口设置指定的颜色值,可以给普通字符加入描边颜色,而将表情Emoji字符Text的Style风格设置为Text.Norma l,保证Emoji字符不加入描边。
具体的,Text元素可以表示纯文本或者富文本(使用HTML标记修饰的文本)。它有Font,Text,Color,Elide,TextFormat,WrapM ode,HorizontalAlignment,VerticalAlignment等属性,可以通过这些属性来决定Text如何显示文本。可以直接通过TextFormat来指定其属性。当不指定TextFormat属性时,Text会默认使用Text.Au toText,自动检测文本是纯文本还是富文本。Text元素的Style属性提供了几种风格:Text.Outline,Text.Raised,Text.Sunken,可以使文字显示特别的效果。而StyleColor属性可以和Style配合使用(如果没有指定Style,则StyleColor不生效),如Style为Text.Outline时,StyleColor就是文字轮廓的颜色。
其中,所述步骤S3中,所述动态创建文本控件的方法包括以下步骤:
S31、QML提供CreateQmlObject函数用于文本控件动态创建,所述函数提供三个参数Qml、Parent和Filepath;
S32、Qml参数提供代码字符串,创建表情字符以及普通字符文本控件;
S33、Parent参数为创建的文本控件提供动态放置的位置;
S34、Filepath参数为创建文本控件时指明表情字符和普通字符的路径。
其中,createQmlObject()函数,从一个QML字符串创建一个对象。
具体的,QML提供了很多方法来动态创建和管理QML对象。如L oader、RePeater、ListView、GridView和PathView等元素都支持动态对象管理。对象也可以在C++中被创建和管理,这是混合QML/C++应用程序的首选方式。QML也支持在JavaScript代码中动态创建对象,这在现有的QML元素不适合应用程序需要的情况下是很有用的,而且也不需要涉及C++组件。
动态创建对象,有两种方法从JavaScript动态创建对象。既可以调用Qt.createComponent()来动态创建Compont对象,也可以使用Qt.createQmlObject()从QML字符串来创建对象。如果QML本身是在运行时产生的,那么使用QML字符串来创建对象是很有用的。动态创建一个组件,要动态加载定义在一个QML文件中的组件,可以在QML全局对象上调用Qt.createComponent()函数。这个函数需要将Q ML文件的URL作为其参数,然后这个URL上创建一个Component对象。一旦有了一个Component,就可以调用它的createObject()函数来创建该组件的一个实例。这个函数需要指定新对象的父对象。因为图形项目没有父对象是无法显示在场景上的,所以建议这样来设置父对象。当管理动态创建的对象时,必须确保创建上下文(creation context)不会再创建的对象销毁前被销毁。否则,如果创建上下文被首先销毁,那么在动态创建对象中的绑定将不会再工作。实际的创建上下文依赖于对象是怎样被创建的:如果使用了Qt.createCompon ent(),创建上下文就是调用该函数的QDeclarativeContext;如果使用了Qt.crateQmlObject(),创建上下文就是父对象的上下文,如果定义了一个Component{},然后在其上调用了CreateObject(),创建上下文就是该Component中定义的上下文,另外需注意,虽然动态创建的对象可以像其他对象一样来使用,但是它们没有id值。
S4、设置步骤S3中表情字符和普通字符对应的文本控件中字符为相同布局,使得每个字符高度间距保持一致;
其中,所述步骤S4中,设置相同布局的方法包括以下步骤:
S41、在所述步骤S33中提供的位置加入Rectangle控件,所述Rectangle控件即为每一个字符画一个矩形;
S42、将表情字符文本控件和普通字符文本控件加入Rectangle控件中,按照Rectangle控件左上角的位置进行对齐;
可选的,所述步骤S42中对齐的方法通过计算每个字符的偏移量,并根据步骤S33设定的位置对表情字符及普通字符文本控件进行上下左右对齐。
其中,Rectangle用来绘制一个填充矩形,可以带边框,也可以不带,可以使用纯色填充,也可以使用渐变色填充,甚至还可以不填充而只提供边框。Color属性可以指定填充颜色,而Gradient属性则用来设置渐变色供填充使用,如果你同时指定了Color和Gradient,那么Gradient生效;如果你设置Color属性为Transparent,那么就可以达到只绘制边框不填充的效果。Border.width指定边框的宽度,Border.color指定边框颜色。Rectangle还可以绘制圆角矩形,只需设置Radius属性。
关于颜色值,在QML中可以使用颜色名字,如blue,red,gree n,transparent等,也可以使“#RRGGBB”或者“#AARRGGBB”来指定,还可以使用Qt.rgba(),Qt.lighter()等方法来构造。
渐变色通过两个或多个颜色值来指定,QML会自动在你指定的颜色之间插值,进行无缝填充。Gradient使用GradientStop来指定一个颜色值和它的位置(取值在0.0与1.0之间)。
本发明实施例二如图2所示还提供一种使用QML对含Emoji表情弹幕描边系统,所述系统包括判断模块、分离模块、创建模块和设置模块;
判断模块,用于表情字符的统一码Unicode区间判断文本字符是否为表情字符;
分离模块,用于将找出的表情字符和普通字符进行分离;
创建模块,用于将分离后的表情字符指定不加入描边的文本控件,将分离后的普通字符指定加入描边的文本控件,并动态创建表情字符和普通字符相对应的文本控件,并对普通字符进行描边;
设置模块,用于设置创建模块中表情字符和普通字符对应的文本控件中字符为相同布局,使得每个字符高度间距保持一致。
本发明实施例三如图3所示提供一种使用QML对含Emoji表情弹幕描边系统的服务器结构示意图,所述实施例的服务器包括:处理器30、存储器31以及存储在所述存储器31中并可在所述处理器30上运行的计算机程序32。所述处理器30执行所述计算机程序32时实现上述各方法实施例中的步骤,所述处理器30执行所述计算机程序32时实现上述装置实施例中各模块的功能。
所述一种使用QML对含Emoji表情弹幕描边系统的服务器可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备,所述一种使用QML对含Emoji表情弹幕描边系统的服务器可包括,但不限于,处理器30、存储器31。图3仅仅是对此服务器的示例,并不构成对此服务器的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,所述一种使用QML对含Emoji表情弹幕描边系统的服务器还可以包括输入输出设备33、显示设备34等。
所述处理器30可以是中央处理单元,还可以是其他通用处理器、数字信号处理器、专用集成电路、现成可编程门阵列或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述存储器31可以是所述一种使用QML对含Emoji表情弹幕描边系统的服务器的内部存储单元、硬盘或内存。所述存储器31也可以是所述服务器的外部存储设备,或配备的插接式硬盘,智能存储卡,安全数字卡,闪存卡等。
进一步地,所述存储器31还可以既包括所述服务器的内部存储单元也包括外部存储设备。所述存储器31用于存储所述计算机程序以及所述电子设备所需的其他程序和数据。所述存储器31还可以用于暂时地存储已经输出或者将要输出的数据。
所述的输入输出设备33可用于接收输入的数字或字符信息,具体的,输入输出设备33还可以包括但不限于键盘、鼠标、操作杆等中的一种和多种。
所述的显示设备34可用于显示由用户输入的信息或提供给用户信息以及终端的各种菜单,显示设备34可包括显示面板,可选的,可采用液晶显示器。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各实施例的模块、方法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
所述集成的模块如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明实现上述实施例方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,RandomAccess Memory)、电载波信号、电信信号以及软件分发介质等。需要说明的是,所述计算机可读介质包含的内容可以根据司法管辖区内立法和专利实践的要求进行适当的增减,例如在某些司法管辖区,根据立法和专利实践,计算机可读介质不包括电载波信号和电信信号。
以上所述,以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。

Claims (10)

1.一种使用QML对含Emoji表情弹幕描边方法,其特征在于,所述方法包括以下步骤:
S1、通过表情字符的统一码Unicode区间判断文本字符是否为表情字符;
S2、将找出的表情字符和普通字符进行分离;
S3、将分离后的表情字符指定不加入描边的文本控件,将分离后的普通字符指定加入描边的文本控件,并动态创建表情字符和普通字符相对应的文本控件,并对普通字符进行描边;
S4、设置步骤S3中表情字符和普通字符对应的文本控件中字符为相同布局,使得每个字符高度间距保持一致。
2.根据权利要求1所述一种使用QML对含Emoji表情弹幕描边方法,其特征在于,所述步骤S1中,通过正则表达式匹配文本字符,若匹配成功,则文本字符属于所述统一码Unicode区间的表情字符,若匹配失败为普通字符。
3.根据权利要求2所述一种使用QML对含Emoji表情弹幕描边方法,其特征在于,所述步骤S2中,分离的方法包括通过QML支持的Split文本分割接口,通过所述Split文本分割接口使用正则表达式匹配文本字符,由此筛选出表情字符,剩下的即为普通字符,并将筛选出的表情字符和普通字符分别放入存储字符列表中。
4.根据权利要求3所述一种使用QML对含Emoji表情弹幕描边方法,其特征在于,所述步骤S3中,所述表情字符指定的文本控件为Text.Normal原始风格方式,不加入描边;
所述普通字符指定的文本控件为Text.Outline,为普通字符加入描边。
5.根据权利要求4所述一种使用QML对含Emoji表情弹幕描边方法,其特征在于,所述步骤S3中,所述动态创建文本控件的方法包括以下步骤:
S31、QML提供CreateQmlObject函数用于文本控件动态创建,所述函数提供三个参数Qml、Parent和Filepath;
S32、Qml参数提供代码字符串,创建表情字符以及普通字符文本控件;
S33、Parent参数为创建的文本控件提供动态放置的位置;
S34、Filepath参数为创建文本控件时指明表情字符和普通字符的路径。
6.根据权利要求5所述一种使用QML对含Emoji表情弹幕描边方法,其特征在于,所述步骤S4中,设置相同布局的方法包括以下步骤:
S41、在所述步骤S33中提供的位置加入Rectangle控件,所述Rectangle控件即为每一个字符画一个矩形;
S42、将表情字符文本控件和普通字符文本控件加入Rectangle控件中,按照Rectangle控件左上角的位置进行对齐。
7.根据权利要求6所述一种使用QML对含Emoji表情弹幕描边方法,其特征在于,所述步骤S42中对齐的方法通过计算每个字符的偏移量,并根据步骤S33设定的位置对表情字符及普通字符文本控件进行上下左右对齐。
8.一种使用QML对含Emoji表情弹幕描边系统,其特征在于,所述系统包括判断模块、分离模块、创建模块和设置模块;
判断模块,用于表情字符的统一码Unicode区间判断文本字符是否为表情字符;
分离模块,用于将找出的表情字符和普通字符进行分离;
创建模块,用于将分离后的表情字符指定不加入描边的文本控件,将分离后的普通字符指定加入描边的文本控件,并动态创建表情字符和普通字符相对应的文本控件,并对普通字符进行描边;
设置模块,用于设置创建模块中表情字符和普通字符对应的文本控件中字符为相同布局,使得每个字符高度间距保持一致。
9.一种使用QML对含Emoji表情弹幕描边系统的服务器,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至7中任一项所述一种使用QML对含Emoji表情弹幕描边方法的步骤。
10.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述一种使用QML对含Emoji表情弹幕描边方法的步骤。
CN201811364240.4A 2018-11-16 2018-11-16 使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质 Pending CN111199138A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811364240.4A CN111199138A (zh) 2018-11-16 2018-11-16 使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811364240.4A CN111199138A (zh) 2018-11-16 2018-11-16 使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质

Publications (1)

Publication Number Publication Date
CN111199138A true CN111199138A (zh) 2020-05-26

Family

ID=70746003

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811364240.4A Pending CN111199138A (zh) 2018-11-16 2018-11-16 使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质

Country Status (1)

Country Link
CN (1) CN111199138A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113485705A (zh) * 2021-06-30 2021-10-08 深圳软牛科技有限公司 基于QML Rectangle组件的选框方法、装置、设备及存储介质
CN113923505A (zh) * 2021-12-14 2022-01-11 飞狐信息技术(天津)有限公司 弹幕处理方法、装置及电子设备和存储介质

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104935997A (zh) * 2015-06-01 2015-09-23 上海幻电信息科技有限公司 观看者自定义高级弹幕的方法和装置
CN105160646A (zh) * 2015-10-21 2015-12-16 广州视睿电子科技有限公司 一种字符描边实现方法和装置
WO2017193540A1 (zh) * 2016-05-12 2017-11-16 乐视控股(北京)有限公司 弹幕播放方法、播放装置及播放系统
WO2018053594A1 (en) * 2016-09-22 2018-03-29 Emoji Global Pty Limited Emoji images in text messages
CN108401177A (zh) * 2018-02-27 2018-08-14 上海哔哩哔哩科技有限公司 视频播放方法、服务器及视频播放系统
CN108614805A (zh) * 2018-05-02 2018-10-02 武汉斗鱼网络科技有限公司 使用qml显示彩色表情的方法及系统、服务器及介质

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104935997A (zh) * 2015-06-01 2015-09-23 上海幻电信息科技有限公司 观看者自定义高级弹幕的方法和装置
CN105160646A (zh) * 2015-10-21 2015-12-16 广州视睿电子科技有限公司 一种字符描边实现方法和装置
WO2017193540A1 (zh) * 2016-05-12 2017-11-16 乐视控股(北京)有限公司 弹幕播放方法、播放装置及播放系统
WO2018053594A1 (en) * 2016-09-22 2018-03-29 Emoji Global Pty Limited Emoji images in text messages
CN108401177A (zh) * 2018-02-27 2018-08-14 上海哔哩哔哩科技有限公司 视频播放方法、服务器及视频播放系统
CN108614805A (zh) * 2018-05-02 2018-10-02 武汉斗鱼网络科技有限公司 使用qml显示彩色表情的方法及系统、服务器及介质

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
江含雪: "传播学视域中的弹幕视频研究", 中国优秀硕士学位论文全文数据库, no. 09, pages 13 *
霍亚飞: "Qt及Qt Quick开发实战精解", 31 May 2012, 北京航空航天大学出版社, pages: 187 - 188 *

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113485705A (zh) * 2021-06-30 2021-10-08 深圳软牛科技有限公司 基于QML Rectangle组件的选框方法、装置、设备及存储介质
CN113485705B (zh) * 2021-06-30 2023-11-21 深圳软牛科技有限公司 基于QML Rectangle组件的选框方法、装置、设备及存储介质
CN113923505A (zh) * 2021-12-14 2022-01-11 飞狐信息技术(天津)有限公司 弹幕处理方法、装置及电子设备和存储介质
CN113923505B (zh) * 2021-12-14 2022-03-01 飞狐信息技术(天津)有限公司 弹幕处理方法、装置及电子设备和存储介质

Similar Documents

Publication Publication Date Title
TWI808393B (zh) 頁面處理方法、裝置、設備及儲存媒體
US11003422B2 (en) Methods and systems for visual programming using polymorphic, dynamic multi-dimensional structures
US10466971B2 (en) Generation of an application from data
CN105511873B (zh) 用户界面控件展示方法及装置
US11449573B2 (en) System and method for smart interaction between website components
US20160098250A1 (en) Application prototyping tool
CN108897541B (zh) 应用程序的视觉还原方法、装置、存储介质及终端
CN110020356A (zh) 一种页面模块的代码生成方法、装置及系统
CN107066440A (zh) 竖排文本的输入控制方法及系统
US20210225059A1 (en) Customizable animation experience
CN113535165A (zh) 界面生成方法、装置、电子设备及计算机可读存储介质
AU2018279309A1 (en) System and method for smart interaction between website components
CN111936966A (zh) 用于创建图形内容的设计系统
WO2013109858A1 (en) Design canvas
CN108961361B (zh) 生成特效文字图像的方法及系统、计算机设备
CN111199138A (zh) 使用QML对含Emoji表情弹幕描边方法、系统、服务器及存储介质
CN115130442A (zh) 报表生成的方法、装置、存储介质及计算机设备
CN111258434A (zh) 在聊天界面插入图片的方法、装置、设备及存储介质
CN106844606A (zh) 网页的焦点处理方法及装置
CN110012338A (zh) 一种显示弹幕数据的方法、装置、计算机设备和存储介质
CN114154095A (zh) 页面图片生成方法、装置、设备和存储介质
CN102801936A (zh) 实现在屏显示的方法
US10930036B2 (en) Bar chart optimization
CN117290036A (zh) 一种量子eda在线工具平台的窗口视图切换方法及装置
CN113608726A (zh) 代码生成方法、装置、电子设备及存储介质

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination