著录项信息
专利名称 | 一种嵌入式多窗口应用图形并行更新方法 |
申请号 | CN201210034661.7 | 申请日期 | 2012-02-16 |
法律状态 | 权利终止 | 申报国家 | 中国 |
公开/公告日 | 2012-07-25 | 公开/公告号 | CN102609229A |
优先权 | 暂无 | 优先权号 | 暂无 |
主分类号 | G06F3/14 | IPC分类号 | G;0;6;F;3;/;1;4;;;G;0;6;F;9;/;3;8查看分类表>
|
申请人 | 中国科学院声学研究所 | 申请人地址 | 北京市海淀区北四环西路21号
变更
专利地址、主体等相关变化,请及时变更,防止失效 |
权利人 | 中国科学院声学研究所 | 当前权利人 | 中国科学院声学研究所 |
发明人 | 朱小勇;姜艳;孙鹏 |
代理机构 | 北京亿腾知识产权代理事务所 | 代理人 | 陈霁 |
摘要
本发明公开了一种针对多窗口应用的图形并行更新方法,该方法包括:根据应用的窗口信息将整个屏幕区域划分为多个子区域,并计算所述子区域的重叠度;当更新应用窗口时,根据所述子区域的重叠度信息分步更新所述应用窗口对应子区域的内容。本发明减少了应用间窗口更新所需的时间,提高了系统的并行处理能力。
1.一种嵌入式多窗口应用图形并行更新方法,其特征在于,该方法包括:
根据应用的窗口信息将整个屏幕区域划分为多个子区域,并计算所述子区域的重叠度;
当更新应用窗口时,根据所述子区域的重叠度信息分步更新所述应用窗口对应子区域的内容;
所述根据应用的窗口信息将整个屏幕区域划分为多个子区域的步骤包括:
在所有窗口中计算两两窗口之间的重叠区域,构成第一子窗口集合;
在所述第一子窗口集合中,进一步计算子窗口两两之间的重叠区域,构成第二子窗口集合,直至所述子窗口集合的空间大小为1或0;
根据所述子窗口集合划分屏幕子区域;
在所述根据所述子区域的重叠度信息分步更新所述应用窗口对应子区域的内容的步骤中优先选择空闲且重叠度高的子区域进行更新,并对更新过的子区域进行标识。
2.根据权利要求1所述的方法,其特征在于,所述重叠度是指所述子区域所覆盖的应用窗口数目。
3.根据权利要求1所述的方法,其特征在于,所述窗口信息包括窗口的位置和/或窗口的大小。
4.根据权利要求1所述的方法,其特征在于,当所述子区域的 重叠度为一时,则直接更新所述子区域;当所述子区域的重叠度大于一时,则通过加锁的方式来更新所述子区域。
5.根据权利要求1所述的方法,其特征在于,所述子区域通过位图来表示。
6.根据权利要求5所述的方法,其特征在于,该方法根据所述位图搜索需要更新的子区域。
7.根据权利要求5所述的方法,其特征在于,所述子区域的重叠度按大小排序,所述重叠度大的优先更新。
8.根据权利要求1所述的方法,其特征在于,当有应用加入或退出时,则重新划分并计算屏幕子区域信息。
一种嵌入式多窗口应用图形并行更新方法\n技术领域\n[0001] 本发明涉及嵌入式技术领域,特别涉及一种嵌入式多窗口应用图形并行更新方法。\n背景技术\n[0002] 随着嵌入式与多媒体技术的快速发展,电视终端正由传统的娱乐中心转向集公共广播、信息服务、文化娱乐、交流互动于一体的家庭多媒体信息平台,多应用的盛行促使电视终端图形系统必须支持多窗口并行显示技术。特别是一些如游戏、信息类应用,需要频繁地对屏幕显示进行更新操作。另外,不同于手机、PDA等低分辨率设备,电视终端的图形分辨率较高,多为1280x720、1920x1080。为满足多窗口并行显示、频繁刷新和高分辨率的需求,必须对嵌入式电视终端有限的图形处理性能进行优化。\n[0003] 在现有技术中,当应用更新窗口时,首先锁定整个屏幕区域,然后更新窗口内容,最后释放锁定。这种方法没有考虑窗口位置和大小信息,当一个应用锁定整个屏幕时,其他应用无法对屏幕进行操作。但是,在多窗口应用下,并不是所有的应用窗口都覆盖整个屏幕,有可能两个应用的窗口在屏幕上没有相交部分,没有必要分别锁定、更新。这种方法没有考虑窗口信息而盲目锁定整个屏幕,导致其他应用更新阻塞,增大了等待时间,降低了系统的并行性。\n发明内容\n[0004] 本发明的目的是解决上述现有技术所存在的问题。\n[0005] 为实现上述目的,本发明提供了一种多窗口应用的图形并行更新方法,该方法包括:根据应用的窗口信息将整个屏幕区域划分为多个子区域,并计算所述子区域的重叠度(degree of overlap);当更新应用窗口时,根据所述子区域的重叠度信息分步更新所述应用窗口对应子区域的内容。\n[0006] 根据本发明的方法,可以减少应用间窗口更新所需的时间,进一步提高了系统的并行处理能力。\n附图说明\n[0007] 图1是本发明实施例多窗口应用的图形并行更新方法的流程图;\n[0008] 图2是本发明实施例多窗口应用的图形并行更新方法的屏幕划分流程图;\n[0009] 图3是本发明实施例多窗口应用示例图;\n[0010] 图4是本发明实施例应用窗口更新流程图。\n具体实施方式\n[0011] 下面通过附图和实施例,对本发明的技术方案做进一步的详细描述。\n[0012] 图1是本发明实施例多窗口应用的图形并行更新方法的流程图。如图所示,该方法包括步骤101-102:\n[0013] 在步骤101,根据多个应用的窗口信息将整个屏幕区域划分为多个子区域,并计算所述子区域的重叠度。\n[0014] 具体地,嵌入式电视终端设备在多个应用加入时,根据所有应用的窗口信息,例如窗口位置和窗口大小信息将整个显示屏幕区域划分为多个子区域,并计算上述多个子区域的重叠度信息。上述重叠度是指多个子区域中的其中一个子区域所覆盖的应用窗口数目。\n另外,当有新的应用加入或退出时,则重新划分并计算屏幕的子区域信息。\n[0015] 以下针对子区域的重叠度进行定义:假设有n个应用,分别对应于n个窗口w1,(1) (1)\nw2,……,wn,记集合W ={w1,w2,…,wn}。对于屏幕上任意子区间V,集合W 中存在l个应用窗口wi1,wi2,……,wil覆盖区间V,则称l为区间V的重叠度。\n[0016] 以下结合图2,针对上述屏幕区域划分的具体算法进行描述:如图2所示,在步骤(K) (K)\n200,设W 为所有应用窗口构成的集合,其中K=1。在步骤201,根据窗口集合W 中各\n窗口两两之间的关系,若两者之间存在重叠区域,则计算出任意两个区间的重叠区域,重叠(K+1) (k+1) (K+1)\n区域构成的集合记为W ,W ={wij|wij∈wi,wij∈wj}。在步骤202,判断集合W 中\n的窗口个数是否大小1。如果是,则执行步骤210,令K=k+1,返回到步骤201;如果不是,(K+2) (K+3)\n则执行步骤203。以此类推,继续计算W 、W 、……中的重叠区域,直至为空。在步骤(K) (K+1)\n203,根据窗口集合W 、W ,……,将整个屏幕区域进行划分。\n[0017] 在实际应用情况下,由于多个应用的窗口之间的重叠度不会太大,因此递推次数(1) (2) (l)\n有限。假设最终的重叠度最大值为l,即通过以上的方法共得到l个集合{W ,W ,…W }。\n(l) (l-1) (l)\n不难看出,W 中的所有区域的任意子区间的重叠度均为l。由于集合W 中包含了W ,\n(l-1) (l)\n因此其任意子区间的重叠度为l或l-1,但W -W 的子区间的重叠度为l-1。假设集合\n(i)\nU 中的区间个数为Ci,屏幕被划分的区域包括:\n[0018] 重叠度为l的集合U(l)中区间个数为Cl,U(l)=W(l);\n[0019] 重叠度为m的集合U(m)中区间个数为Cm,U(m)计算如下:\n[0020] 其中wi(m)∈W(m),wij(m+1)∈ wi(m),\n(m+2) (m+1)\nwijk ∈wij ,…;\n[0021] 重叠度为1的集合U(1)中区间个数为C1,U(1)计算如下:\n(1) (2) (3) (2)\n[0022] 其中wi∈W ,wij ∈wi,wijk ∈wij …;\n最终整个屏幕将被划分为 个区间,其集合形式可表示为\n[0023] 在一个例子中,以一个四元级(x1,y1,x2,y2)表征一个窗口参数,其中(x1,y1)为窗口左上角坐标,(x2,y2)为窗口右下角坐标,选取屏幕左上角为坐标原点。任意两个窗口(xi1,yi1,xi2,yi2)和(xj1,yj1,xj2,yj2),当窗口坐标满足关系式max(xi1,xj1)<min(xi2,xj2)且max(yi1,yj1)<min(yi2,yj2)时,存在重叠部分,重叠窗口的坐标为(max(xi1,xj1),max(yi1,yj1),min(xi2,xj2),min(yi2,yj2))。\n[0024] 以下结合图3,阐述多窗口应用的具体实例。如图3所示,共有4个窗口应用,其整个屏幕的图形分辨率为1280x720。其中,w1为全屏的应用,窗口坐标为(0,0,1280,720),即包括区域U1、U2、U3和U4;w2应用占据屏幕的左半边,坐标参数为(0,0,640,720),即包括区域U1、U2和U3;w3应用占据w2的下半部分,坐标参数为(0,360,640,720),即包括区域U1和U2;w4应用占据w3的右半部分,坐标参数为(320,360,640,720),即区域U1。\n[0025] 根据我们的屏幕划分方法,可分为以下几个步骤:步骤一,在应用窗口集合w(1)中(2)\n找出两两窗口重叠部分,构成集合w ,共有6个窗口,包括w1,2(0,0,640,720),w1,3(0,360,\n640,720),w1,4(320,360,640,720),w2,3(0,360,640,720),w2,4(320,360,640,720) 和 w3,\n4(320,360,640,720),其中wi,j指第i个窗口和第j个窗口的重叠区域;步骤二,继续在应(2) (3)\n用窗口集合w 中找出两两窗口重叠部分,构成集合w ,包括3个窗口w1,2,3(0,360,360,(3)\n720),w1,2,4(320,360,640,720),w1,3,4(320,360,640,720);步骤三,继续在应用窗口集合w(4)\n中找出两两窗口重叠部分,构成集合w ,包括1个窗口w1,2,3,4(320,360,640,720)。因此得到划分屏幕的子区域集合,该子区域集合包括:一个重叠度为4的窗口u1,坐标为(320,\n360,640,720);一个重叠度为3的窗口u2,坐标为(0,360,320,720);一个重叠度为2的窗口u3,坐标为(0,0,640,360);一个重叠度为1的窗口u4,坐标为(640,0,1280,720)。\n[0026] 在步骤102,当更新应用窗口时,根据所述子区域的重叠度信息分步更新所述应用窗口对应子区域的内容。当需要被更新的子区域的重叠度为一时,表明该子区域只被一个应用所使用,可直接更新该子区域;当子区域的重叠度大于一时,则通过加锁的方式来更新该子区域,以保证该子区域间多应用的互斥访问。\n[0027] 本发明实施例子区域分步更新的方法包括以下步骤:1、首先确定窗口需要更新的所有屏幕子区域;2、在所需要更新的区域中优先选择空闲且重叠度高的子区域进行更新,并对更新过的子区域进行标识;3、继续按步骤2的方法更新未更新的子区域,直到所有子区域更新完毕。\n[0028] 在一个实施例中,每个应用通过使用一个位图来表示各自窗口需要更新的子区域,置位表示该子区域包含在该应用窗口中。例如,应用1的位图为(1,1,1,1),表明该应用\n1的窗口覆盖了u1、u2、u3、u4。依次类推应用2的位图为(1,1,1,0),应用3的位图为(1,1,\n0,0),应用4的位图为(1,0,0,0)。\n[0029] 下面结合图4,以更新应用1窗口为例说明分布更新的方法,如图4所示,该方法包括步骤401-406:\n[0030] 在步骤401,获取应用1窗口对应的位图。图4所示的应用1窗口的位图为(1,1,\n1,1),表明该应用1的窗口覆盖了u1、u2、u3、u4。\n[0031] 在步骤402,根据子区域位图搜索可更新的子区域。\n[0032] 具体地,根据应用1的位图(1,1,1,1)搜索需要更新且未被其他应用占用的子区域。子区域的重叠度按大小排序,位图顺序对应的子区域的重叠度从大到小依次排列。由于重叠度越大的子区域越容易发生更新冲突,因此根据应用位图从头搜索可以优先保证重叠度大的且空闲的子区域被更新,进一步降低冲突的可能性。\n[0033] 在步骤403,根据步骤402搜索结果更新应用1对应的子区域。\n[0034] 在步骤404,将更新后的子区域在位图中的对应位清零。\n[0035] 在一例子中,假设应用4所对应的子区域U4正被其他应用所占用,则只更新应用\n1所覆盖的子区域U1、U2和U3,更新后的应用1位图为(0,0,0,1),即将原位图(1,1,1,1)中子区域U1、U2和U3对应的二进制“1”清零。\n[0036] 在步骤405,判断位图是否有标志位被置位,即位图中子区域所对应的二进制是“1”。若有,则说明仍有未被更新的子区域,转向步骤402,否则转向步骤406。\n[0037] 在步骤406,更新完成。\n[0038] 本发明实施例将整个屏幕根据重叠度进行分割,使得多窗口应用能够尽可能并行更新窗口,提高了系统的并行性。另外,由于在更新应用窗口时根据重叠度的高低进行子区域的更新,进一步地降低应用间更新窗口冲突的可能性,减少了窗口更新所需的时间。\n[0039] 以上所述的具体实施方式,对本发明的目的、技术方案和有益效果进行了进一步详细说明,所应理解的是,以上所述仅为本发明的具体实施方式而已,并不用于限定本发明的保护范围,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
法律信息
- 2021-01-29
未缴年费专利权终止
IPC(主分类): G06F 3/14
专利号: ZL 201210034661.7
申请日: 2012.02.16
授权公告日: 2014.12.31
- 2014-12-31
- 2012-09-26
实质审查的生效
IPC(主分类): G06F 3/14
专利申请号: 201210034661.7
申请日: 2012.02.16
- 2012-07-25
引用专利(该专利引用了哪些专利)
序号 | 公开(公告)号 | 公开(公告)日 | 申请日 | 专利名称 | 申请人 |
1
| |
2008-11-12
|
2008-07-08
| | |
2
| |
2009-01-07
|
2008-07-03
| | |
3
| |
2009-03-04
|
2007-02-09
| | |
4
| |
2009-05-27
|
2007-04-24
| | |
被引用专利(该专利被哪些专利引用)
序号 | 公开(公告)号 | 公开(公告)日 | 申请日 | 专利名称 | 申请人 | 该专利没有被任何外部专利所引用! |