一种UI界面的显示处理方法及装置转让专利

申请号 : CN201611121830.5

文献号 : CN108196920B

文献日 :

基本信息:

PDF:

法律信息:

相似专利:

发明人 : 徐超

申请人 : 武汉斗鱼网络科技有限公司

摘要 :

本发明实施例公开了一种UI界面的显示处理方法及装置,所述方法包括:解析待显示UI界面,得到所述待显示UI界面的元素节点;根据所述待显示UI界面的元素节点创建与待显示UI界面对应的树形控件;配置所述待显示UI界面的与所述树形控件对应的渲染列表;以及根据所述渲染列表,采用双缓冲技术对所述树形控件进行渲染。本发明实施例提出的UI界面的显示处理方法及装置,能够高效地实现UI界面的渲染,提高复杂UI界面的显示速度和显示效果,提升用户的使用体验。

权利要求 :

1.一种UI界面的显示处理方法,其特征在于,所述方法包括:解析待显示UI界面,得到所述待显示UI界面的元素节点;

根据所述待显示UI界面的元素节点创建与所述待显示UI界面对应的树形控件;

配置所述待显示UI界面的与所述树形控件对应的渲染列表;以及根据所述渲染列表,采用双缓冲技术对所述树形控件进行渲染,具体包括:采用双缓冲技术创建与所述树形控件对应的位图对象;

根据所述渲染列表中各元素节点在树形控件中的位置信息确定对应元素节点在所述位图对象中对应的待渲染区域;

根据各元素节点在树形控件中的绘制信息对所述待渲染区域进行渲染;

将渲染后的所述位图对象绘制到所述树形控件。

2.根据权利要求1所述的方法,其特征在于,所述树形控件中的每一元素节点配置有对应的元素数据结构,所述元素数据结构包括对应元素节点在树形控件中的绘制信息、位置信息和对应元素节点的父节点信息和子节点列表。

3.根据权利要求2所述的方法,其特征在于,所述配置所述待显示UI界面的与所述树形控件对应的渲染列表,包括:确定所述树形控件中每一元素节点对应的元素数据结构的渲染信息;将各个元素数据结构的渲染信息进行组合,得到所述待显示UI界面的渲染列表。

4.根据权利要求2所述的方法,其特征在于,所述方法还包括:在接收到元素节点添加请求时,根据待添加元素节点的父节点信息查找对应的父元素节点,所述元素节点添加请求中包括有待添加元素节点的父节点信息;

为所述待添加元素节点配置对应的待添加元素数据结构,将所述待添加元素数据结构添加在所述父元素节点中;

将待添加元素数据结构的渲染信息添加到所述渲染列表中。

5.根据权利要求2所述的方法,其特征在于,所述方法还包括:在接收到元素节点更新请求时,根据待更新元素节点的节点信息查找对应的元素节点,所述元素节点更新请求中包括有待更新元素节点的节点信息和该元素节点在树形控件中的目标绘制信息;

根据所述目标绘制信息对所述待更新元素节点对应的待渲染区域进行重新渲染。

6.一种UI界面的显示处理装置,其特征在于,所述装置包括:解析模块,用于解析待显示UI界面,得到所述待显示UI界面的元素节点;

生成模块,用于根据所述待显示UI界面的元素节点创建与待显示UI界面对应的树形控件;

配置模块,用于配置所述待显示UI界面的与所述树形控件对应的渲染列表;

显示模块,用于根据所述渲染列表,采用双缓冲技术对所述树形控件进行渲染,所述显示模块,具体包括:创建单元,用于采用双缓冲技术创建与所述树形控件对应的位图对象;

确定单元,用于根据所述渲染列表中各元素节点在树形控件中的位置信息确定对应元素节点在所述位图对象中对应的待渲染区域;

渲染单元,用于根据各元素节点在树形控件中的绘制信息对所述待渲染区域进行渲染;

显示单元,用于将渲染后的所述位图对象绘制到所述树形控件。

7.根据权利要求6所述的装置,其特征在于,所述树形控件中的每一元素节点配置有对应的元素数据结构,所述元素数据结构包括对应元素节点在树形控件中的绘制信息、位置信息和对应元素节点的父节点信息和子节点列表。

8.根据权利要求6所述的装置,其特征在于,所述配置模块,具体用于确定所述树形控件中每一元素节点对应的元素数据结构的渲染信息;将各个元素数据结构的渲染信息进行组合,得到所述待显示UI界面的渲染列表。

说明书 :

一种UI界面的显示处理方法及装置

技术领域

[0001] 本发明涉及图形用户界面技术领域,尤其涉及一种UI界面的显示处理方法及装置。

背景技术

[0002] 随着计算机技术的不断发展,硬件性能的不断提高,这使得设计更加复杂的UI控件成为可能。发明人在实现本发明过程中发现:虽然Windows已经提供有相应的UI控件,但是这些UI控件的功能比较单一,使用比较繁琐。而对于复杂的UI控件,不仅设计过程复杂,同时,在对复杂UI控件的界面进行显示时,经常会出现如闪烁或数据残留等现象,影响用户观看体验,而且现有技术无法灵活地实现UI控件的扩展和更新。

发明内容

[0003] 鉴于上述问题,本发明提出了一种UI界面的显示处理方法及装置,能够高效地实现UI界面的渲染,提高复杂UI界面的显示速度和显示效果,提升用户的使用体验。
[0004] 本发明的一个方面,提供了一种UI界面的显示处理方法,所述方法包括:
[0005] 解析待显示UI界面,得到所述待显示UI界面的元素节点;
[0006] 根据所述待显示UI界面的元素节点创建与待显示UI界面对应的树形控件;
[0007] 配置所述待显示UI界面的与所述树形控件对应的渲染列表;以及[0008] 根据所述渲染列表,采用双缓冲技术对所述树形控件进行渲染。
[0009] 可选地,所述树形控件中的每一元素节点配置有对应的元素数据结构,所述元素数据结构包括对应元素节点在树形控件中的绘制信息、位置信息和对应元素节点的父节点信息和子节点列表。
[0010] 可选地,所述配置所述待显示UI界面的与所述树形控件对应的渲染列表,包括:
[0011] 确定所述树形控件中每一元素节点对应的元素数据结构的渲染信息;将各个元素数据结构的渲染信息进行组合,得到所述待显示UI界面的渲染列表。
[0012] 可选地,所述根据所述渲染列表,采用双缓冲技术对所述树形控件进行渲染,包括:
[0013] 采用双缓冲技术创建与所述树形控件对应的位图对象;
[0014] 根据所述渲染列表中各元素节点在树形控件中的位置信息确定对应元素节点在所述位图对象中对应的待渲染区域;
[0015] 根据各元素节点在树形控件中的绘制信息对所述待渲染区域进行渲染;
[0016] 将渲染后的所述位图对象绘制到所述树形控件。
[0017] 可选地,所述方法还包括:
[0018] 在接收到元素节点添加请求时,根据待添加元素节点的父节点信息查找对应的父元素节点,所述元素节点添加请求中包括有待添加元素节点的父节点信息;
[0019] 为所述待添加元素节点配置对应的待添加元素数据结构,将所述待添加元素数据结构添加在所述父元素节点中;
[0020] 将待添加元素数据结构的渲染信息添加到所述渲染列表中。
[0021] 可选地,所述方法还包括:
[0022] 在接收到元素节点更新请求时,根据待更新元素节点的节点信息查找对应的元素节点,所述元素节点更新请求中包括有待更新元素节点的节点信息和该元素节点在树形控件中的目标绘制信息;
[0023] 根据所述目标绘制信息对所述待更新元素节点对应的待渲染区域进行重新渲染。
[0024] 本发明的又一个方面,提供了一种UI界面的显示处理装置,所述装置包括:
[0025] 解析模块,用于解析待显示UI界面,得到所述待显示UI界面的元素节点;
[0026] 生成模块,用于根据所述待显示UI界面的元素节点创建与待显示UI界面对应的树形控件;
[0027] 配置模块,用于配置所述待显示UI界面的与所述树形控件对应的渲染列表;
[0028] 显示模块,用于根据所述渲染列表,采用双缓冲技术对所述树形控件进行渲染。
[0029] 可选地,所述树形控件中的每一元素节点配置有对应的元素数据结构,所述元素数据结构包括对应元素节点在树形控件中的绘制信息、位置信息和对应元素节点的父节点信息和子节点列表。
[0030] 可选地,所述配置模块,具体用于确定所述树形控件中每一元素节点对应的元素数据结构的渲染信息;将各个元素数据结构的渲染信息进行组合,得到所述待显示UI界面的渲染列表。
[0031] 可选地,所述显示模块,包括:
[0032] 创建单元,用于采用双缓冲技术创建与所述树形控件对应的位图对象;
[0033] 确定单元,用于根据所述渲染列表中各元素节点在树形控件中的位置信息确定对应元素节点在所述位图对象中对应的待渲染区域;
[0034] 渲染单元,用于根据各元素节点在树形控件中的绘制信息对所述待渲染区域进行渲染;
[0035] 显示单元,用于将渲染后的所述位图对象绘制到所述树形控件。
[0036] 本发明实施例提供的UI界面的显示处理方法及装置,通过对待显示UI界面进行解析,得到待显示UI界面的元素节点,并根据待显示UI界面的元素节点创建待显示UI界面对应的树形控件,以根据与待显示UI界面的树形控件对应的渲染列表,采用双缓冲技术对该树形控件进行渲染,实现对待显示UI界面的高效渲染,提高复杂UI界面的显示速度和显示效果,进而提升用户的使用体验。
[0037] 此外,本发明实施例提供的UI界面的显示处理方法及装置,通过对待显示UI界面进行解析,得到待显示UI界面的元素节点,进而可以灵活地实现基于元素节点的UI控件的扩展和更新。
[0038] 上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。

附图说明

[0039] 通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
[0040] 图1示出了本发明实施例的一种UI界面的显示处理方法的流程图;
[0041] 图2示出了本发明实施例的UI界面的显示处理方法中步骤S14的细分流程图;
[0042] 图3示出了本发明实施例的一种UI界面的显示处理装置的结构示意图;
[0043] 图4示出了本发明实施例的UI界面的显示处理装置中显示模块的内部结构示意图。

具体实施方式

[0044] 下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
[0045] 本技术领域技术人员可以理解,除非另外定义,这里使用的所有术语(包括技术术语和科学术语),具有与本发明所属领域中的普通技术人员的一般理解相同的意义。还应该理解的是,诸如通用字典中定义的那些术语,应该被理解为具有与现有技术的上下文中的意义一致的意义,并且除非被特定定义,否则不会用理想化或过于正式的含义来解释。
[0046] 图1示意性示出了本发明实施例的一种UI界面的显示处理方法的流程图。参照图1,本发明实施例的UI界面的显示处理方法具体包括以下步骤:
[0047] S11、解析待显示UI界面,得到所述待显示UI界面的元素节点。
[0048] 目前,在开发Windows可视化窗口程序时通常会用到列表或树控件,即将可视化窗口程序中的数组信息展示到窗口上。本实施例中,UI界面的元素节点即UI界面对应的树控件的枝干或树叶,例如要实现一个好友列表的树形控件,好友类型就是一个枝干,类型名称是一个Lable控件是好友枝干的叶子,好友张三列表项又是好友类型对应枝干的枝干,而列表项又是由好友头像UI,好友名字UI,可能还有按钮UI这些叶子组成。因此,通过对UI界面进行解析,可以得到该UI界面的元素节点。
[0049] S12、根据所述待显示UI界面的元素节点创建与待显示UI界面对应的树形控件。
[0050] 本实施例中,树形控件中的每一元素节点配置有对应的元素数据结构,所述元素数据结构包括对应元素节点在树形控件中的绘制信息、位置信息和对应元素节点的父节点信息和子节点列表。其中,父节点信息可以为父节点句柄。元素结构可以看作是列表项。从数据层面看控件其实是一个列表,列表项是子项信息包括了渲染信息,如果现在子项添加其他UI控件,其实就是在子项信息中在添加一个列表,列表项信息就是你要添加的UI控件的渲染信息。当控件需要更新的时候记得遍历子项中的列表就可以实现了。这样一来子项中的UI就被称为子项的子项,也就是大家所认识的树型结构了。
[0051] S13、配置所述待显示UI界面的与所述树形控件对应的渲染列表。
[0052] 相应地,所述配置所述待显示UI界面的与所述树形控件对应的渲染列表,具体包括:确定所述树形控件中每一元素节点对应的元素数据结构的渲染信息;将各个元素数据结构的渲染信息进行组合,得到所述待显示UI界面的渲染列表。
[0053] S14、根据所述渲染列表,采用双缓冲技术对所述树形控件进行渲染。
[0054] 本发明实施例中,通过对待显示UI界面进行解析,得到所述待显示UI界面的元素节点,然后在MFC中创建一个CWnd原始控件,用来作为容器(或称为画板),然后通过CWnd控件的消息回调,如OnPain()窗口绘制消息,OnMouseMove()鼠标移动消息,OnLButtonDown()鼠标左键按下消息,OnLButtonUp()鼠标左键抬起,OnMouseWheel()鼠标滑轮消息,OnVScroll()拖放滚动条消息,OnMouseLeave()鼠标移出消息等,来绘制一个与待显示UI界面对应的树形控件,根据待显示UI界面的元素节点添加ROOT元素,具体实现如下:子项信息保存在原始父节点列表中,子项UI信息保存在子项列表中。设置回调函数,本实施例中,为了实现CWnd控件的消息回调,还包括设置消息回调函数的步骤。具体的,回调函数是通过BOOST库提供的函数绑定方法定义函数回调,然后用库提供的方法将外部的函数设置到内部中定义的回调函数值中,最后在控件内部调用回调,函数实现其实是在外部定义的。然后通过CScrollBar的Create方法创建滚动条,然后用SCROLLINFO结构体设置滚动条,最后通过OnVScroll()滚动条拖放消息使控件显示和滚动条高度保持一致。
[0055] 树形控件中的每一元素节点配置有对应的元素数据结构,该元素数据结构包含对应元素节点在树形控件中的绘制信息(文本图片等)、位置信息和对应元素节点的元素数据信息,如父节点信息和子节点列表等。
[0056] 元素数据结构的代码实现具体如下:
[0057]
[0058]
[0059] 最后定义控件的一些属性,如渲染列表将所有的元素添加到列表中,当前选中项元素句柄(元素结构内存地址),ROOT元素是指所有枝干叶子的最上层元素这里可以理解为控件本身,滚动条类型一般只垂直或水平显示等。
[0060] 本发明实施例提供的UI界面的显示处理方法,通过对待显示UI界面进行解析,得到待显示UI界面的元素节点,并根据待显示UI界面的元素节点创建待显示UI界面对应的树形控件,以根据与待显示UI界面的树形控件对应的渲染列表,采用双缓冲技术对该树形控件进行渲染,实现对待显示UI界面的高效渲染,提高复杂UI界面的显示速度和显示效果,进而提升用户的使用体验。此外,本发明实施例提供的UI界面的显示处理方法,通过对待显示UI界面进行解析,得到待显示UI界面的元素节点,进而可以灵活地实现基于元素节点的UI控件的扩展和更新。
[0061] 为了进一步体现发明的优越性,如下进一步揭示本发明UI界面的显示处理方法中步骤S14的细分步骤,来体现依据本步骤实现的另一实施例。参照图2,本步骤的细分步骤包括:
[0062] S141、采用双缓冲技术创建与所述树形控件对应的位图对象;
[0063] 操作流程具体如下,创建GDI双缓冲,首先通过CreateCompatibleDC方法创建一个临时DC,然后通过CreateCompatibleBitmap方法创建一个位图对象HBITMAP,最后通过SelectObject方法将HBITMAP选到临时DC中,这样就完成双缓冲创建。
[0064] S142、根据所述渲染列表中各元素节点在树形控件中的位置信息确定对应元素节点在所述位图对象中对应的待渲染区域;
[0065] S143、根据各元素节点在树形控件中的绘制信息对所述待渲染区域进行渲染;
[0066] S144、将渲染后的所述位图对象绘制到所述树形控件。
[0067] 本发明实施例中,具体通过以下方式实现控件的渲染:
[0068] OnPain消息回调:首先获取控件的大小,然后使用GDI+双缓冲技术定义一个与控件的大小相同的Bitmap,遍历渲染列表,根据每个列表项中的位置信息(即列表项对应的元素在Bitmap中的位置)计算当前开始渲染位置并保存渲染节点在列表中的迭代器,然后通过一个While循环从保存的迭代器继续遍历列表,每遍历一个列表项,将该列表项提供的信息渲染到双缓冲区的Bitmap中。最后,通过GDI+的DrawImage方法,把双缓冲区的Bitmap绘制到CWnd中。
[0069] InvalidateEx方法:刷新整个控件,通过调用Cwnd::Invalidate方法来实现,刷新逻辑在CWnd::OnPain消息回调中实现。
[0070] InvalidateItem方法:更新某一个节点,通过输入的节点句柄,遍历列表查找列表项,然后根据列表项的渲染信息进行绘制,并根据列表项的位置信息覆盖到失效的区域。
[0071] 本发明实施例中,使用高效的GID+双缓冲技术进行渲染,并通过将UI界面解析成对应的树形控件,从数据层面看控件其实就是一个列表,当更新和显示的时候可以只渲染用户感兴趣的子项,其他子项可以忽略。例如。当显示控件时,是从列表的第一项开始的,然后在渲染第二项…….,当超过控件的显示高度是可以停止了,同理当控件滚动或滑动时是一样的。本发明实施例解决了现有技术中在对复杂UI空间的界面进行显示时,出现的如闪烁或数据残留等现象的问题,达到了随着子节点的增加控件渲染效率不变的效果,提高用户观看体验。
[0072] 为了实现在控件子项中添加其他UI控件子项,在本发明的一个可选实施例中,所述方法还包括以下步骤:在接收到元素节点添加请求时,根据待添加元素节点的父节点信息查找对应的父元素节点,所述元素节点添加请求中包括有待添加元素节点的父节点信息;为所述待添加元素节点配置对应的待添加元素数据结构,将所述待添加元素数据结构添加在所述父元素节点中;将待添加元素数据结构的渲染信息添加到所述渲染列表中。本发明实施例可以通过在待添加元素节点配置对应的待添加元素数据结构,并通过在对应的父元素节点中添加待添加元素数据结构,实现在控件子项中添加其他UI控件子项的操作,而且本发明实施例提供的在控件子项中添加其他UI控件子项的实现方案中,UI控件子项的增加不会影响控件的渲染效率。
[0073] 在一个具体实施例中,创建子项可通过以下方式实现:1、通过文件,由于JSON格式的文件本来就是数据结构,本实施可以把列表子项的信息数据按照树型结构保存到文件中,当要显示控件时把JSON文件读取到一个列表中即可实现。2、动态添加,比较简单一般是按照一定的样式一条一条的往列表中添加。
[0074] 具体代码实现如下:
[0075] Addnode方法:根据传进来的父节点句柄查找对应的列表项,然后实例化NEW一个TreeItemInfo结构体添加到查询到的列表项的列表中,如果查询句柄为空直接添加到列表项尾部,最后还要把TreeItemInfo结构添加到渲染列表中。
[0076] AddNodeByList方法:跟Addnode大致一样,只是最后添加是从输入的列表完整添加到渲染列表中。
[0077] 为了实现对树形控件中的元素节点的更新,在本发明的一个可选实施例中,所述方法还包括以下步骤:在接收到元素节点更新请求时,根据待更新元素节点的节点信息查找对应的元素节点,所述元素节点更新请求中包括有待更新元素节点的节点信息和该元素节点在树形控件中的目标绘制信息;根据所述目标绘制信息对所述待更新元素节点对应的待渲染区域进行重新渲染。本发明实施例可以通过对待更新元素节点的节点信息和该元素节点在树形控件中的目标绘制信息进行更新,实现对待更新元素节点对应的待渲染区域的重新渲染。简单方便地实现UI控件子项的更新。
[0078] 此外,基于相同的原理,本发明实施例还能够实现在控件子项中设置不同的高度的操作。子项设置不同高度,其实就是对列表子项的位置信息的设置,当遍历渲染时只要渲染按照位置信息就可以实现每一个子项的高度都可以不同。本发明实施例能够实现复杂UI界面的快速设置和显示,进一步提升用户的使用体验。
[0079] 为了实现对树形控件中的元素节点的删除,在本发明的一个可选实施例中,所述方法还包括以下步骤:在接收到元素节点删除请求时,根据待删除元素节点的节点信息查找对应的元素节点,所述元素节点删除请求中包括有待删除元素节点的节点信息;删除该元素节点在树形控件中的目标绘制信息。本发明实施例通过删除元素节点在树形控件中的目标绘制信息的方式,实现元素节点的删除。在一个具体实施例中,删除子项可通过DeleteAllChild方法实现。具体的,DeleteAllChild方法:根据输入的节点句柄,遍历列表查找列表项并进行删除操作。
[0080] 在执行对树形控件中的元素节点的更新、删除以及在树形控件中的添加新的元素节点等操作后,需要对与所述树形控件对应的渲染列表进行相应操作,并根据更新后的渲染列表,采用双缓冲技术对所述树形控件进行重新渲染,以实现更新后的UI界面的显示。
[0081] 本发明实施例提供的UI界面的显示处理方法,在开发可视化UI程序时,可以把所可以看到的元素(例如文本,按钮,图片,面板等UI元素)看做一个元素节点或一个列表项,然后把所有的这些元素构建到树型结构中来,例如把主界面看做主干,由主干在分成许多面板枝干,在每个枝干由许多元素(按钮,图片等)来组成,类似枝干的树叶。其中有些复杂的枝干面板又可以由许多面板或元素组成。由此将一个复杂的UI界面构造成一个树型的数据结构。该树型结构,是一个数据信息结构,存在于内存也可以理解为一个字符串,由于最终是想得到一个可视化界面,这样就必须遍历树结构中的所有元素(列表项),通过元素中绘制信息使用GDI+双缓冲技术或其他绘制技术将元素绘制出来,即得到一个复杂的可视化界面。
[0082] 对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。
[0083] 图3示意性示出了本发明一个实施例的UI界面的显示处理装置的结构示意图。参照图3,本发明实施例的UI界面的显示处理装置具体包括解析模块301、生成模块302、配置模块303以及显示模块304,其中:所述的解析模块301,用于解析待显示UI界面,得到所述待显示UI界面的元素节点;所述的生成模块302,用于根据所述待显示UI界面的元素节点创建与待显示UI界面对应的树形控件;所述的配置模块303,用于配置所述待显示UI界面的与所述树形控件对应的渲染列表;所述的显示模块304,用于根据所述渲染列表,采用双缓冲技术对所述树形控件进行渲染。
[0084] 在本发明实施例中,所述树形控件中的每一元素节点配置有对应的元素数据结构,所述元素数据结构包括对应元素节点在树形控件中的绘制信息、位置信息和对应元素节点的父节点信息和子节点列表。
[0085] 进一步地,所述配置模块303,具体用于确定所述树形控件中每一元素节点对应的元素数据结构的渲染信息;将各个元素数据结构的渲染信息进行组合,得到所述待显示UI界面的渲染列表。
[0086] 为了进一步体现发明的优越性,如下进一步揭示本发明UI界面的显示处理装置中显示模块304的内部结构图,来体现依据本步骤实现的另一实施例。参照图4,本实施例中的显示模块304,具体包括:创建单元3041、确定单元3042、渲染单元3043以及显示单元3044,其中:所述的创建单元3041,用于采用双缓冲技术创建与所述树形控件对应的位图对象;所述的确定单元3042,用于根据所述渲染列表中各元素节点在树形控件中的位置信息确定对应元素节点在所述位图对象中对应的待渲染区域;所述的渲染单元3043,用于根据各元素节点在树形控件中的绘制信息对所述待渲染区域进行渲染;所述的显示单元3044,用于将渲染后的所述位图对象绘制到所述树形控件。
[0087] 本发明实施例中,所述装置还包括附图中未示出的子项添加模块,所述的子项添加模块,用于在接收到元素节点添加请求时,根据待添加元素节点的父节点信息查找对应的父元素节点,所述元素节点添加请求中包括有待添加元素节点的父节点信息;为所述待添加元素节点配置对应的待添加元素数据结构,将所述待添加元素数据结构添加在所述父元素节点中;将待添加元素数据结构的渲染信息添加到所述渲染列表中。本发明实施例中,子项添加模块可以通过在待添加元素节点配置对应的待添加元素数据结构,并通过在对应的父元素节点中添加待添加元素数据结构,实现在控件子项中添加其他UI控件子项的操作,而且本发明实施例提供的在控件子项中添加其他UI控件子项的实现方案中,UI控件子项的增加不会影响控件的渲染效率。
[0088] 本发明实施例中,所述装置还包括附图中未示出的子项更新模块,所述的子项更新模块,用于在接收到元素节点更新请求时,根据待更新元素节点的节点信息查找对应的元素节点,所述元素节点更新请求中包括有待更新元素节点的节点信息和该元素节点在树形控件中的目标绘制信息;根据所述目标绘制信息对所述待更新元素节点对应的待渲染区域进行重新渲染。本发明实施例中,子项更新模块可以通过对待更新元素节点的节点信息和该元素节点在树形控件中的目标绘制信息进行更新,实现对待更新元素节点对应的待渲染区域的重新渲染。简单方便地实现UI控件子项的更新。
[0089] 此外,基于相同的原理,所述子项更新模块,还能够实现在控件子项中设置不同的高度的操作。本发明实施例能够实现复杂UI界面的快速设置和显示,进一步提升用户的使用体验。
[0090] 本发明实施例中,所述装置还包括附图中未示出的子项删除模块,所述的子项删除模块,用于在接收到元素节点删除请求时,根据待删除元素节点的节点信息查找对应的元素节点,所述元素节点删除请求中包括有待删除元素节点的节点信息;删除该元素节点在树形控件中的目标绘制信息。本发明实施例通过删除元素节点在树形控件中的目标绘制信息的方式,实现元素节点的删除。
[0091] 对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
[0092] 本发明实施例提供的UI界面的显示处理方法及装置,通过对待显示UI界面进行解析,得到待显示UI界面的元素节点,并根据待显示UI界面的元素节点创建待显示UI界面对应的树形控件,以根据与待显示UI界面的树形控件对应的渲染列表,采用双缓冲技术对该树形控件进行渲染,实现对待显示UI界面的高效渲染,提高复杂UI界面的显示速度和显示效果,进而提升用户的使用体验。此外,本发明实施例提供的UI界面的显示处理方法,通过对待显示UI界面进行解析,得到待显示UI界面的元素节点,进而可以灵活地实现基于元素节点的UI控件的扩展和更新。
[0093] 以上所描述的装置实施例仅仅是示意性的,其中所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。本领域普通技术人员在不付出创造性的劳动的情况下,即可以理解并实施。
[0094] 通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到各实施方式可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件。基于这样的理解,上述技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在计算机可读存储介质中,如ROM/RAM、磁碟、光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行各个实施例或者实施例的某些部分所述的方法。
[0095] 此外,本领域的技术人员能够理解,尽管在此的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
[0096] 最后应说明的是:以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。