WO2016015527A1 - 基于合成渲染加速的网页更新方法和装置 - Google Patents

基于合成渲染加速的网页更新方法和装置 Download PDF

Info

Publication number
WO2016015527A1
WO2016015527A1 PCT/CN2015/081940 CN2015081940W WO2016015527A1 WO 2016015527 A1 WO2016015527 A1 WO 2016015527A1 CN 2015081940 W CN2015081940 W CN 2015081940W WO 2016015527 A1 WO2016015527 A1 WO 2016015527A1
Authority
WO
WIPO (PCT)
Prior art keywords
webpage
snapshot
attribute
layer
thread
Prior art date
Application number
PCT/CN2015/081940
Other languages
English (en)
French (fr)
Inventor
易旭昕
Original Assignee
优视科技有限公司
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 优视科技有限公司 filed Critical 优视科技有限公司
Publication of WO2016015527A1 publication Critical patent/WO2016015527A1/zh

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor

Definitions

  • the present invention relates to the field of web page rendering technologies, and in particular, to a web page updating method and apparatus based on synthetic rendering acceleration.
  • browsers generally adopt a multi-threaded rendering acceleration architecture to take full advantage of the hardware performance of a multi-core CPU (Central Processing Unit) and a GPU (Graphic Processing Unit), and avoid the UI (User Interface, User interface) Thread blocking causes user operations to be unsmooth.
  • synthetic rendering acceleration is to use more rendering acceleration architecture to improve rendering performance by dividing web pages into multiple layers.
  • the browser groups all the web page elements according to a predetermined rule, and belongs to a specific layer, and all the layers are organized into a layer tree in a tree structure, and the web page snapshot is composed of layers. The tree is composed.
  • the layer consists of two parts: content and attributes.
  • the layer content is a drawing description of all the web page elements that are subordinate to the layer.
  • the layer attribute corresponds to some CSS (Cascading Style Sheets) attributes of the web page elements it contains.
  • CSS CSS Style Sheets
  • the page element layer grouping rules guarantee the values of all webpage elements belonging to the same layer on these CSS attributes. The same is true, so the value of an attribute of a layer comes from the value of the CSS attribute corresponding to the layer attribute of the page element belonging to it.
  • the layer's CSS Transform property, CSS Animation property, and CSS Opacity property map to these CSS properties of the page elements contained in the layer.
  • the rendering acceleration engine under the synthetic rendering acceleration architecture usually consists of two main threads: the kernel thread and the composition thread.
  • the kernel thread is mainly responsible for the analysis of HTML (HyperText Markup language) and CSS scripts, the execution of JavaScript dynamic code, and the layout of web pages.
  • the kernel thread holds a snapshot of the current web page and updates it after each re-layout. Webpage snapshot, And copy the updated snapshot to the synthetic thread.
  • the compositing thread is responsible for pre-rendering the snapshot of the web page received from the kernel thread, the pre-rendering is to rasterize the content of each layer (the drawing description) into pixels and store it in the cache, and then the synthetic thread is then pre-rendered according to the pre-rendering
  • the attribute of the pixel buffer and the layer is synthesized into a frame buffer (frame buffer) of the current display window.
  • the display controller reads the frame buffer to render the web page to the screen.
  • the web page dynamically changes the CSS properties of the web page elements through the JavaScript code at runtime.
  • Some of the CSS properties correspond to the layer properties of the layer to which the web page element belongs, such as CSS Transform property, CSS Animation property and CSS Opacity property. Changes to these attributes do not cause changes in the content of the elements, which means that they do not affect how the elements are pre-drawn.
  • the kernel thread In the existing synthetic rendering acceleration architecture, after the webpage is loaded and the first typesetting and pre-rendering are completed, when the content and attributes of the layer change and the webpage needs to be updated, the kernel thread must re-type the new webpage snapshot and copy. The new web page snapshot is sent to the composition thread, and the composition thread re-processes the pre-rendering and other processing steps.
  • the layer attribute corresponding to the CSS attribute of the webpage element part only affects the display of the layer content, has no influence on the webpage layout, and does not affect the result of the layer rasterization.
  • the above-mentioned webpage update process needs to be re-typed and re-rendered. It will occupy a lot of system resources, resulting in low update efficiency and speed. Due to the low efficiency and speed of web page update, the frame rate of web page dynamic effect display is low, and web page dynamic display performance is not good.
  • the application provides a webpage updating method and apparatus based on synthetic rendering acceleration.
  • a method for updating a webpage based on synthetic rendering acceleration including:
  • the kernel thread updates the attribute of the layer of the webpage element in the source webpage snapshot, and the source webpage snapshot is in the kernel thread.
  • Current web page snapshot
  • the kernel thread sends a synchronization update request to the composition thread
  • the synthesizing thread After receiving the synchronization update request, the synthesizing thread synchronously updates the attribute of the corresponding layer in the current webpage snapshot in the synthetic thread according to the attribute of the layer in the updated source webpage snapshot.
  • the change of the cascading style sheet attribute corresponding to the layer attribute is independent of the network. Changes in the content of page elements.
  • the cascading style sheet attributes include a cascading style sheet geometric transformation attribute, a cascading style sheet animation attribute, and a cascading style sheet opacity attribute.
  • the updating according to the attribute of the layer in the updated source webpage snapshot, the attribute of the corresponding layer in the current webpage snapshot, including:
  • the updating according to the attribute of the layer in the updated source webpage snapshot, the attribute of the corresponding layer in the current webpage snapshot in the synthetic thread, including:
  • the webpage updating method based on the synthetic rendering acceleration, after synchronously updating the cascading style sheet attributes of the corresponding layer in the current webpage snapshot in the synthetic thread according to the cascading style sheet attribute of the layer in the source webpage snapshot include:
  • the synthesizing thread generates a webpage cache according to the synthesizing operation of the updated current webpage snapshot.
  • a webpage updating apparatus based on synthetic rendering acceleration including:
  • Kernel thread snapshot update module for kernel thread updates in kernel threads when the JavaScript dynamic code changes the cascading style sheet properties of the web page element corresponding to the layer properties The attribute of the layer of the webpage element in the source webpage snapshot, where the source webpage snapshot is the current webpage snapshot in the kernel thread;
  • a kernel thread request sending module configured to send a synchronization update request message to the synthesizing thread in the kernel thread
  • a synthetic thread request receiving module for receiving the synchronization update request in the synthesis thread
  • a synthetic thread snapshot update module configured to synchronously update, in the synthesizing thread, an attribute of a corresponding layer in a current webpage snapshot in the synthetic thread according to an attribute of a layer in the source webpage snapshot.
  • the synthetic thread snapshot update module includes:
  • a kernel thread access module for accessing the kernel thread
  • a layer comparison submodule configured to compare, by the kernel thread access module, each layer of a current webpage snapshot in the composite thread with each corresponding layer of the updated source webpage snapshot;
  • a first determining sub-module configured to determine whether an attribute of each layer in the current webpage snapshot in the synthetic thread is the same as an attribute of each corresponding layer in the updated source webpage snapshot
  • a first update submodule configured to: when a layer of the current webpage snapshot in the synthetic thread has a different layer from a corresponding layer in the updated source webpage snapshot, set the attribute of the layer and the The properties of the corresponding layer in the updated source page snapshot are the same.
  • the synthetic thread snapshot update module includes:
  • a kernel thread access module for accessing the kernel thread
  • a first search submodule configured to search for a webpage element in which at least one of a cascading style sheet geometric transformation attribute, a cascading style sheet animation attribute, and a cascading style sheet opacity attribute is set in a current webpage snapshot in the synthetic thread;
  • a second search submodule configured to search, by accessing the kernel thread module, a webpage element in which at least one of a cascading style sheet geometric transformation attribute, a cascading style sheet animation attribute, and a cascading style sheet opacity attribute is set in the source webpage snapshot;
  • An element attribute comparison module configured to compare a cascading style sheet attribute of the webpage element found by the first search submodule and a cascading style sheet attribute of the webpage element found by the second search submodule; and a second judgment submodule for the element based
  • the attribute comparison module determines whether the cascading style sheet attributes of the two compared web page elements are the same;
  • a second update submodule configured to: according to the judgment result of the second determining submodule, when there is a cascading style sheet geometric transformation attribute, a cascading style sheet animation attribute, or a cascading style sheet opacity attribute in the current webpage snapshot in the synthetic thread a webpage element, setting an attribute of a layer of the webpage element in the current webpage snapshot in the synthetic thread and a cascading style sheet geometric transformation attribute, a cascading style sheet animation attribute, and a cascading style sheet of a corresponding webpage element in the source webpage snapshot
  • the opacity property is the same.
  • the webpage updating device based on the synthetic rendering acceleration further includes:
  • a synthesizing module configured to generate a webpage cache according to the synthesizing operation of the updated current webpage snapshot in the synthesizing thread.
  • the technical solution provided by the embodiment of the present application establishes a mechanism for synchronous update between a webpage snapshot of a synthetic thread and a webpage snapshot of a kernel thread.
  • the kernel thread When the browser runs the JavaScript dynamic code to change the cascading style sheet attribute corresponding to the layer attribute of the webpage element, the kernel thread only updates the attribute of the layer of the webpage element in the current webpage snapshot accordingly, and the synthetic thread Send a sync update request.
  • the compositing thread updates the attribute of the corresponding layer in the current webpage snapshot in the compositing thread according to the updated webpage snapshot of the kernel thread, and then performs the compositing operation according to the updated current webpage snapshot, that is, the merging thread can complete the synchronization operation. Update of the webpage.
  • the technical solution provided by the embodiment of the present application may include the following beneficial effects: avoiding re-typesetting of the kernel thread and copying of the webpage snapshot, and avoiding the pre-rendering step of the synthetic thread, and improving the processing efficiency and speed of the browser webpage update.
  • the update efficiency and speed are accelerated, which may increase the frame rate of the webpage dynamic effect display, thereby improving the dynamic display performance of the webpage.
  • FIG. 1 is a schematic diagram of a synthetic rendering acceleration based webpage according to an exemplary embodiment of the present application. Schematic diagram of the new method
  • FIG. 2 is a block diagram of a webpage updating apparatus based on synthetic rendering acceleration according to an exemplary embodiment of the present application
  • FIG. 3 is a block diagram of a synthetic rendering acceleration based webpage updating apparatus according to another exemplary embodiment of the present application.
  • FIG. 1 is a schematic flowchart diagram of a method for updating a webpage based on synthetic rendering acceleration according to an exemplary embodiment of the present application. As shown in FIG. 1, the method includes steps S101 to S103.
  • step S101 when the JavaScript dynamic code changes the CSS attribute of the webpage element corresponding to the layer attribute, the kernel thread updates the attribute of the layer corresponding to the webpage element in the source webpage snapshot.
  • the source webpage snapshot may be a current webpage snapshot in the kernel thread
  • the CSS attribute corresponding to the layer attribute includes a CSS Transform attribute, a CSS Animation attribute, and a CSS Opacity attribute, and the change is independent of the change of the content of the webpage element.
  • changes to these properties do not result in changes to the content of the page elements, and do not affect the pre-rendering of page elements.
  • the kernel thread Update the attributes of the corresponding layer in the source web page snapshot according to the CSS attribute of the changed web page element, and the CSS attribute includes CSS Transform property, CSS Animation property, and CSS Opacity property.
  • the corresponding layer is a layer of the changed webpage element in the webpage snapshot; updating the attribute of the layer corresponding to the webpage element in the source webpage snapshot may include: setting the attribute of the corresponding layer in the webpage snapshot and The CSS property of the webpage element corresponding to the dynamic code change of the JavaScript is the same.
  • the corresponding CSS Transform property of the layer where the webpage element is located is updated, and so on.
  • the layer grouping rule of the browser ensures that the CSS attributes corresponding to the layer attributes are the same among all the webpage elements belonging to the same layer, and the layer attributes are the same as the CSS attributes corresponding to the layer attributes of the webpage elements belonging to it.
  • the kernel thread finds the layer where the webpage element is located in the webpage snapshot, and sets the CSS of the layer attribute corresponding to the layer attribute changed by the webpage element.
  • the properties are the same, updating the layer properties and updating the page snapshot accordingly.
  • the source web page snapshot is the updated current web page snapshot.
  • step S101 only needs to update the attribute of the layer in which the changed webpage element is located in the webpage snapshot, and does not need to re-type the entire webpage to generate a new webpage snapshot, omitting the typesetting step. Saves thread processing resources.
  • step S102 the kernel thread sends a synchronization update request to the synthesis thread.
  • the kernel thread may use a message passing manner in thread communication to generate a synchronous update request to the synthesizing thread.
  • step S103 after receiving the synchronization update request, the synthesizing thread synchronously updates the attribute of the corresponding layer in the current webpage snapshot of the synthetic thread according to the attribute of the layer in the source webpage snapshot.
  • updating the attribute of the corresponding layer in the current webpage snapshot according to the attribute of the layer in the source webpage snapshot may include: the synthesizing thread accesses the kernel thread, and traverses each layer and the source webpage of the current webpage snapshot in the synthesizing thread.
  • Each corresponding layer in the snapshot compares each layer of the current page snapshot in the composition thread with each layer in the source page snapshot in the kernel thread.
  • the attributes of the corresponding layer in the snapshot are different, the attributes of the layer in the composition thread are set to be the same as the attributes of the corresponding layer in the source web page snapshot.
  • the current webpage snapshot in the synthesizing thread is a snapshot of the webpage held by the synthesizing thread after the first pre-rendering. Since the pre-rendering is performed only for the layer content, the change of the layer attribute does not affect the result of the layer pre-rendering. (Pre-draw the generated pixel cache). After the synthesizing thread receives the synchronous update request sent by the kernel thread, the layer content of the current web page snapshot is kept unchanged, and only the layer attribute of the current web page snapshot in the synthetic thread is updated. Then, according to the pre-rendered result and the updated layer attribute that have been generated, the webpage cache is updated to achieve the purpose of webpage update.
  • the synthetic thread access kernel thread can use the way of data sharing between threads, that is, the kernel thread shares its current web page snapshot for the synthetic thread to access.
  • updating the attribute of the corresponding layer in the current webpage snapshot of the synthetic thread according to the attribute of the corresponding layer in the source webpage snapshot may further include: comparing the current webpage snapshot of the synthetic thread with the layer attribute corresponding to the layer attribute
  • the webpage element of the CSS attribute is corresponding to the webpage element of the CSS attribute corresponding to the layer attribute corresponding to the layer webpage snapshot, and if the CSS attribute corresponding to the layer attribute in the two webpage elements participating in the comparison is different, the setting is performed.
  • the attribute of the layer where the webpage element is located is the same as the CSS attribute corresponding to the layer attribute of the corresponding webpage element in the source webpage snapshot. If the CSS attribute corresponding to the layer attribute of the two webpage elements participating in the comparison is the same, the update is not performed.
  • Synchronizing the attributes of the corresponding layer in the current web page snapshot of the synthetic thread according to the attributes of the corresponding layer in the source web page snapshot may further include: comparing the current web page snapshot in the composition thread with the CSS Transform attribute, the CSS Animation attribute, and the CSS Opacity attribute. At least one of the webpage elements and the webpage element corresponding to at least one of the CSS Transform property, the CSS Animation property, and the CSS Opacity property corresponding to the source webpage snapshot are different when there is a CSS Transform property, a CSS Animation property, or a CSS Opacity property.
  • the webpage element, that is, the property of the layer where the webpage element is located is the same as the CSS Transform property, the CSS Animation property, and the CSS Opacity property of the corresponding webpage element in the source webpage snapshot.
  • the layer's properties may be empty.
  • the proportion of layers with empty attributes is very high. Therefore, instead of comparing each layer, you can compare the current web page snapshot of the synthetic thread with the source web page snapshot. The web page element of the CSS property corresponding to the layer property.
  • the usual layer properties are CSS Transform property, CSS Animation property, and CSS Opacity property
  • the synthesizing thread After the synthesizing thread updates its current web page snapshot, the synthesizing thread performs a synthesizing operation according to the layer attribute of the current web page snapshot and the pre-rendered pixel buffer, and generates a webpage cache output to the frame buffer to complete the webpage update.
  • the webpage updating method based on the synthetic rendering acceleration provided by the embodiment of the present application, when the CSS attribute corresponding to the layer attribute in the webpage element is changed by the JavaScript dynamic code, the kernel thread only needs to update the webpage element in the current webpage snapshot of the kernel thread.
  • the properties of the layer no need to re-type.
  • the compositing thread only needs to update the attributes of the corresponding layer of the current web page snapshot accordingly, and does not need to perform the pre-rendering operation again.
  • the process of re-formatting and copying the snapshot of the kernel thread can be omitted, and the process of re-rendering the synthetic thread can be omitted, the webpage update speed can be accelerated, and the webpage update efficiency can be improved, and accordingly, the dynamic effect display of the webpage can be increased.
  • the frame rate improves the dynamic display performance of web pages.
  • the CSS Transform attribute of the webpage element is changed by using the JavaScript to change the dynamic effect of the inertial scrolling.
  • the technical solution provided by the embodiment of the present application can be improved by about 20 to 30% in the frame rate of the dynamic effect display. To make the effect of inertial scrolling smoother.
  • the present invention can be implemented by means of software plus a necessary general hardware platform, and of course, can also be through hardware, but in many cases, the former is better.
  • Implementation Based on such understanding, the technical solution of the present invention, which is essential or contributes to the prior art, can be embodied in the form of a software product and stored in a storage medium, including a number of instructions for making an intelligent
  • the apparatus performs all or part of the steps of the methods described in various embodiments of the invention.
  • the foregoing storage medium includes: a medium that can store data and program code, such as a read only memory (ROM), a random access memory (RAM), a magnetic disk, or an optical disk.
  • FIG. 2 is a block diagram of a rendering acceleration based webpage updating apparatus according to an exemplary embodiment of the present application.
  • the apparatus may include a kernel thread snapshot update module U201, a kernel thread request sending module U202, a synthetic thread request receiving module U210, and a synthetic thread snapshot update module U220.
  • the kernel thread snapshot update module U201 is configured to: in the kernel thread, when the JavaScript dynamic code changes the cascading style sheet attribute corresponding to the layer attribute of the webpage element, the kernel thread updates the layer of the corresponding webpage element in the source webpage snapshot. Attributes.
  • the source web page snapshot may be a current web page snapshot in the kernel thread
  • the CSS attribute corresponding to the layer attribute includes a CSS Transform attribute, a CSS Animation attribute, and a CSS Opacity attribute, and the change does not cause the webpage element content.
  • the changes do not affect the pre-rendering of web page elements.
  • the kernel thread request sending module U202 is connected to the U201 for transmitting a synchronization update request message to the synthesizing thread in the kernel thread.
  • the synthesizing thread request receiving module U210 is configured to receive a synchronous update request in the synthesizing thread, and perform inter-thread communication with the kernel thread request sending module U202, and the communication manner may use a message passing manner, and a dotted line between the U210 and the U202 is shown in FIG. Communication relationship.
  • the synthetic thread snapshot update module U220 is connected to the U210, and is configured to synchronously update the attribute of the corresponding layer in the current webpage snapshot in the synthetic thread according to the attribute of the layer in the source webpage snapshot in the synthesizing thread.
  • FIG. 3 is a block diagram of another apparatus for updating a webpage based on a rendering acceleration according to an exemplary embodiment of the present application. Compared with the embodiment shown in FIG. 2, the apparatus shown in this embodiment may further include:
  • the synthesizing module U230 is connected to the U220, and is configured to generate a webpage cache according to the synthesizing operation of the current webpage snapshot in the updated synthesizing thread in the synthesizing thread.
  • the synthetic thread snapshot update module U220 may include:
  • Kernel thread access module for accessing kernel threads
  • a layer comparison submodule configured to compare each layer of the current webpage snapshot in the composite thread with each corresponding layer of the source webpage snapshot through the kernel thread access module
  • a first determining sub-module configured to determine whether an attribute of each layer in the current webpage snapshot in the synthetic thread is the same as an attribute of each corresponding layer in the source webpage snapshot
  • the first update sub-module is configured to: when the current webpage snapshot in the synthetic thread has a layer different from the attribute of the corresponding layer in the source webpage snapshot, the attribute of the setting layer is the same as the attribute of the corresponding layer in the source webpage snapshot.
  • the synthetic thread snapshot update module in another possible implementation manner, may include:
  • Kernel thread access module for accessing kernel threads
  • a first search submodule configured to find a webpage element in which at least one of a CSS Transform property, a CSS Animation property, and a CSS Opacity property is set in the current webpage snapshot;
  • a second search submodule configured to search, by accessing the kernel thread module, a webpage element having at least one of a CSS Transform property, a CSS Animation property, and a CSS Opacity property in the source webpage snapshot;
  • An element attribute comparison module configured to: use a CSS attribute of the webpage element found by the first search submodule and a CSS attribute of the webpage element found by the second search submodule;
  • a second determining sub-module configured to determine, according to the element attribute comparison module, whether the CSS attributes of the two compared webpage elements are the same;
  • a second update sub-module configured to: when there is a webpage element with different CSS attributes in the current webpage snapshot in the synthetic thread, set the attribute of the layer of the webpage element in the current webpage snapshot of the synthetic thread and the corresponding webpage in the source webpage snapshot
  • the CSS attribute of the element corresponding to the layer attribute is the same.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

一种基于合成渲染加速的网页更新方法及装置。当浏览器运行JavaScript动态代码改变网页元素中对应与图层属性的CSS属性时,内核线程相应地更新其当前的网页快照中网页元素所在图层的属性,合成线程根据内核线程更新后的网页快照,相应地更新合成线程中当前的网页快照中对应图层的属性,然后根据更新后当前的网页快照进行合成操作,完成网页的更新。该技术方案节省了内核线程的重排版和网页快照拷贝,以及合成线程的预绘制步骤,提高了网页更新的处理效率和网页动态显示性能。

Description

基于合成渲染加速的网页更新方法和装置
本申请要求于2014年7月31日提交中国专利局、申请号为201410373650.0、发明名称为“一种基于合成渲染加速的网页更新方法和装置”的中国专利申请的优先权,其全部内容通过引用结合在本申请中。
技术领域
本发明涉及网页渲染技术领域,尤其涉及一种基于合成渲染加速的网页更新方法和装置。
背景技术
现阶段浏览器一般都采用多线程的渲染加速架构,以充分利用多核CPU(Central Processing Unit,中央处理器)和GPU(Graphic Processing Unit,图形处理器)的硬件性能,并且避免UI(User Interface,用户界面)线程阻塞导致用户操作不流畅。其中,合成渲染加速是使用较多的渲染加速架构,通过将网页划分成多个图层来提升渲染性能。在合成渲染加速架构下,浏览器将所有的网页元素按照预定的规则分组,使其从属于某一特定图层,将所有图层以树状结构组织成图层树,网页快照则由图层树构成。
图层树中,图层包括内容和属性两部分。图层内容为从属于图层的所有网页元素的绘制描述。图层属性则跟其包含的网页元素的某些CSS(Cascading Style Sheets,层叠式样表)属性对应,网页元素图层分组规则会保证从属于同一图层的所有网页元素在这些CSS属性上的值都是一样的,所以图层某一属性的值就来自于从属于它的网页元素跟这个图层属性相对应的CSS属性的值。例如:图层的CSS Transform(几何变换)属性、CSS Animation(动画)属性和CSS Opacity(不透明度)属性跟图层包含的网页元素的这些CSS属性形成映射关系。合成渲染加速架构下的渲染加速引擎通常包括两个主要的线程:内核线程和合成线程。内核线程主要负责HTML(HyperText Markup language,超文本标记语言)和CSS脚本的解析、JavaScript动态代码的执行和网页的排版等任务,内核线程持有当前网页的快照,在每次重新排版后更新该网页快照, 并拷贝更新后的快照发送给合成线程。合成线程则负责预绘制从内核线程接收到的网页快照,所述预绘制为将每个图层的内容(绘制描述)光栅化为像素并存入缓存中,然后合成线程再根据预绘制得到的像素缓存和图层的属性合成为网页缓存输出至当前显示窗口的帧缓冲存储器(Frame Buffer,简称帧缓存)。显示控制器读取帧缓存则可以将网页呈现到屏幕上。
现在网页在运行时会通过JavaScript代码不断动态改变网页元素的CSS属性,其中一部分CSS属性跟网页元素所属图层的图层属性相对应,例如CSS Transform属性、CSS Animation属性和CSS Opacity属性,一般而言这些属性的变更不会导致元素内容的变化,也就是说这些属性不影响元素是如何预绘制的。在现有的合成渲染加速架构下,在网页加载完毕以及首次排版和预绘制完成后,当图层的内容和属性发生变化需要更新网页时,内核线程都要重新排版生成新的网页快照,拷贝新的网页快照发送至合成线程,而合成线程则重新进行预绘制等处理步骤。但前述跟网页元素部分CSS属性相对应的图层属性只影响图层内容的展示,对网页排版无影响,也不影响图层光栅化的结果,上述需要重新排版和重新预绘制的网页更新过程会占据很多的系统资源,导致更新效率和速度低,由于网页更新的效率和速度低,也使得网页动态效果显示的帧率低,网页动态显示性能不佳。
发明内容
本申请提供一种基于合成渲染加速的网页更新方法和装置。
根据本申请实施例的第一方面,提供一种基于合成渲染加速的网页更新方法,包括:
当JavaScript动态代码使网页元素的与图层属性对应的层叠样式表属性发生变化时,内核线程更新源网页快照中所述网页元素所在图层的属性,所述源网页快照为所述内核线程中当前的网页快照;
所述内核线程向合成线程发送同步更新请求;以及
接收到所述同步更新请求后,所述合成线程根据更新的源网页快照中图层的属性同步更新合成线程中当前的网页快照中对应图层的属性。
可选的,所述与图层属性对应的层叠样式表属性的变化独立于所述网 页元素内容的变化。
可选的,所述层叠样式表属性包括层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性。
可选的,所述根据所述更新的源网页快照中图层的属性同步更新当前网页快照中对应图层的属性,包括:
比较所述合成线程中当前网页快照的每个图层与所述更新的源网页快照的每个对应图层,当所述合成线程中当前的网页快照中存在与所述更新的源网页快照中对应图层的属性不同的图层时,设置所述图层的属性与所述更新的源网页快照中对应图层的属性相同。
可选的,所述根据所述更新的源网页快照中图层的属性同步更新合成线程中当前的网页快照中对应图层的属性,包括:
比较所述合成线程中当前的网页快照中设置有层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性至少其中之一的网页元素,与所述更新的源网页快照中对应的设置有层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性至少其中之一的网页元素;以及
当合成线程中当前的网页快照中存在几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性不同的网页元素时,设置所述合成线程中当前的网页元素所在图层的属性与所述更新的源网页快照中对应网页元素的几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性相同。
所述基于合成渲染加速的网页更新方法,在根据所述源网页快照中图层的层叠样式表属性同步更新所述合成线程中当前的网页快照中对应的图层的层叠样式表属性之后,还包括:
所述合成线程根据更新后的当前网页快照进行合成操作生成网页缓存。
根据本申请实施例的第二方面,提供一种基于合成渲染加速的网页更新装置,包括:
内核线程快照更新模块,用于在内核线程中,当JavaScript动态代码使网页元素的与图层属性对应的层叠样式表属性发生变化时,内核线程更新 源网页快照中所述网页元素所在图层的属性,所述源网页快照为内核线程中当前的网页快照;
内核线程请求发送模块,用于在所述内核线程中向合成线程发送同步更新请求消息;
合成线程请求接收模块,用于在所述合成线程中接收所述同步更新请求;以及
合成线程快照更新模块,用于在所述合成线程中根据所述源网页快照中图层的属性同步更新合成线程中当前的网页快照中对应图层的属性。
可选的,所述合成线程快照更新模块,包括:
内核线程访问模块,用于访问所述内核线程;
图层比较子模块,用于通过所述内核线程访问模块比较合成线程中当前的网页快照的每个图层与所述更新的源网页快照的每个对应图层;
第一判断子模块,用于判断所述合成线程中当前的网页快照中每个图层的属性与所述更新的源网页快照中每个对应图层的属性是否相同;
第一更新子模块,用于当所述合成线程中当前的网页快照中存在与所述更新的源网页快照中对应图层的属性不同的图层时,设置所述图层的属性与所述更新的源网页快照中对应图层的属性相同。
可选的,所述合成线程快照更新模块,包括:
内核线程访问模块,用于访问所述内核线程;
第一查找子模块,用于查找所述合成线程中当前的网页快照中设置有层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性至少其中之一的网页元素;
第二查找子模块,用于通过访问内核线程模块查找源网页快照中设置有层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性至少其中之一的网页元素;
元素属性比较模块,用于比较第一查找子模块查找到的网页元素的层叠样式表属性和第二查找子模块查找到的网页元素的层叠样式表属性;第二判断子模块,用于基于元素属性比较模块判断两个进行比较的网页元素的层叠样式表属性是否相同;
第二更新子模块,用于根据第二判断子模块的判断结果,当所述合成线程中当前的网页快照中存在层叠样式表几何变换属性、层叠样式表动画属性或层叠样式表不透明度属性不同的网页元素时,设置所述合成线程中当前的网页快照中所述网页元素所在图层的属性与源网页快照中对应网页元素的层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性相同。
所述基于合成渲染加速的网页更新装置,还包括:
合成模块,用于在所述合成线程中根据更新后的当前的网页快照进行合成操作生成网页缓存。
本申请实施例提供的技术方案,在合成线程的网页快照和内核线程的网页快照之间建立同步更新的机制。当浏览器运行JavaScript动态代码改变网页元素的与图层属性对应的层叠样式表属性发生变化时,内核线程只用相应地更新其当前的网页快照中网页元素所在图层的属性,并向合成线程发送同步更新请求。合成线程接收到同步更新请求后,根据内核线程更新后的网页快照,相应地更新合成线程中当前的网页快照中对应图层的属性,然后根据更新后当前的网页快照进行合成操作,即可以完成网页的更新。本申请实施例提供的技术方案可以包括以下有益效果:避免了内核线程的重排版和网页快照拷贝,以及避免了合成线程的预绘制步骤,提高了浏览器网页更新的处理效率和速度。更新效率和速度加快,可能相应增加网页动态效果显示的帧率,从而提高网页动态显示性能。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本申请。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,对于本领域普通技术人员而言,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1为本申请一示例性实施例示出的一种基于合成渲染加速的网页更 新方法的流程示意图;
图2为本申请一示例性实施例示出的一种基于合成渲染加速的网页更新装置的框图;以及
图3为本申请另一示例性实施例示出的一种基于合成渲染加速的网页更新装置的框图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本申请相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本申请的一些方面相一致的装置和方法的例子。
为了全面理解本申请,在以下详细描述中提到了众多具体的细节,但是本领域技术人员应该理解,本申请可以无需这些具体细节而实现。在其他实施例中,不详细描述公知的方法、过程、装置和模块,以免不必要地导致实施例模糊。
图1为本申请一示例性实施例示出的一种基于合成渲染加速的网页更新方法的流程示意图。如图1所示,该方法包括步骤S101至步骤S103。
在步骤S 101中,当JavaScript动态代码使网页元素的与图层属性对应的CSS属性发生变化时,内核线程更新源网页快照中对应网页元素所在图层的属性。
在本实施例中,源网页快照可以为内核线程中当前的网页快照,与图层属性对应的CSS属性包括CSS Transform属性、CSS Animation属性和CSS Opacity属性,其变更独立于网页元素内容的变化,也就是说,这些属性的变化不会导致网页元素内容的变化,不影响网页元素的预绘制。
在合成渲染加速架构下,在网页加载完毕、内核线程的首次排版和合成线程的首次预绘制及合成操作完成后,当内核线程执行JavaScript动态代码,改变了一些网页元素的CSS属性后,内核线程根据被改变的网页元素的CSS属性,更新源网页快照中对应图层的属性,CSS属性包括CSS  Transform属性、CSS Animation属性和CSS Opacity属性。在本实施例中,对应图层为被改变的网页元素在网页快照中所在的图层;更新源网页快照中对应网页元素所在图层的属性可以包括:设置网页快照中对应图层的属性与网页元素对应的被JavaScript动态代码改变的CSS属性相同,例如,JavaScript动态代码改变了某个网页元素的CSS Transform属性,则相应的更新网页元素所在图层的CSS Transform属性,以此类推。浏览器的图层分组规则会保证从属于同一图层的所有网页元素中与图层属性对应的CSS属性都相同,图层属性与从属于它的网页元素的与图层属性对应的CSS属性相同,所以当网页元素的CSS属性被JavaScript动态代码更改时,内核线程找到所述网页元素在网页快照中所在的图层,设置该图层的属性与网页元素被改变的与图层属性对应的CSS属性相同,从而更新图层属性,相应地也更新了网页快照。内核线程更新完毕后,源网页快照即为更新后的当前的网页快照。
由于图层属性只是对图层内容展示的规定,使网页更生动,例如文本或图片的几何变换、不透明度和动画效果,图层属性不影响图层内容,也不影响排版结果,因此当JavaScript动态代码改变网页元素的CSS属性后,步骤S101只需对发生变化的网页元素在网页快照中所在图层的属性进行更新,不需对整个网页重新排版生成新的网页快照,省略了排版步骤,节省了线程处理资源。
在步骤S102中,内核线程向合成线程发送同步更新请求。
在本实施例中,内核线程可以使用线程通信中的消息传递方式,向合成线程发生同步更新请求。
在步骤S103中,合成线程接收到所述同步更新请求后,根据源网页快照中图层的属性同步更新合成线程当前的网页快照中对应图层的属性。
在本实施例中,根据源网页快照中图层的属性同步更新当前网页快照中对应图层的属性可以包括:合成线程访问内核线程,遍历合成线程中当前网页快照的每个图层和源网页快照中每个对应的图层,比较合成线程中当前网页快照的每个图层与内核线程中源网页快照中每个对应的图层。当存在属性不同的图层时,即合成线程中当前网页快照的某个图层与源网页 快照中对应图层的属性不同时,设置合成线程中所述图层的属性与源网页快照中对应图层的属性相同。
在本实施例中,合成线程中当前的网页快照为首次预绘制之后合成线程持有的网页快照,由于预绘制只针对图层内容进行,因此图层属性的变化不影响图层预绘制的结果(预绘制生成的像素缓存)。当合成线程接收到内核线程发送的同步更新请求后,保持当前的网页快照的图层内容不变,只需更新合成线程中当前的网页快照的图层属性。然后根据已经生成的预绘制的结果和更新后的图层属性进行合成操作,便可以完成网页缓存的更新,达到网页更新的目的。
在本实施例中,合成线程访问内核线程可以使用线程之间数据共享的方式,即内核线程共享其当前的网页快照,供合成线程访问。
在本实施例中,根据源网页快照中对应图层的属性同步更新合成线程当前的网页快照中对应图层的属性还可以包括:比较合成线程当前的网页快照中设置有与图层属性对应的CSS属性的网页元素,与源网页快照中对应的设置有和图层属性对应的CSS属性的网页元素,如果参与比较的两个网页元素中和图层属性对应的CSS属性不同,则设置所述网页元素所在图层的属性与源网页快照中对应网页元素的和图层属性对应的CSS属性相同,如果参与比较的两个网页元素中和图层属性对应的CSS属性相同,则不更新。
根据源网页快照中对应图层的属性同步更新合成线程当前的网页快照中对应图层的属性还可以包括:比较合成线程中当前的网页快照中设置有CSS Transform属性、CSS Animation属性和CSS Opacity属性至少其中之一的网页元素,与源网页快照中对应的设置有CSS Transform属性、CSS Animation属性和CSS Opacity属性至少其中之一的网页元素,当存在CSS Transform属性、CSS Animation属性或CSS Opacity属性不同的网页元素时,即设置所述网页元素所在图层的属性与源网页快照中对应网页元素的CSS Transform属性、CSS Animation属性和CSS Opacity属性相同。
由于并非所有图层都有属性,也就是说,一些图层中没有图层内容的展示规定,例如,当一个图层仅仅只是用于展示无透明度的静态文本时, 或者当一个图层中所有网页元素都没有设置CSS Transform属性、CSS Animation属性和CSS Opacity属性时,图层的属性可能为空。通常对动态效果要求低的网页,属性为空的图层的比例会很高,因此可以不用对每个图层都进行比较,而是比较合成线程的当前网页快照中与源网页快照中设置有与图层属性对应的CSS属性的网页元素。更进一步的,由于通常图层属性为CSS Transform属性、CSS Animation属性和CSS Opacity属性,因此可以比较合成线程当前的网页快照中与源网页快照中设置有CSS Transform属性、CSS Animation属性和CSS Opacity属性至少其中之一的网页元素。比较设置有与图层属性对应的CSS属性的网页元素,相比比较每个图层,可以更好地提高更新速度和效率,节省线程处理资源。
在合成线程更新其当前网页快照后,合成线程根据更新后当前的网页快照的图层属性,和预绘制生成的像素缓存,进行合成操作生成网页缓存输出至帧缓存,完成网页的更新。
本申请实施例提供的基于合成渲染加速的网页更新方法,当网页元素中与图层属性对应的CSS属性被JavaScript动态代码改变时,内核线程只需更新网页元素在内核线程当前的网页快照中对应的图层的属性,不需重新排版。同时,合成线程只需相应地更新其当前网页快照对应图层的属性,不需要再重新进行预绘制操作。相比相关技术中的网页更新方法,可以省略内核线程重新排版和拷贝快照的过程,以及省略合成线程重新绘制的过程,加快网页更新速度,提高网页更新效率,相应地,可以增加网页动态效果显示的帧率,提高网页动态显示性能。以使用JavaScript不断改变网页元素的CSS Transform属性来形成惯性滚动的动态效果为例,本申请实施例提供的技术方案比相关技术中的方案在动态效果显示的帧率上可以提升20~30%左右,使惯性滚动的效果更流畅。
通过以上的方法实施例的描述,所属领域的技术人员可以清楚地了解到本发明可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,并存储在一个存储介质中,包括若干指令用以使得一台智能 设备执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:只读存储器(ROM)、随机存取存储器(RAM)、磁碟或者光盘等各种可以存储数据和程序代码的介质。
图2为本申请一示例性实施例示出的一种基于渲染加速的网页更新装置的框图。如图2所示,所述装置可以包括内核线程快照更新模块U201、内核线程请求发送模块U202、合成线程请求接收模块U210以及合成线程快照更新模块U220。
内核线程快照更新模块U201,用于在内核线程中,当JavaScript动态代码使网页元素的与图层属性对应的层叠样式表属性发生变化时,内核线程更新源网页快照中对应网页元素所在图层的属性。
在本实施例中,源网页快照可以为内核线程中当前的网页快照,所述与图层属性对应的CSS属性包括CSS Transform属性、CSS Animation属性和CSS Opacity属性,其变更不会导致网页元素内容的变化,不影响网页元素的预绘制。
内核线程请求发送模块U202,与U201连接,用于在内核线程中向合成线程发送同步更新请求消息。
合成线程请求接收模块U210,用于在合成线程中接收同步更新请求,与内核线程请求发送模块U202进行线程间通信,通信方式可以使用消息传递方式,图2中以虚线表示U210和U202之间的通信关系。
合成线程快照更新模块U220,与U210连接,用于在合成线程中根据源网页快照中图层的属性同步更新合成线程中当前的网页快照中对应图层的属性。
图3为本申请一实例性实施例示出的另一种基于渲染加速的网页更新装置的框图,与图2所示实施例相比较,该实施例中所示装置还可以包括:
合成模块U230,与U220连接,用于在合成线程中根据更新后合成线程中当前的网页快照进行合成操作生成网页缓存。
在本实施例中,合成线程快照更新模块U220,在一种可能的实施方式中,可以包括:
内核线程访问模块,用于访问内核线程;
图层比较子模块,用于通过内核线程访问模块比较合成线程中当前的网页快照的每个图层与源网页快照的每个对应图层;
第一判断子模块,用于判断合成线程中当前的网页快照中每个图层的属性与源网页快照中每个对应图层的属性是否相同;以及
第一更新子模块,用于合成线程中当前的网页快照中存在与源网页快照中对应图层的属性不同的图层时,设置图层的属性与源网页快照中对应图层的属性相同。
在本实施例中,合成线程快照更新模块,在另一种可能的实施方式中,可以包括:
内核线程访问模块,用于访问内核线程;
第一查找子模块,用于查找当前网页快照中设置有CSS Transform属性、CSS Animation属性和CSS Opacity属性至少其中之一的网页元素;
第二查找子模块,用于通过访问内核线程模块查找源网页快照中设置有CSS Transform属性、CSS Animation属性和CSS Opacity属性至少其中之一的网页元素;
元素属性比较模块,用于第一查找子模块查找到的网页元素的CSS属性和第二查找子模块查找到的网页元素的CSS属性;
第二判断子模块,用于基于元素属性比较模块判断两个进行比较的网页元素的CSS属性是否相同;以及
第二更新子模块,用于当合成线程中当前的网页快照中存在CSS属性不同的网页元素时,设置合成线程当前的网页快照中所述网页元素所在图层的属性与源网页快照中对应网页元素的与图层属性对应的CSS属性相同。
为了描述的方便,描述以上装置时以功能分为各种模块分别描述。当然,在实施本申请时可以把各模块的功能在同一个或多个软件和/或硬件中实现。
本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于装置实施例而言,由于其基本相似于方法实施例, 所以描述得比较简单,相关之处参见方法实施例的部分说明即可。以上所描述的装置及系统实施例仅仅是示意性的,其中所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。本领域普通技术人员在不付出创造性劳动的情况下,即可以理解并实施。
需要说明的是,在本文中,诸如“第一”和“第二”等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者逆序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、装置或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、装置或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个......”限定的要素,并不排除在包括所述要素的过程、方法、装置或者设备中还存在另外的相同要素。
以上所述仅是本申请的具体实施方式,使本领域技术人员能够理解或实现本申请。对这些实施例的多种修改对本领域的技术人员来说将是显而易见的,本文中所定义的一般原理可以在不脱离本申请的精神或范围的情况下,在其它实施例中实现。因此,本申请将不会被限制于本文所示的这些实施例,而是要符合与本文所公开的原理和新颖特点相一致的最宽的范围。

Claims (13)

  1. 一种基于合成渲染加速的网页更新方法,其特征在于,包括:
    当JavaScript动态代码使网页元素的与图层属性对应的层叠样式表属性发生变化时,内核线程更新源网页快照中所述网页元素所在图层的属性,所述源网页快照为所述内核线程中当前的网页快照;
    所述内核线程向合成线程发送同步更新请求;以及
    接收到所述同步更新请求后,所述合成线程根据更新的源网页快照中图层的属性同步更新合成线程中当前的网页快照中对应图层的属性。
  2. 如权利要求1所述的基于合成渲染加速的网页更新方法,其特征在于,所述与图层属性对应的层叠样式表属性的变换独立于所述网页元素内容的变化。
  3. 如权利要求2所述的基于合成渲染加速的网页更新方法,其特征在于,
    所述与图层属性对应的层叠样式表属性包括层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性。
  4. 如权利要求3所述的基于合成渲染加速的网页更新方法,其特征在于,所述根据所述更新的源网页快照中图层的属性同步更新当前网页快照中对应图层的属性,包括:
    比较所述合成线程中当前的网页快照的每个图层与所述更新的源网页快照的每个对应图层,当所述合成线程中当前的网页快照中存在与所述更新的源网页快照中对应图层的属性不同的图层时,设置所述图层的属性与所述更新的源网页快照中对应图层的属性相同。
  5. 如权利要求3所述的基于合成渲染加速的网页更新方法,其特征在于,所述根据所述更新的源网页快照中图层的属性同步更新合成线程中当前的网页快照中对应图层的属性,包括:
    比较所述合成线程中当前的网页快照中设置有层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性至少其中之一的网页元素,与所述更新的源网页快照中对应的设置有层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性至少其中之一的网页元素;以及
    当存在几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性不同的网页元素时,设置所述合成线程中当前的网页快照中所述网页元素所在图层的属性与所述更新的源网页快照中对应网页元素的几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性相同。
  6. 如权利要求1-5任一所述的基于合成渲染加速的网页更新方法,其特征在于,在根据所述更新的源网页快照中图层的层叠样式表属性同步更新合成线程中当前的网页快照中对应的图层的层叠样式表属性之后,还包括:
    所述合成线程根据更新后合成线程中当前的网页快照进行合成操作生成网页缓存。
  7. 一种基于合成渲染加速的网页更新装置,其特征在于,包括:
    内核线程快照更新模块,用于在内核线程中,当JavaScript动态代码使网页元素的与图层属性对应的层叠样式表属性发生变化时,内核线程更新源网页快照中所述网页元素所在图层的属性,所述源网页快照为所述内核线程中当前的网页快照;
    内核线程请求发送模块,用于在所述内核线程中向合成线程发送同步更新请求消息;
    合成线程请求接收模块,用于在所述合成线程中接收所述同步更新请求;以及
    合成线程快照更新模块,用于在所述合成线程中根据所述更新的源网页快照中图层的属性同步更新所述合成线程中当前的网页快照中对应图层的属性。
  8. 如权利要求7所述的基于合成渲染加速的网页更新装置,其特征在于,所述合成线程快照更新模块,包括:
    内核线程访问模块,用于访问所述内核线程;
    图层比较子模块,用于通过所述内核线程访问模块比较合成线程中当前的网页快照的每个图层与所述更新的源网页快照的每个对应图层;
    第一判断子模块,用于判断所述合成线程中当前的网页快照中每个图层的属性与所述更新的源网页快照中每个对应图层的属性是否相同;
    第一更新子模块,用于当所述合成线程中当前的网页快照中存在与所述更新的源网页快照中对应图层的属性不同的图层时,设置所述图层的属性与所述更新的源网页快照中对应图层的属性相同。
  9. 如权利要求7所述的基于合成渲染加速的网页更新装置,其特征在于,所述合成线程快照更新模块,包括:
    内核线程访问模块,用于访问所述内核线程;
    第一查找子模块,用于查找所述合成线程中当前的网页快照中设置有层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性至少其中之一的网页元素;
    第二查找子模块,用于通过访问内核线程模块查找所述更新的源网页快照中设置有层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性至少其中之一的网页元素;
    元素属性比较模块,用于比较第一查找子模块查找到的网页元素的层叠样式表属性和第二查找子模块查找到的网页元素的层叠样式表属性;
    第二判断子模块,用于基于元素属性比较模块判断两个进行比较的网页元素的层叠样式表属性是否相同;以及
    第二更新子模块,用于根据第二判断子模块的判断结果,当存在层叠样式表几何变换属性、层叠样式表动画属性或层叠样式表不透明度属性不同的网页元素时,设置所述合成线程中当前的网页快照中所述网页元素所在图层的属性与所述更新的源网页快照中对应网页元素的层叠样式表几何 变换属性、层叠样式表动画属性和层叠样式表不透明度属性相同。
  10. 如权利要求7-9任一所述的基于合成渲染加速的网页更新装置,其特征在于,还包括:
    合成模块,用于在所述合成线程中根据更新后的当前的网页快照进行合成操作生成网页缓存。
  11. 一种基于合成渲染加速的网页更新装置,其特征在于,包括:一个或多个处理器和存储有操作指令的存储介质,当运行所处存储介质中的操作指令时,所述处理器执行如下步骤:
    当JavaScript动态代码使网页元素的与图层属性对应的层叠样式表属性发生变化时,所述处理器控制内核线程更新源网页快照中所述网页元素所在图层的属性,所述源网页快照为内核线程中当前的网页快照;
    所述处理器控制所述内核线程向合成线程发送同步更新请求;以及
    所述处理器控制所述合成线程根据更新的源网页快照中图层的属性同步更新所述合成线程中当前的网页快照中对应图层的属性。
  12. 如权利要求11所述的基于合成渲染加速的网页更新装置,其特征在于,所述处理器控制所述合成线程根据更新的源网页快照中图层的属性同步更新所述合成线程中当前的网页快照中对应图层的属性,包括:
    比较所述合成线程中当前的网页快照的每个图层与所述更新的源网页快照的每个对应图层,当所述合成线程中当前的网页快照中存在与所述更新的源网页快照中对应图层的属性不同的图层时,设置所述图层的属性与所述更新的源网页快照中对应图层的属性相同。
  13. 如权利要求11所述的基于合成渲染加速的网页更新装置,其特征在于,所述处理器控制所述合成线程根据更新的源网页快照中图层的属性同步更新所述合成线程中当前的网页快照中对应图层的属性,包括:
    比较所述合成线程中当前的网页快照中设置有层叠样式表几何变换属 性、层叠样式表动画属性和层叠样式表不透明度属性至少其中之一的网页元素,与所述更新的源网页快照中对应的设置有层叠样式表几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性至少其中之一的网页元素;以及
    当存在几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性不同的网页元素时,设置所述合成线程中当前的网页快照中所述网页元素所在图层的属性与所述更新的源网页快照中对应网页元素的几何变换属性、层叠样式表动画属性和层叠样式表不透明度属性相同。
PCT/CN2015/081940 2014-07-31 2015-06-19 基于合成渲染加速的网页更新方法和装置 WO2016015527A1 (zh)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
CN201410373650.0A CN105335410B (zh) 2014-07-31 2014-07-31 一种基于合成渲染加速的网页更新方法和装置
CN201410373650.0 2014-07-31

Publications (1)

Publication Number Publication Date
WO2016015527A1 true WO2016015527A1 (zh) 2016-02-04

Family

ID=55216741

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/CN2015/081940 WO2016015527A1 (zh) 2014-07-31 2015-06-19 基于合成渲染加速的网页更新方法和装置

Country Status (2)

Country Link
CN (1) CN105335410B (zh)
WO (1) WO2016015527A1 (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109445840A (zh) * 2018-11-07 2019-03-08 北京字节跳动网络技术有限公司 一种网页的动态更新方法、装置、电子设备及存储介质
CN112667135A (zh) * 2021-01-26 2021-04-16 马瑞利汽车电子(广州)有限公司 一种汽车仪表主题切换方法
CN112966198A (zh) * 2021-02-25 2021-06-15 平安壹钱包电子商务有限公司 级联样式表数据生成方法、系统、计算机设备及存储介质
CN114356324A (zh) * 2021-12-16 2022-04-15 阿里巴巴(中国)有限公司 界面处理方法、装置、设备和存储介质

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107292945B (zh) * 2016-03-31 2021-01-26 阿里巴巴集团控股有限公司 视频图像的图层渲染处理方法及其系统
CN106325875A (zh) * 2016-08-29 2017-01-11 浪潮软件集团有限公司 一种网页ui界面与网页设计图的对比方法
CN115830190A (zh) * 2016-12-22 2023-03-21 广州方硅信息技术有限公司 动画处理方法和装置
CN108287836B (zh) * 2017-01-09 2022-09-13 腾讯科技(深圳)有限公司 一种资源缓存方法及装置
CN107391128B (zh) * 2017-07-07 2020-07-28 北京小米移动软件有限公司 监控虚拟文件对象模型vdom的方法和装置
CN110288689B (zh) * 2019-06-20 2020-09-01 北京三快在线科技有限公司 对电子地图进行渲染的方法和装置
CN112988661B (zh) * 2021-02-19 2024-03-19 金蝶软件(中国)有限公司 一种余额表更新方法及其相关设备

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090228784A1 (en) * 2008-03-04 2009-09-10 Gilles Drieu Transforms and animations of web-based content
CN102982113A (zh) * 2012-11-08 2013-03-20 山东大学 一种针对Android系统的基于内容分组的浏览器页面加载方法
CN103473347A (zh) * 2013-09-24 2013-12-25 北京大学 一种基于网页相似度的浏览器渲染优化方法
CN103677491A (zh) * 2012-09-03 2014-03-26 百度在线网络技术(北京)有限公司 一种用于渲染网页的方法和装置

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101847269B (zh) * 2009-03-27 2011-11-09 上海科泰世纪科技有限公司 多图层动画渲染系统及方法
US9570046B2 (en) * 2010-09-13 2017-02-14 Nokia Technologies Oy Method and apparatus for rendering content
CN103678631B (zh) * 2013-12-19 2016-10-05 华为技术有限公司 页面渲染方法及装置

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090228784A1 (en) * 2008-03-04 2009-09-10 Gilles Drieu Transforms and animations of web-based content
CN103677491A (zh) * 2012-09-03 2014-03-26 百度在线网络技术(北京)有限公司 一种用于渲染网页的方法和装置
CN102982113A (zh) * 2012-11-08 2013-03-20 山东大学 一种针对Android系统的基于内容分组的浏览器页面加载方法
CN103473347A (zh) * 2013-09-24 2013-12-25 北京大学 一种基于网页相似度的浏览器渲染优化方法

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109445840A (zh) * 2018-11-07 2019-03-08 北京字节跳动网络技术有限公司 一种网页的动态更新方法、装置、电子设备及存储介质
CN109445840B (zh) * 2018-11-07 2021-12-10 北京字节跳动网络技术有限公司 一种网页的动态更新方法、装置、电子设备及存储介质
CN112667135A (zh) * 2021-01-26 2021-04-16 马瑞利汽车电子(广州)有限公司 一种汽车仪表主题切换方法
CN112966198A (zh) * 2021-02-25 2021-06-15 平安壹钱包电子商务有限公司 级联样式表数据生成方法、系统、计算机设备及存储介质
CN114356324A (zh) * 2021-12-16 2022-04-15 阿里巴巴(中国)有限公司 界面处理方法、装置、设备和存储介质

Also Published As

Publication number Publication date
CN105335410B (zh) 2017-06-16
CN105335410A (zh) 2016-02-17

Similar Documents

Publication Publication Date Title
WO2016015527A1 (zh) 基于合成渲染加速的网页更新方法和装置
CN106570098B (zh) 页面刷新的方法及装置
EP2924590A1 (en) Page rendering method and apparatus
US8959431B2 (en) Low resolution placeholder content for document navigation
CN110096277B (zh) 一种动态页面展示方法、装置、电子设备及存储介质
CN107729094B (zh) 一种用户界面渲染的方法及装置
US9514242B2 (en) Presenting dynamically changing images in a limited rendering environment
US9286390B2 (en) Presentation of rich search results in delineated areas
WO2015196822A1 (zh) 一种网页适应屏幕排版方法及装置
WO2017124811A1 (zh) 一种数据绘制方法和装置、终端、存储介质
US20150205476A1 (en) Overscroll visual effects
US9766860B2 (en) Dynamic source code formatting
CN104809123B (zh) 一种网页渲染方法及系统
WO2015078159A1 (zh) 网页显示方法及装置
WO2017152776A1 (zh) 网络引擎启动方法及装置
US20140164911A1 (en) Preserving layout of region of content during modification
US20150370439A1 (en) Gpu-optimized scrolling systems and methods
CN106488298B (zh) 一种在ui中图像绘制的方法及装置和电视
CN106407009A (zh) 一种图片显示方法和装置
CN111460342B (zh) 页面的渲染展示方法、装置、电子设备及计算机存储介质
CN110609729A (zh) 一种基于cmspweb的页面监听滚动渲染方法
CN107621951B (zh) 一种视图层级优化的方法及装置
CN111625234A (zh) 页面骨架屏生成方法、装置、设备及可读存储介质
CN114238877A (zh) 云桌面的水印生成方法、装置及电子设备
EP3008697B1 (en) Coalescing graphics operations

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 15826934

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

122 Ep: pct application non-entry in european phase

Ref document number: 15826934

Country of ref document: EP

Kind code of ref document: A1