This disclosure relates generally to display systems. More particularly, but not by way of limitation, this disclosure relates to techniques for properly rending text into a region of the display that may move arbitrarily from region to region on the display.
In some modern display systems an extra buffer (aka, a side buffer) may be used to store material that can move from one region of a display to another region (aka, dynamic material). When the material contained in the side buffer is moved, the entire side buffer may be blended into the background of the second region. While this approach works well much of the time, it does not work well when text is part of the information stored in the side buffer. To properly render text, it is necessary to know what is behind the text. This is why input to a text render pipeline includes the R (red), G (green), B (blue) and alpha (transparency) of each text character plus each character's RGB glyph-mask (i.e., 7 inputs). Side buffers have only 4 channels: R, G, B and alpha. As a result, once text is rendered into a side buffer it is no longer possible to render that text onto the screen properly as its glyph-mask information is no longer available.
The following summary is included in order to provide a basic understanding of some aspects and features of the claimed subject matter. This summary is not an extensive overview and as such it is not intended to particularly identify key or critical elements of the claimed subject matter or to delineate the scope of the claimed subject matter. The sole purpose of this summary is to present some concepts of the claimed subject matter in a simplified form as a prelude to the more detailed description that is presented below.
In one embodiment the disclosed concepts provide a method to properly render dynamic material that includes anti-aliased text. As used herein, dynamic material may be moved from one location or region on a display screen to another location or region. The phrase “anti-aliased text” means text that has a corresponding glyph-mask. Also as used herein, anti-aliased text may be considered properly rendered when the text's corresponding glyph-mask is taken into account when rendering. Methods in accordance with this disclosure include storing, in a first memory (e.g., an off-screen buffer memory), first information for display on a display unit, the display unit having a full display area, the first memory corresponding to a first region of the full display area, the first region corresponding to less than all of the display unit's full display area, wherein the first information includes color and transparency content; storing, in a second memory (e.g., a second off-screen buffer memory), glyph-mask information (e.g., associated with anti-aliased text) of the first information, the second memory having a size equal to the first memory (in some embodiments, the first and second memories may have a 1:1 correspondence in pixels); detecting a change in location of the first region to a second region of the full display area, the second region having second information; updating the first information in the first memory to new information based on the first information, the second information and the glyph-mask information; and updating the glyph-mask information in the second memory by removing the glyph-mask information from the second memory when the glyph-mask information corresponds to opaque new information in the first memory, and blending the glyph-mask information in the second memory with the new information when the glyph-mask information corresponds to translucent new information in the first memory. In one or more other embodiments updating the first information comprises blending the first information's color and transparency content with color and transparency information of the second information. In still other embodiments the first and second memory may comprise off-screen memory which itself can be backing memory for a compositing engine of an operating system. In yet other embodiments, the various methods described herein may be embodied in computer executable program code or instructions and stored in a non-transitory storage device. In yet another embodiment, the method may be implemented in an electronic device having a display unit, memory and a compositing engine.
This disclosure pertains to systems, methods, and computer readable media to improve the operation of a computer's display system. In general, techniques are disclosed for retaining glyph-mask information for text associated with a region that may be arbitrarily moved across a screen. More particularly, techniques disclosed herein utilize an additional off-screen buffer referred to as the glyph-mask buffer. The glyph-mask buffer coincides with an existing side buffer in extent, but is used only to retain anti-aliased glyph information (i.e., glyph-masks). When the side buffer's content is updated, the effect of that update on the region's text may be reflected in an update to the glyph-mask buffer. At display time, the region corresponding to the side buffer, and the text therein, may be properly rendered at any screen location by combining the screen's target display area (background), the side buffer and the glyph-mask buffer.
In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the disclosed concepts. As part of this description, some of this disclosure's drawings represent structures and devices in block diagram form in order to avoid obscuring the novel aspects of the disclosed concepts. In the interest of clarity, not all features of an actual implementation may be described. Further, as part of this description, some of this disclosure's drawings may be provided in the form of flowcharts. The boxes in any particular flowchart may be presented in a particular order. It should be understood however that the particular sequence of any given flowchart is used only to exemplify one embodiment. In other embodiments, any of the various elements depicted in the flowchart may be deleted, or the illustrated sequence of operations may be performed in a different order, or even concurrently. In addition, other embodiments may include additional steps not depicted as part of the flowchart. Moreover, the language used in this disclosure has been principally selected for readability and instructional purposes, and may not have been selected to delineate or circumscribe the inventive subject matter, resort to the claims being necessary to determine such inventive subject matter. Reference in this disclosure to “one embodiment” or to “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the disclosed subject matter, and multiple references to “one embodiment” or “an embodiment” should not be understood as necessarily all referring to the same embodiment.
It will be appreciated that in the development of any actual implementation (as in any software and/or hardware development project), numerous decisions must be made to achieve a developers' specific goals (e.g., compliance with system- and business-related constraints), and that these goals may vary from one implementation to another. It will also be appreciated that such development efforts might be complex and time-consuming, but would nevertheless be a routine undertaking for those of ordinary skill in the design and implementation of computer display systems having the benefit of this disclosure.
Referring to
Another way to think about the side buffer/glyph-mask buffer system is as two planes of a single underlying memory. In this model, side buffer 110 corresponds to the memory content's color plane and glyph-mask buffer 115 corresponds to the memory content's glyph-mask plane. In one embodiment, each pixel in the color plane (side buffer) may carry color or chroma and transparency information. In the RGB color space this could be represented as (R, G, B, α), where “α” represents transparency. Similarly, each pixel in the glyph-mask plane (glyph-mask buffer) carries any glyph's color information. In the RGB color space this could be represented as (MR, MG, MB). In the glyph-mask plane or buffer, only glyph information is retained. That is, if a particular pixel in the color plane (side buffer) is not associated with anti-aliased text having a glyph-mask, that pixel's corresponding value in the glyph-mask plane or buffer may be set to a value corresponding to fully transparent (or some other empty or nugatory value).
In some embodiments, compositing (or render) engine 120 may be implemented as a function provided by the operating system (OS). One way to represent an OS diagrammatically is as a number of separate layers stacked one atop the other as shown in
Referring to
Before discussing the details of one implementation of a glyph-aware rendering operation, it may be helpful to take a closer look at certain aspects of display system 100. Referring to
Referring to
To see how various actions in accordance with render operation 500 may effect content in glyph-mask buffer 115, consider
Also shown is glyph-mask buffer 635 having fully retained first glyph-mask 640 corresponding to first string 605 (see
Referring to
Processor module 705 may include one or more processing units each of which may include at least one central processing unit (CPU) and zero or more graphics processing units (GPUs); each of which in turn may include one or more processing cores. Each processing unit may be based on reduced instruction-set computer (RISC) or complex instruction-set computer (CISC) architectures or any other suitable architecture. Processor module 705 may be a single processor element, a system-on-chip, an encapsulated collection of integrated circuits (ICs), or a collection of ICs affixed to one or more substrates. Memory 710 may include one or more different types of media (typically solid-state) used by processor module 705 and graphics hardware 720. For example, memory 710 may include memory cache, read-only memory (ROM), and/or random access memory (RAM). Storage 715 may include one more non-transitory storage mediums including, for example, magnetic disks (fixed, floppy, and removable) and tape, optical media such as CD-ROMs and digital video disks (DVDs), and semiconductor memory devices such as Electrically Programmable Read-Only Memory (EPROM), and Electrically Erasable Programmable Read-Only Memory (EEPROM). Memory 710 and storage 715 may be used to retain media (e.g., audio, image and video files), preference information, device profile information, computer program instructions or code organized into one or more modules and written in any desired computer programming language, and any other suitable data. When executed by processor module 705 and/or graphics hardware 720 such computer program code may implement one or more of the methods described herein. Graphics hardware 720 may be special purpose computational hardware for processing graphics and/or assisting processor module 705 perform computational tasks. In one embodiment, graphics hardware 720 may include one or more GPUs, and/or one or more programmable GPUs and each such unit may include one or more processing cores. In another embodiment, graphics hardware 720 may include one or more custom designed graphics engines or pipelines. Such engines or pipelines may be driven, at least in part, through software or firmware. Device sensors 725 may include, but need not be limited to, an optical activity sensor, an optical sensor array, an accelerometer, a sound sensor, a barometric sensor, a proximity sensor, an ambient light sensor, a vibration sensor, a gyroscopic sensor, a compass, a barometer, a magnetometer, a thermistor, an electrostatic sensor, a temperature or heat sensor, a pixel array and a momentum sensor. Communication interface 730 may be used to connect computer system 700 to one or more networks or other devices. Illustrative networks include, but are not limited to, a local network such as a USB network, an organization's local area network, and a wide area network such as the Internet. Communication interface 730 may use any suitable technology (e.g., wired or wireless) and protocol (e.g., Transmission Control Protocol (TCP), Internet Protocol (IP), User Datagram Protocol (UDP), Internet Control Message Protocol (ICMP), Hypertext Transfer Protocol (HTTP), Post Office Protocol (POP), File Transfer Protocol (FTP), and Internet Message Access Protocol (IMAP)). User interface adapter 735 may be used to connect microphone 745, speaker 750, keyboard 755, pointer device 760, and other user interface devices such as image capture device 765 or a touch-pad (not shown). Display adapter 740 may be used to connect one or more display units 770 which may provide touch input capability.
Referring to
It is to be understood that the above description is intended to be illustrative, and not restrictive. The material has been presented to enable any person skilled in the art to make and use the disclosed subject matter as claimed and is provided in the context of particular embodiments, variations of which will be readily apparent to those skilled in the art (e.g., some of the disclosed embodiments may be used in combination with each other). Accordingly, the specific arrangement of steps or actions shown in
Number | Name | Date | Kind |
---|---|---|---|
5940080 | Ruehle | Aug 1999 | A |
7796139 | Feierbach | Sep 2010 | B1 |
7904807 | Bell | Mar 2011 | B2 |
8855414 | Hobbs | Oct 2014 | B1 |
20100045691 | Naito | Feb 2010 | A1 |
20130120657 | Dick | May 2013 | A1 |
20150026549 | Shao | Jan 2015 | A1 |
Number | Date | Country | |
---|---|---|---|
20180350327 A1 | Dec 2018 | US |