US 7275219 B2
A method for generating a presentation of region-of-interest in an information representation including the steps of: selecting a viewpoint for the region-of-interest; selecting a location for the region-of-interest; creating a lens surface having a predetermined location for the region-of-interest; creating a transformed presentation by: determining a mapping for pixel coordinates from the representation to the lens surface by applying a distortion function defining said lens surface to said pixel coordinates; calculating a vector from the predetermined location to the location; and, copying pixel information from the representation to the lens surface according to the mapping as displaced by the vector; and, displaying the transformed presentation on a display screen to generate the presentation of the region-of-interest.
1. A method for generating a presentation of a region-of-interest in an information representation for display on a display screen, comprising:
determining a mapping of original texel corner coordinates in said representation to distorted texel corner coordinates for a lens initially located at a first location in said representation, said distorted texel corner coordinates produced by applying a two-dimensional distortion function defining said lens to said original texel corner coordinates, said lens for rendering within said presentation a magnified region for said region-of-interest at least partially surrounded by an at least partially compressed region where said magnification decreases to that of said representation surrounding said lens to provide context for said magnified region with respect to said representation, said representation having uniform texels, each texel having at least three corners, and each corner having a respective original texel corner coordinate;
calculating a displacement from said first location to a second location in said representation, said second location being that of said region-of-interest;
adjusting said mapping with said displacement to produce an adjusted mapping to thereby relocate said lens to said second location;
copying texel information from said representation to said relocated lens at said second location according to said adjusted mapping to thereby generate said presentation of said region-of-interest; and
displaying said presentation on said display screen.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
9. The method of
10. A system for generating a presentation of a region-of-interest in an information representation for display on a display screen, comprising:
a processor coupled to memory and the display screen; and,
modules within the memory and executed by the processor, the modules including:
a module for determining a mapping of original texel corner coordinates in the representation to distorted texel corner coordinates for a lens initially located at a first location in the representation, the distorted texel corner coordinates produced by applying a two-dimensional distortion function defining the lens to the original texel corner coordinates, the lens for rendering within the presentation a magnified region for the region-of-interest at least partially surrounded by an at least partially compressed region where the magnification decreases to that of the representation surrounding the lens to provide context for the magnified region with respect to the representation, the representation having uniform texels, each texel having at least three corners, and each corner having a respective original texel corner coordinate;
a module for calculating a displacement from the first location to a second location in the representation, the second location being that of the region-of-interest;
a module for adjusting the mapping with the displacement to produce an adjusted mapping to thereby relocate the lens to the second location;
a module for copying texel information from the representation to the relocated lens at the second location according to the adjusted mapping to thereby generate the presentation of the region-of-interest; and,
a module for displaying the presentation on the display screen.
11. The system of
12. The system of
13. The system of
14. The system of
15. The system of
16. The system of
17. The system of
18. The system of
This application claims priority from Canadian Patent Application No. 2,370,751 Filed Feb. 5, 2002, the disclosure of which is incorporated herein by reference.
The invention relates to the field of computer-graphics processing, and more specifically to a method and system for fast rendering of a detail-in-context lens in a detail-in-context presentation.
Display screens are the primary interface for displaying information from a computer. Display screens are limited in size, thus presenting a challenge to graphical user interface design, particularly when large amounts of information are to be displayed. This problem is normally referred to as the “screen real estate problem”.
Well-known solutions to this problem include panning, zooming, scrolling or combinations thereof. While these solutions are suitable for a large number of visual display applications, these solutions become less effective where sections of the visual information are spatially related, such as maps, three-dimensional representations, newspapers and such like. In this type of information display, panning, zooming and/or scrolling is not as effective as much of the context of the panned, zoomed or scrolled display is hidden.
A recent solution to this problem is the application of “detail-in-context” presentation techniques. Detail-in-context is the magnification of a particular region of interest (the “focal region” or “detail”) in a data presentation while preserving visibility of the surrounding information (the “context”). This technique has applicability to the display of large surface area media, such as maps, on computer screens of variable size including graphics workstations, laptop computers, personal digital assistants (“PDAs”), and cell phones.
In the detail-in-context discourse, differentiation is often made between the terms “representation” and “presentation”. A representation is a formal system, or mapping, for specifying raw information or data that is stored in a computer or data processing system. For example, a digital map of a city is a representation of raw data including street names and the relative geographic location of streets and utilities. Such a representation may be displayed visually on a computer screen or printed on paper. On the other hand, a presentation is a spatial organization of a given representation that is appropriate for the task at hand. Thus, a presentation of a representation organizes such things as the point of view and the relative emphasis of different parts or regions of the representation. For example, a digital map of a city may be presented with a region magnified to reveal street names.
In general, a detail-in-context presentation may be considered as a distorted view (or distortion) of a portion of the original representation where the distortion is the result of the application of a “lens” like distortion function to the original representation. A detailed review of various detail-in-context presentation techniques such as Elastic Presentation Space may be found in a publication by Marianne S. T. Carpendale, entitled “A Framework for Elastic Presentation Space” (Carpendale, Marianne S. T., A Framework for Elastic Presentation Space (Burnaby, British Columbia: Simon Fraser University, 1999)), and incorporated herein by reference.
In general, detail-in-context data presentations are characterized by magnification of areas of an image where detail is desired, in combination with compression of a restricted range of areas of the remaining information (i.e. the context), the result typically giving the appearance of a lens having been applied to the display surface. Using the techniques described by Carpendale, points in a representation are displaced in three dimensions and a perspective projection is used to display the points on a two-dimensional presentation display. Thus, when a lens is applied to a two-dimensional continuous surface representation, for example, the resulting presentation appears to be three-dimensional. In other words, the lens transformation appears to have stretched the continuous surface in a third dimension.
One shortcoming of these detail-in-context presentation systems is that the rendering of a raster image which has under-gone a distortion through the application of one or more lenses (e.g. pyramid lenses) can be time consuming. Both the CPU and input/output systems of the detail-in-context presentation system can be taxed when performing such a rendering. Past techniques for rendering these images have usually involved texturing the raster image upon a three-dimensional triangulated surface. This technique can provide fast results, especially when combined with the use of accelerated three-dimensional rendering hardware, but rendering can be slow when no such hardware is present. In addition, the result is only an approximation of the true distortion of the lens with accuracy being limited by the coarseness of the triangulated mesh. It would desirable to have a method for rendering an accurately distorted raster image quickly and without the need for specialized rendering hardware.
A need therefore exists for the fast and effective display of detail-in-context lens presentations in detail-in-context presentation systems. Consequently, it is an object of the present invention to obviate or mitigate at least some of the above mentioned disadvantages.
In general, the present invention provides for the effective presentation of detail-in-context lens type presentations in detail-in-context presentation systems through the use of improved rendering techniques.
According to one aspect of the invention, there is provided a method for generating a presentation of a region-of-interest in an information representation including the steps of: selecting a viewpoint for the region-of-interest; selecting a location for the region-of-interest; creating a lens surface having a predetermined location for the region-of-interest; creating a transformed presentation by: determining a mapping for pixel coordinates from the representation to the lens surface by applying a distortion function defining said lens surface to said pixel coordinates; calculating a vector from the predetermined location to the location; and, copying pixel information from the representation to the lens surface according to the mapping as displaced by the vector; and, displaying the transformed presentation on a display screen to generate the presentation of the region-of-interest. Preferably, the step of determining a mapping includes perspectively projecting the lens surface onto a plane spaced from the viewpoint. Preferably, the pixel information includes colour information.
Advantageously, the invention allows detail-in-context presentations that involve lens translations to be rendered without fully recalculating texel mappings.
Embodiments of the invention may best be understood by referring to the following description and accompanying drawings. In the description and drawings, line numerals refer to like structures or processes. In the drawings:
In the following description, numerous specific details are set forth to provide a thorough understanding of the invention. However, it is understood that the invention may be practiced without these specific details. In other instances, well-known software, circuits, structures and techniques have not been described or shown in detail in order not to obscure the invention.
The term “data processing system” is used herein to refer to any machine for processing data, including the computer systems and network arrangements described herein. The term “Elastic Presentation Space” (“EPS”) (or “Pliable Display Technology” (“PDT”)) is used herein to refer to techniques that allow for the adjustment of a visual presentation without interfering with the information content of the representation. The adjective “elastic” is included in the term as it implies the capability of stretching and deformation and subsequent return to an original shape. EPS graphics technology is described by Carpendale in “A Framework for Elastic Presentation Space” (Carpendale, Marianne S. T., A Framework for Elastic Presentation Space (Burnaby, British Columbia: Simon Fraser University, 1999)), which is incorporated herein by reference. In EPS graphics technology, a two-dimensional visual representation is placed onto a surface; this surface is placed in three-dimensional space; the surface, containing the representation, is viewed through perspective projection; and the surface is manipulated to effect the reorganization of image details. The presentation transformation is separated into two steps: surface manipulation or distortion and perspective projection.
EPS is applicable to multidimensional data and is well suited to implementation on a computer for dynamic detail-in-context display on an electronic display surface such as a monitor. In the case of two dimensional data, EPS is typically characterized by magnification of areas of an image where detail is desired 233, in combination with compression of a restricted range of areas of the remaining information (i.e. the context) 234, the end result typically giving the appearance of a lens 230 having been applied to the display surface. The areas of the lens 230 where compression occurs may be referred to as the “shoulder” 234 of the lens 230. The area of the representation transformed by the lens may be referred to as the “lensed area”. The lensed area thus includes the focal region and the shoulder. To reiterate, the source image or representation to be viewed is located in the basal plane 210. Magnification 233 and compression 234 are achieved through elevating elements of the source image relative to the basal plane 210, and then projecting the resultant distorted surface onto the reference view plane 201. EPS performs detail-in-context presentation of n-dimensional data through the use of a procedure wherein the data is mapped into a region in an (n+1) dimensional space, manipulated through perspective projections in the (n+1) dimensional space, and then finally transformed back into n-dimensional space for presentation. EPS has numerous advantages over conventional zoom, pan, and scroll technologies, including the capability of preserving the visibility of information outside 234 the local region of interest 233.
For example, and referring to
Method. The problem of rendering a raster image distorted through the use of PDT can be considered to be a problem of transforming texels between two image “spaces.” In general, a texel (i.e. texture element) may be defined as a texture map pixel or pixels. The texels from the undistorted image can be said to belong to the “source” image space (i.e. representation), and the texels from the distorted image belong to the “target” image space (i.e. presentation). In general, all rendering approaches must somehow determine colour values for each target texel using the known source texels and the known PDT transformation. According to the present invention, time consuming pre-calculations of the displacements of the corners of each texel are first performed. These pre-calculations are then used to speed up actual rendering cycles. This results in speedy rendering times for individual frames at the cost of the time required to perform pre-calculations. In general, a pre-calculation step is performed when properties of a lens such as magnification level, focal region size, or lens bounds size are changed. The pre-calculation step is not performed when the position of the lens is changed (e.g. lens dragging). Thus, the method is optimized for lens dragging but not for manipulation of other lens properties (e.g. re-sizing). The pre-calculation step is followed by a rendering step. For reference, various lens manipulations using a GUI are described in Canadian Patent Applications Nos. 2,345,803 and 2,350,342, which are incorporated herein by reference.
In addition, pre-calculated results can be re-used during multiple renderings as long as only the position of the lens is changed. As will be described below, the relationship of the transformed texel coordinates with the target image texels is used to generate an associative table.
In the pre-calculation step, the distorted position of the corners 402, 403, 404, 405 of each source texel 401 is computed by passing their coordinates through the PDT distortion function for the corresponding lens so that each source texel 401 is mapped onto one or more texels 411 in the target image 410. In other words, the distortion function defining the lens is applied to the corners of each source texel 401 to produce transformed texel corner coordinates. The application of the distortion function may include coordinate system transformations.
The process 500 for constructing the associative table involves the mapping of quadrilaterals (i.e. transformed texel corner coordinates 411) to square untransformed texels 401. In general, this does not result in an obvious 1:1 mapping or an obvious n:1 mapping. Sometimes a transformed texel is entirely contained in a target texel. At other times, it may barely touch the target texel. At still other times, it may overlap by a larger or partial amount. If anti-aliasing is desired, then a n:1 relationship may be constructed. If anti-aliasing is not desired, then a 1:1 relationship may be constructed. For 1:1 relationships, for each square target pixel 410 the “correct” transformed source pixel must be determined. This determination may take the form of choosing the transformed pixel the centre of which is closest to the centre of the target pixel. Or, this determination may take the form of choosing the transformed source pixel that overlaps the target pixel the most. For n:1 relationships, complexity increases. In this case, texels may be weighted differently and several different techniques may be used to determine which of several source pixels correspond with each individual target texel.
In summary, when texels 401 are transformed from source image space 400 to target image space 410, they are often no longer perfectly square. As a result, there is rarely an exact one-to-one correspondence between source texels 401 and target texels 410. As such, it is necessary to use a method of approximating texel coverage in order to construct the associative table. As mentioned above, different methods can be used to map transformed source texels onto target texels. To maximize speed, nearest neighbour matches can be used to map single source texels to single target texels. To maximize quality, anti-aliasing techniques call be used to take into account cases in which one target texel corresponds to multiple source texels. Anti-aliasing techniques can also incorporate weightings into the associative table in order to produce more accurate results.
According to an alternate embodiment of the invention, rather than displacing the coordinates of texel corners from source space to target space in the pre-calculation step, an inverse operation is performed as follows. For each of the pixels contained within the bounds of the lens, an “undisplace” (i.e. the inverse of displace) operation is used to find the related source pixel. An advantage of this alternate method is that fewer operations may be required because, in general, the source image is usually larger than the target image. As such, the lens bounds will contain fewer pixels in target space than source space. Therefore, fewer undisplace operations may be required to progress from target pixels to source pixels. This alternate method is most advantageous when an undisplace operation is computationally less costly than a displace operation and when the lens does not include folding.
Following the pre-calculation step, the rendering step is performed. Advantageously, the rendering step is computationally simple and fast as a result of the calculations already performed during the pre-calculation step. First, a global offset, as determined by the position of the lens in both the source space 400 and the target space 410 and the corresponding offset vectors 510, 520, is determined. Then, the associative table is traversed. For each entry in the table, the exact source texel position(s) and target texel position are determined using the table entry and global offset. Texel values are then copied. If there are multiple source texels corresponding to a single target texel, colour values must be averaged, or weighted according to predetermined weights, before the colour value is set. After all table entries have been traversed, the final image is complete.
With respect to copying, if anti-aliasing is not required, then texel values are copied from a single source texel to a single target pixel. This copying may be performed by a straight memory copy (e.g. a memcpy, assignment, or 1-pixel bitblt operation). It anti-aliasing is required, one pixel is drawn to but a number of pixels are read from. As such, a number of read operations are performed. The read values are combined, for example, through weighting, and then a single write operation is performed. Depending on the status of anti-aliasing, the nature of storage media (i.e. main memory or video memory), differences in platforms, operating systems, and related factors, several copying techniques can be used as follows:
With respect to weighting, several techniques can be used. For example, each pixel touched can be given an equal weight (i.e. averaged). Alternately, the exact coverage of each transformed pixel with the target pixel can be calculated and the weight can be related to the surface area of the coverage. Or, the distance from the center of each transformed pixel to the center of the target pixel can be determined and the weighting factor be related to that determined value. In addition, to increase speed, the number of pixels to be related may be limited by specifying that using a given weighting technique, a maximum of the N most strongly weighted pixels will be stored as being related, or that only pixels weighted greater than a value X will be stored.
If shading is desired, the copying may consist of a read operation, an operation to change the read value for shading purposes, and then a write operation. In other words, for shading, immediately before writing the colour value to the target pixel, the colour value is manipulated to darken it or lighten it by the desired amount to provide the desired shading effect. Any of the known shading algorithms may be used in this context.
As described, the present invention includes two main computation steps. First, the pre-computation step calculates mappings between texels in the source and target image buffers. Second, the step of rendering these mapped texels is performed. On a typical system 300 the first step is much more time consuming to perform. It would be advantageous to perform the time consuming calculation of the first step without interrupting the continuous and timely rendering performed during the step. To accomplish this, the two main steps may be separated into two separate threads for processing. The rendering thread can use the most recent complete results of the pre-computing thread repeatedly (i.e. allowing lens movement but not lens reshaping) while the pre-computing the thread computes updated texel mappings. Furthermore, the pre-computing thread can monitor the states of the lenses and pause itself when pre-computing is not necessary. In addition, the separate threads can be run on multiple processing units 320 in order to maximize performance.
As the pre-calculations for mappings between texels are computationally time consuming, to improve performance these mappings can be transmitted over a network from the data processing system 300 to a remote machine so that the remote machine need not perform the pre-calculations itself. The pixel mappings can be stored in a format transmittable over a network (e.g. compressed and/or encrypted) and sent to a remote machine where that remote machine can use the mappings to generate local presentations. This feature is advantageous in situations where two remote machines need to synchronize their displays. It is also advantageous in situations where a powerful machine (e.g. a server) performs the pre-calculations and sends them to a less powerful machine (e.g. a PDA).
Texel mappings produced during the pre-calculation step can be stored in a file which can be compressed or encrypted. This is advantageous as it allows a lens shape to be archived for later retrieval or sharing with other systems and users.
Data Carrier Product. The sequences of instructions which when executed cause the method described herein to be performed by the exemplary data processing system of
Computer Software Product. The sequences of instructions which when executed cause the method described herein to be performed by the exemplary data processing system of
Integrated Circuit Product. The sequences of instructions which when executed cause the method described herein to be performed by the exemplary data processing system of
Although preferred embodiments of the invention have been described herein, it will be understood by those skilled in the art that variations may be made thereto without department from the spirit of the invention or the scope of the appended claims.