The present invention relates to display and printing of graphic objects and in particular to the modification of displayed graphic objects using blend operations.
The display and printing of images by computer systems often involves some manipulation of the images, for example through combining the images using compositing operations or by modification using blend, or blending, operations. Other manipulations such as colour mapping may also be performed.
In compositing, graphic objects with transparency data may be combined using operators such as the well-known Porter and Duff operators (described in “Compositing Digital Images”, Porter, T, Duff, T; Computer Graphics, Vol 18 No 3 (1984) pp 253-259), in which the opacity is modelled as the proportion of a pixel that is covered by opaque data. When combining colour and opacity from two Objects A and B (Source and Destination objects respectively), the pixel is divided into four regions, as illustrated in
where:
αA=opacity (or “alpha”) of Object A
αB=opacity of Object B
The mathematical descriptions of these regions are used to define twelve compositing operators. All operators provide distinct combinations of these regions. Examples of the Porter and Duff operators applied to opaque objects are illustrated in
Porter and Duff operators can be summarised by three terms within a function that represent the three regions 10, 20, 30 that may be painted by any of the operators. The fourth region 40 where no source (Object A) or destination (Object B) colour is present cannot contribute to the resultant colour or opacity. The resultant colour multiplied by the resultant opacity at any pixel is given by:
Cresultαresult=F(CA,CB)αAαB+Y·CAαA(1−αB)+Z·CBαB(1−αA) (1)
where:
F(CA, CB)αAαB=a function selecting either the source or destination colour or no colour, multiplied by the product of the source and destination alpha. Hence this term can only be one of the following; CAαAαB, CBαAαB or 0. This term represents the [Source and Destination] region 10 in
Y·CAαA(1−αB)=the product of the source colour, source opacity or alpha, complement of the destination opacity, and a binary factor (Y; either 1 or 0). This term represents the [Source Only] region 20 in
Z·CBαB(1−αA)=the product of the destination colour, destination alpha, complement of the source opacity, and a binary factor (Z; either 1 or 0). This term represents the [Destination Only] region 30 in
The resultant opacity at any point is given by:
αresult=X·αAαB+Y·αA(1−αB)+Z·αB(1−αA) (2)
where:
X·αAαB=the product of the source opacity, destination opacity, and a binary factor (X; either 1 or 0). This term represents the [Source and Destination] region 10 in
Y·αA(1−αB)=the product of the source opacity, complement of the destination opacity, and the binary factor Y (either 1 or 0). This term represents the [Source Only] region 20 in
Z·αB(1−αA)=the product of the destination opacity, complement of the source opacity, and the binary factor Z (either 1 or 0). This term represents the [Destination Only] region 30 in
Table 1 lists the 12 Porter and Duff operators. A textual description is provided explaining how the operators relate to the equations and terms defined above.
It is common, however, only to use the src-over operator, where all three contributing regions 10, 20, 30 are used, and the colour of the region 10 where both objects are opaque is taken from the colour of the topmost (or source) object.
The src-over operator has also been used as the basis for blend, or blending, operations in systems where transparency data is used. In a blend operation, the source or blending object (Object A) or effect is used as a parameter of a blend function B that modifies the destination object (Object B). In the presence of transparency, the blend function operates on the region 10 where both objects are opaque, so that the src-over operator gives rise to an over-based blend operation:
Cover-blendαover-blend=CAαA(1−αB)+CBαB(1−αA)+B(CA,CB)αAαB (3)
αover-blend=αA(1−αB)+αB(1−αA)+αAαB (4)
where:
CA=colour of Object A;
CB=colour of Object B;
Cover-blend=resultant colour of over-based blend operation;
B(CA, CB)=blend function of Objects A and B;
αA=opacity of Object A;
αB=opacity of Object B; and
αover-blend=resultant opacity of over-based blend operation.
The src-over operator has the useful property that it does not modify pixels of the bottom object (Object B) outside the intersection of the two objects. However, a blend operation based on the src-over operator contains terms that include colour from both operands of the blending function. In some cases the resultant produced by an over-based blend operation may be undesirable. An example of such a case is described in the following three paragraphs.
When Object B is partially transparent i.e. αB<1, the colour of Object A contributes to the colour of the resultant other than through the blending function.
if (CA+CB)>=1
B(CA,CB)=1 (5)
else
B(CA,CB)=CB·1(1−CA) (6)
It is noted that CA and CB are normalised colour values in range [0, 1]. If CA has a value of 1, no matter what value CB has, the term of B(CA, CB) will be equal to 1.
The objects, 301 and 302, are shown separately in
This effect is particularly noticeable in the ‘dodge’ and ‘burn’ blending operations. The ‘dodge’ operator is intended to brighten the destination (Object B) colour to reflect the source (Object A) colour. Performing a ‘dodge’ operation with black is intended to produce no change. The ‘burn’ operator is intended to be complementary, and darken the destination colour to reflect the source colour. Performing a ‘burn’ operation with white is intended to produce no change.
There exists a need to be able to modify the result of a blend operation in order to produce an alternative effect.
A rendering system, which may be a framestore renderer, a bandstore renderer or a pixel sequential renderer, is provided with blending operations based on the Porter and Duff atop operator and the Porter and Duff in operator. These blending operations include colour from both operands in the result of the blend operation, but only through the term incorporating the blend function.
According to a first embodiment of the invention there is provided a method of compositing graphic elements in a pixel-based renderer, said method comprising the steps of:
receiving a first graphic element having a first colour and a first opacity and a second graphic element having a second colour and a second opacity;
determining a blend output of a blend function dependent on the first colour and the second colour; and
determining a resultant colour of a compositing operation on the first and second graphic elements, the resultant colour being dependent on the blend output and otherwise being independent of the second colour.
According to a second aspect of the invention there is provided a method of compositing a first graphic element comprising a first colour and a first opacity with a second graphic element comprising a second colour and a second opacity using a blend function that operates on the two colours independently of their respective opacities and a compositing operator characterised in that the contribution of the second graphic element colour to the resultant colour is independent of the first opacity of the first graphic element.
According to a further aspect of the invention there is provided an apparatus for compositing graphic elements in a pixel-based renderer, said apparatus comprising:
means for receiving a first graphic element having a first colour and a first opacity and a second graphic element having a second colour and a second opacity;
means for determining a blend output of a blend function dependent on the first colour and the second colour; and
means for determining a resultant colour of a compositing operation on the first and second graphic elements, the resultant colour being dependent on the blend output and otherwise being independent of the second colour.
According to a further aspect of the invention there is provided a computer program product comprising machine-readable program code recorded on a machine-readable recording medium, for controlling the operation of a data processing apparatus on which the program code executes to perform a method of compositing graphic elements in a pixel-based renderer, said method comprising the steps of:
receiving a first graphic element having a first colour and a first opacity and a second graphic element having a second colour and a second opacity;
determining a blend output of a blend function dependent on the first colour and the second colour; and
determining a resultant colour of a compositing operation on the first and second graphic elements, the resultant colour being dependent on the blend output and otherwise being independent of the second colour.
According to a further aspect of the invention there is provided a computer program comprising machine-readable program code for controlling the operation of a data processing apparatus on which the program code executes to perform a method of compositing graphic elements in a pixel-based renderer, said method comprising the steps of:
receiving a first graphic element having a first colour and a first opacity and a second graphic element having a second colour and a second opacity;
determining a blend output of a blend function dependent on the first colour and the second colour; and
determining a resultant colour of a compositing operation on the first and second graphic elements, the resultant colour being dependent on the blend output and otherwise being independent of the second colour.
Other aspects of the invention are also disclosed.
One or more embodiments of the invention will now be discussed with reference to the drawings, in which:
Where reference is made in any one or more of the accompanying drawings to steps and/or features, which have the same reference numerals, those steps and/or features have for the purposes of this description the same function(s) or operation(s), unless the contrary intention appears.
A rendering system is provided with operations for compositing based on the Porter and Duff model as described in “Compositing Digital Images”, Porter, T: Duff, T; Computer Graphics, Vol 18 No 3 (1984) pp 253-259, with the addition of blending operations. In the Porter and Duff model, a pixel in an object is notionally divided into two regions, one fully opaque and one fully transparent, such that the proportion of the pixel that is opaque is given by the opacity, a (or so in the notation of
If two objects S and D overlap, their opacities act independently such that each pixel in the overlap region is divided into four regions, orthogonally, as shown in
A set of flags controlling the contribution of the regions provides a flexible means of determining the Porter and Duff operation to be performed.
The Porter and Duff operators are formed by combining colour and opacity contributed by combinations of the aforementioned regions. The original Porter and Duff operators are formed from the complete set of combinations of these regions where the intersecting region S ROP D 720 takes the colour of the uppermost (higher priority) object.
In the described arrangements, a rendering system, which can be a framestore renderer, a bandstore renderer or a pixel sequential renderer, is provided with blend operations based on the Porter and Duff atop (ie. src-atop) operator. These operations are distinct from both their predecessors, i.e. the Porter and Duff operators and the prior art over (ie. src-over) based blend operations. Porter and Duff operators only allow inclusion or non-inclusion of colour and transparency values obtained directly from the objects. Objects to be rendered are often referred to as “graphic elements” in the art. The prior art blend operations explicitly include colour from both operands in the result of the blend.
The basic atop operator as defined by Porter and Duff is as follows:
αresultCresult=(1−αA)αBCB+αAαBCA (7)
In the first arrangement, the atop operator is modified such that the colour of the region where both objects are opaque is determined by the blending function, B(CA, CB):
αresultCresult=(1−αA)αBCB+αAαBB(CA,CB) (8)
αresultαB (9)
Like the over operator, the atop operator does not modify pixels of object B outside the intersection of the two objects. The atop operator is therefore suitable for use in a framestore system, as discussed in more detail below. Furthermore, the blend operation based on atop does not include a term in which object A directly contributes colour. The only effect of the colour of object A on the result is through the blending function. Note also that the resultant (non-premultiplied) colour is independent of the opacity of Object B.
A similar blend operation may be constructed by including the colour term from object A and not including that of object B, i.e. a blend operation based on the Porter and Duff ratop (ie. dst-atop) operator. However such an operator potentially modifies all of the pixels of object B, which makes it expensive to implement in a framestore system where object B has been stored in the framestore.
Blend operations may also be constructed based on the Porter and Duff in (ie. src-in) operator. The basic in operator as defined by Porter and Duff is as follows:
αresultCresultαAαBCA (10)
In the arrangements described herein, the in-based blend operation is:
αresultCresult=αAαBB(CA,CB) (11)
αresultαAαB (12)
The in operator has the undesirable property that it potentially modifies an object over the entire extent of the object. The in operator is therefore expensive to use in a framestore system. This expense is due to the modification of previously rendered objects by clearing the objects outside the area of intersection. However, blend operations based on the in operator are potentially useful operations and are included for completeness.
The remaining Porter and Duff operators do not include the region where both objects overlap and are therefore not suitable candidates for use with blending operations.
The blend functions B used in the described arrangements may be ‘Dodge’ or ‘Burn’ functions, which have the following form:
Dodge:
Burn:
Note that in these definitions CA and CB are normalised colours, i.e. valued in the range [0, 1].
The above-described components of the system 1 are interconnected via a bus system 9 and are operable in a normal operating mode of computer systems well known in the art.
Also seen in
The pixel sequential renderer 18 operates generally speaking in the following manner. A render job to be rendered is given to driver software on processor 2 by third party software, for supply to the pixel sequential renderer 18. The render job is typically in a page description language which defines an image comprising objects placed on a page from a rearmost object to a foremost object, to be composited in a manner defined by the render job. The driver software converts the render job to an intermediate render job, which is then fed to the pixel sequential renderer 18.
The pixel sequential renderer 18 generates the colour and opacity for the pixels one at a time in raster scan order. At any pixel currently being scanned and processed, the pixel sequential renderer 18 composites only those exposed objects that are active at the currently scanned pixel. The pixel sequential renderer 18 determines that an object is active at a currently scanned pixel if that pixel lies within the boundary of the object. The pixel sequential renderer 18 achieves this by reference to a fill counter associated with that object. The fill counter keeps a running fill count that indicates whether the pixel lies within the boundary of the object. When the pixel sequential renderer 18 encounters an edge associated with the object the renderer increments or decrements the fill count depending upon the direction of the edge. The renderer 18 is then able to determine whether the current pixel is within the boundary of the object depending upon the fill count and a predetermined winding count rule. The pixel sequential renderer 18 determines whether an active object is exposed with reference to a flag associated with that object. This flag associated with an object indicates whether or not the object obscures lower order objects. That is, this flag indicates whether the object is partially transparent, in which case the lower order active objects make a contribution to the colour and opacity of the current pixel. Otherwise, this flag indicates that the object is opaque, in which case active lower order objects will not make any contribution to the colour and opacity of the currently scanned pixel. The pixel sequential renderer 18 determines that an object is exposed if it is the uppermost active object, or if all the active objects above the object have their corresponding flags set to transparent.
The pixel sequential renderer 18 then composites these exposed active objects to determine and output the colour and opacity for the currently scanned pixel.
The driver software, in response to the page, also extracts edge information defining the edges of the objects for feeding to an edge tracking module. The driver software also generates a linearised table (herein after called the priority properties and status table) of the expression tree of the objects and their compositing operations which is fed to the priority determination module. The priority properties and status table contains one record for each object on the page. In addition, each record contains a field for storing a pointer to an address for the fill of the corresponding object in a fill table. This fill table is also generated by the driver software and contains the fill for the corresponding objects, and is fed to the fill determination module. The priority properties and status table together with the fill table are devoid of any edge information and effectively represent the objects, where the objects are infinitively extending. The edge information is fed to the edge tracking module, which determines, for each pixel in raster scan order, the edges of any objects that intersect a currently scanned pixel. The edge tracking module passes this information onto the priority determination module. Each record of the priority properties and status table contains a counter, which maintains a fill count associated with the corresponding object of the record.
The priority determination module processes each pixel in a raster scan order. Initially, the fill counts associated with all the objects are zero, and so all objects are inactive. The priority determination module continues processing each pixel until it encounters an edge intersecting that pixel. The priority determination module updates the fill count associated with the object of that edge, and so that object becomes active. The priority determination continues in this fashion updating the fill count of the objects and so activating and de-activating the objects. The priority determination module also determines whether these active objects are exposed or not, and consequently whether they make a contribution to the currently scanned pixel. In the event that they do, the pixel determination module generates a series of messages which ultimately instructs the pixel compositing module to composite the colour and opacity for these exposed active objects in accordance with the compositing operations specified for these objects in the priority properties and status table so as to generate the resultant colour and opacity for the currently scanned pixel. These series of messages do not actually contain the colour and opacity for that object but rather an address to the fill table, which the fill determination module uses to determine the colour and opacity of the object.
For ease of explanation the location (viz level) of the object in the order of the objects from the rearmost object to the foremost is herein referred to as the object's priority. Preferably, a number of non-overlapping objects that have the same fill and compositing operation, and that form a contiguous sequence in the order of the objects, may be designated as having the same priority.
The pixel sequential renderer also utilises clip objects to modify the shape of another object. The pixel sequential renderer maintains an associated clip count for the clip in a somewhat similar fashion to the fill count to determine whether the current pixel is within the clip region.
There are often runs of pixels having constant colour and opacity between adjacent edges. The pixel sequential renderer can composite the colour and opacity for the first pixel in the run and in subsequent pixels in the run reproduce the previous composited colour and opacity without any further compositions, thus reducing the overall number of compositing operations.
A software program (hereafter referred to as the driver), is loaded and executed on the host processor 2 for generating instructions and data for the pixel-sequential graphics rendering apparatus 18, from data provided by a third-party application. The third-party application may provide data in the form of a standard language description of the objects to be drawn on the page, such as PostScript and PCL, or in the form of function calls to the driver through a standard software interface, such as the Windows GDI or X-11.
The driver software separates the data associated with an object (supplied by the third-party application) into data about the edges of the object, any operation or operations associated with painting the object onto the page, and the colour and opacity with which to fill pixels which fall inside the edges of the object.
The driver software partitions the edges of each object into edges which are monotonic increasing in the Y-direction, and then divides each partitioned edge of the object into segments of a form suitable for the edge module described below. Partitioned edges are sorted by the X-value of their starting positions and then by Y. Groups of edges starting at the same Y-value remain sorted by X-value, and may be concatenated together to form a new edge list, suitable for reading in by the edge module when rendering reaches that Y-value.
The driver software sorts the operations, associated with painting objects, into priority order, and generates instructions to load the data structure associated with the priority determination module. This structure includes a field for the fill rule, which describes the topology of how each object is activated by edges, a field for the type of fill which is associated with the object being painted, and a field to identify whether data on levels below the current object is required by the operation. There is also a field, herein called clip count, that identifies an object as a clipping object, that is, as an object which is not, itself, filled, but which enables or disables filling of other objects on the page.
The driver software also prepares a data structure (the fill table) describing how to fill objects, said fill table is indexed by the data structure in the priority determination module. This allows several levels in the priority determination module to refer to the same fill data structure.
The driver software assembles the aforementioned data into a job containing instructions for loading the data and rendering pixels, in a form that can be read by the rendering system, and transfers the assembled job to the rendering system. This may be performed using one of several methods known to the art, depending on the configuration of the rendering system and its memory.
Referring now to
For example,
In
It will be apparent from the above that the ability to handle plural data formats describing edge segments allows for simplification of edge descriptions and evaluation, without reliance on complex and computationally expensive mathematical operations. In contrast, in the system of
The rendering system will be described with reference to the simple example of rendering an image 78 shown in
The blue triangular object 80 however is defined by three object edges 82, 84 and 86, each seen as vectors that define the vertices of the triangle. Edges 82 and 84 are seen to commence at pixel location (100,20) and extend respectively to pixel locations (170,90) and (30,90). Edge 86 extends between those two pixel locations in a traditional rasterised direction of left to right. In this specific example because the edge 86 is horizontal like the edges 96 and 98 mentioned above, it is not essential that the edge 86 be defined. In addition to the starting and ending pixel locations used to describe the edges 82 and 84, each of these edges will have associated therewith the slope value, in this case +1 and −1 respectively.
Returning to
The display list generation 15 is preferably implemented as a software driver executing on the host processor 2 with attached ROM 6 and RAM 3. The display list generation 15 converts an object graphics description, expressed in any one or more of the well known graphic description languages, graphic library calls, or any other application specific format, into a display list. The display list is typically written into a display list store 16, generally formed within the RAM 4 but which may alternatively be formed within the rendering stores 13 (
The instruction stream 24 includes code interpretable as instructions to be read by the pixel sequential rendering apparatus 18 to render the specific graphic objects desired in any specific image. For the example of the image shown in
Similarly, the edge information 25 for the example of
(i) edge 84 commences at pixel position 100, edge 82 commences at pixel position 100;
(ii) edge 92 commences at pixel position 40, edge 94 commences at pixel position 160;
(iii) edge 84 runs for 70 scan lines, edge 82 runs for 70 scanlines;
(iv) edge 84 has slope=−1, edge 84 has slope=+1;
(v) edge 92 has slope=0 edge 94 has slope=0.
(vi) edges 92 and 94 each run for 70 scanlines.
It will be appreciated from the above example of the instruction stream 24 and edge information 25 and the manner in which each are expressed, that in the image 78 of
The display list store 16 is read by the pixel sequential rendering apparatus 18, which is typically implemented as an integrated circuit. The pixel sequential rendering apparatus 18 converts the display list into a stream of raster pixels 19 which can be forwarded to another device, for example, a printer, a display, or a memory store.
The pixel sequential rendering apparatus 12 may be implemented as an integrated circuit, or it may be implemented as an equivalent software module executing on a general purpose processing unit, such as the host processor 2.
As is shown in
The display list store 16 and the other stores 32-38 detailed above may be implemented in RAM or any other data storage technology.
The processing stages 22 shown in the arrangement of
The operation of the pixel compositing module 700 (
Preferably, the pixel compositing module 700 implements a modified form of the compositing approach as described in “Compositing Digital Images”, Porter, T: Duff, T; Computer Graphics, Vol 18 No 3 (1984) pp 253-259. Examples of Porter and Duff compositing operations are shown in
Preferably, the images to be composited are based on expression trees. Expression trees are often used to describe the compositing operations required to form an image, and typically comprise a plurality of nodes including leaf nodes, unary nodes and binary nodes. A leaf node is the outermost node of an expression tree, has no descendent nodes and represents a primitive constituent of an image. Unary nodes represent an operation which modifies the pixel data coming out of the part of the tree below the unary operator. A binary node typically branches to left and right subtrees; wherein each subtree is itself an expression tree comprising at least one leaf node. An example of an expression tree is shown in
Turning now to
The compositing operations of the expression tree are implemented by means of the pixel compositing stack 38 (
A message sequence 2212 is illustrated in
Referring again to
During the operation of the pixel compositing module 700, the decoder 2302, upon the receipt of a colour composite message, extracts the raster operation COLOR_OP and alpha channel operation codes ALPHA_OP and passes them to the compositor 2304. The decoder 2302 also extracts the stack operation STACK_OP and colour and opacity values COLOR, ALPHA of the colour composite message and passes them to the stack controller 2306. Typically, the pixel compositing module 700 combines the colour and opacity from the colour composite message with a colour and opacity popped from the pixel compositing stack 38 according to the raster operation and alpha channel operation from the colour composite message. The module 700 then pushes the result back onto the pixel compositing stack 38. More generally, the stack controller 2306 forms a source (src) and destination (dest) colour and opacity, according to the stack operation specified. If at this time, or during any pop of the pixel compositing stack, the pixel compositing stack 38 is found to be empty, an opaque white colour value is used without any error indication. These source and destination colours and opacity are then made available to the compositor 2304 which performs the compositing operation in accordance with the COLOR_OP and ALPHA_OP codes. The resultant (result) colour and opacity is then made available to the stack controller 2306, which stores the result on the stack 38 in accordance with the STACK_OP code. These stack operations are described below in more detail.
During the operation of the pixel compositing module 700, if the decoder 2302 receives an end of pixel message, it then instructs the stack controller 2306 to pop a colour and opacity from the pixel compositing stack 38. If the stack 38 is empty an opaque white value is used. The resultant colour and opacity is then formed into a pixel output message which is forwarded to the pixel output FIFO 702. If the decoder 2302 receives a repeat message or an end of scanline message, the decoder 2302 by-passes (not illustrated) the compositor 2304 and stack controller 2306 and forwards the messages to the pixel output FIFO 702 without further processing.
Other stack operations may also be used.
The manner in which the compositor 2304 combines the source (src) colour and opacity with the destination (dest) colour and opacity will now be described with reference to
The process of combining the source and destination colour, as distinct from the other operations discussed above, is termed a raster operation and is one of a set of functions as specified by the raster operation code from the pixel composite message. Some of the raster operations are shown in
The alpha channel operation from the composite pixel message is also considered during the combination of the source and destination colour. The alpha channel operation is performed using three flags LAO_USE_D_OUT_S. LAO_USE_S_OUT_D, LAO_USE_S_ROP_D, which respectively identify the regions of interest: (1−so)*do, so*(1−do), and so*do in the overlay of the source pixel 702 and the destination pixel 710. For each of the regions, a region opacity value is formed which is zero if the corresponding flag in the alpha channel operation is not set, else it is the area of the region.
The resultant opacity is formed from the sum of the region opacities. Each component of the result colour is then formed by the sum of the products of each pair of region colour and region opacity, divided by the resultant opacity.
As shown in
The resultant colour and opacity is passed to the stack controller circuit and pushed onto the pixel compositing stack 38. However, if the stack operation is STACK_KEEP_SRC, the source value is pushed onto the stack before the result of the colour composite message is pushed.
When an end of pixel message is encountered, the colour and opacity value on top of the stack is formed into a pixel output message, and sent to the Pixel Output module. Repeat pixel messages are passed through the Pixel Compositing module to the Pixel Output module.
The pixel sequential rendering apparatus 18 described above can perform the standard ‘over’ based blending operations. These operations are described in the background art. The equation to describe an ‘over’ based blending operation is:
αresultCresult=αA(1−αB)CA+(1−αA)αBCB+αAαBB(CA,CB) (17)
αresultαA(1−αB)+(1−αA)αB+αAαB (18)
where B(CA, CB) is the blending function.
To perform such a blending operation, the software driver sets the COLOR_OP operation code to the appropriate value to represent the blending function, B(CA, CB). The driver sets the three ALPHA_OP flags LAO_USE_D_OUT_S. LAO_USE_S_ROP_D and LAO_SE_S_OUT_D. Setting these flags indicates that all three regions of interest should be considered in this calculation.
The pixel sequential rendering apparatus 18 in the first arrangement is also driven in such a way as to implement the atop-based blending operation:
αresultCresult=(1−αA)αBCB+αAαBB(CA,CB) (19)
αresult=αB (20)
Performing the blending operation as described by Equations (19) and (20) does not permit the colour of the blending object (Object A) to influence the resultant colour except through the blending function. The modified atop-based blending operations also share the benefit of the over-based blending operations that when an effect is applied, the effect is restricted to the area of the blending object, i.e. Object B is not modified outside the area of intersection with Object A. The blending function used for the blending operation, B(CA, CB), will be controlled using the COLOR_OP opcode.
To blend using the atop-based blending operation as described above the software driver sets the LAO_USE_D_OUT_S and the LAO_USE_S_ROP_D flags in the priority table entries that control the effect, leaving the LAO_USE_S_OUT_D flag unset.
The atop based blending operation is advantageous compared to blending operations based upon the over operator as the colour of the effect (object A) only affects the resultant composited value through the blending function.
The pixel sequential rendering apparatus 18 is also capable of implementing blending operations based on the Porter and Duff in operator. The modified in-operator-based blending operations may be expressed as:
αresultCresult=αAαBB(CA,CB) (21)
αresult=αAαB (22)
This can be realised in the pixel sequential rendering apparatus 18 described previously by only setting the LAO_USE_S_ROP_D flag and leaving both the LAO_USE_D_OUT_S and LAO_USE_S_OUT_D flags unset. Once again the COLOR_OP opcode should be set appropriately for the blending function required, B(CA, CB). This modified operator has the disadvantage of modifying pixels over the entire area of Object B.
In an alternative arrangement, the atop-based blending operations are implemented in a framestore (alternatively called a Painter's Algorithm) renderer. A framestore renderer is well known in the prior art and will not be explained in great detail. In general, a framestore render immediately renders each graphical object to a memory representing the entire image. The memory will typically be a matrix/array of pixels. For this particular implementation the framestore renderer must also be able to read the values previously written into the framestore. This particular framestore must contain both colour and opacity values, the opacity values being normalised to the range 0 to 1.
A blending operation based on the Porter and Duff over compositing operation is known in the prior art to be suited to a framestore renderer. A blending operation based on the atop Porter and Duff operator according to the present disclosure is also suitable for a framestore renderer. Equations (19) and (20) show the modified atop-based blending operation.
Object B may be considered to be the background that is already written into the framestore. Object A is the object to be blended with the background (Object B). The result of blending Object A with Object B has the opacity of Object B. The colour of the result is the sum of two terms, one a product of the opacities of Objects A and B and the blending function, the other term a product of the opacity of Object B, the complement of the opacity of Object A (i.e. the transparency of Object A), and the colour of Object B.
Object B has already been drawn to the frame store. Object A is then to be blended with Object B. For each pixel in Object A, the corresponding colour and opacity values are read from the framestore for Object B. These colour and opacity values are used in conjunction with the values from Object A and the blending function to determine the new colour value for the corresponding framestore pixel. This new value is written into the framestore to replace the previous value. The opacity value for this pixel does not need to change, as the resultant opacity is equal to the opacity of Object B.
The atop based blending operation of the first arrangement may be implemented using a method 2600 as shown in
Method 2600 then enters a loop which steps through the pixels of Object A. In step 2602, which is the first step in the loop, the corresponding colour value for the current pixel is read from the buffer containing Object B. Then, in step 2603, the colour and opacity of Object A and Object B are used to calculate the new colour value for the pixel of the buffer containing Object B. If Object B has not painted this pixel of the buffer, the colour and opacity information used is that of transparent black.
In step 2604 the new colour value is then written into the buffer containing object B. When using atop based blending operations the opacity of the buffer containing Object B does not change.
Next, in step 2605, the method 2600 checks whether there are any more pixels in Object A. If so, (the YES option of step 2605), execution proceeds to step 2607, in which the colour and opacity of the next pixel in Object A are obtained before the method 2600 returns to step 2602 from where the next pixel is processed. If there are no pixels left in Object A (the NO option of step 2605), the method 2600 ends in step 2606.
The results of the blend using the framestore renderer are identical to those of the pixel sequential rendering arrangement described in section 4.0.
Object A or Object B may be a group of objects that are, for the purposes of compositing, treated as a single object. In particular Object B may be the background, i.e. the result of previous rendering and compositing operations.
A modified blending operation based on the Porter and Duff in operator may also be implemented in the framestore renderer. This modified operator is less advantageous in a framestore renderer than the blending operation based on the atop operator. The complication is that the use of the in operator means that pixels are modified over the entire area of the operator. More specifically pixels modified by this operation are not limited to the intersection of the two objects. All pixels within the union of object A and object B are modified by a blend operation based on the in operator.
Equations (21) and (22) represent an in based blending operation.
Object B can be considered to be the background that is already written into the framestore. Object A is the object to be blended with the background (Object B). The result of blending Object A with Object B has opacity equal to the product of Object A and Object B's opacities. The resulting pre-multiplied colour is the product of the opacities of Objects A and B and the blending function. Object B and Object A are cleared (i.e. set to transparent black) outside the intersecting region.
The Foreground Correction Method described herein is a method for modifying the result of blending operations to produce a desired effect or alternative result. The Foreground Correction Method may be particularly advantageous when an underlying software graphics library or a graphics or rendering system (e.g. the pixel sequential rendering apparatus 18 shown in
The generalised Foreground Correction Method 400 starts in step 401 where the Current Background (Object B) is obtained. Obtaining the Current Background may involve retrieving or calculating the in-memory representation of either a subset or all of the previously rendered objects. The Current Background (Object B) will be known as a First Graphic Element containing colour and opacity values. Similarly Object A will be known as a Second Graphic Element containing colour and opacity values. The Current Background may be retrieved from the rendering stores 830.
In step 402 a copy of the First Graphic Element (Object B) is made prior to any blending operations. The copy of the First Graphic Element (Object B) will be known as the Object A Contribution Buffer.
In step 403 the Second Graphic Element (Object A) is composited into the Object A Contribution Buffer using a Porter and Duff operator. The resultant of this compositing operation can be considered to be a First Intermediate Result.
In step 404 the Second Graphic Element (Object A) is composited with the First Graphic Element (Object B) using a blend operation. This resultant can be considered to be a Second Intermediate Result. Note that the blend operation used to produce this result could be a blend operation based on any Porter and Duff operator, even though in many systems the only available blend operation is based on the Porter and Duff src-over operator.
Finally, in step 405, the colour and opacity values of the First Intermediate Result (result in Object A Contribution Buffer) are combined with the colour and opacity values of the Second Intermediate Result (Current Background result) to produce a final result. The combining step may be an addition or a subtraction, depending on the blending operation being performed.
In a first arrangement, the Foreground Correction Method corrects the resultant of compositing the Objects A and B using an over-based blend operation. In the example of
Object A 506 represents the desired graphic object to composite with previously composited objects. In the example, Object A 506 (identifiable with object 302 in
The first step 501 of the first arrangement is to obtain the Current Background (Object B) 507 (as in step 401). Obtaining the Current Background 507 may involve retrieving or calculating the in-memory representation of either a subset or all of the previously rendered objects. The Current Background 507 will be known as a First Graphic Element containing colour and opacity values. Similarly Object A will be known as a Second Graphic Element containing colour and opacity values.
In step 502 (as in step 402), a copy of the Current Background 507 is made prior to any blending operations. The copy 508 of the Current Background is stored in the Object A Contribution Buffer. At this point the contents of both the Current Background 507 and the Object A Contribution Buffer 508 should be identical.
In step 503 (a special case of step 403) the Second Graphic Element (Object A) 506 is composited into the Object A Contribution Buffer using the src-out Porter and Duff operator:
Csrc-outαsrc-out=CAαA(1−αB) (23)
αsrc-out=αA(1−αB) (24)
where:
Csrc-out=resultant colour of src-out Porter and Duff operator; and
αsrc-out=resultant opacity of src-out Porter and Duff operator.
This resultant 509 can be considered to be a First Intermediate Result.
In step 504 (a special case of step 404) the Second Graphic Element (Object A) 506 is composited with the First Graphic Element 507 using an over-based ‘dodge’ blend operation
Cover-blendαover-blend=CAαA(1−αB)+CBαB(1−αA)+B(CA,CB)αAαB (25)
αover-blend=αA(1−αB)+αB(1−αA)+αAαB (26)
where (for a ‘dodge’ operation) B(CA, CB) is defined as:
if (CA+CB)>=1
B(CA,CB)=1 (27)
else
B(CA,CB)=CB·1/(1−CA) (28)
This resultant 510 (identifiable with the result 303 of
At this point it can be seen that the contents 510 of the Current Background differ from the contents 509 of the Object A Contribution Buffer. The contents 509 of the Object A Contribution Buffer only include those portions of the grey triangle 507 that overlap Object A 506.
Finally, in step 505 (a special case of step 405), the opacity and colour of the First Intermediate Result 509 (result in Object A Contribution Buffer) is subtracted from the opacity and colour values of the Second Intermediate Result 510 (stored in the Current Background) to produce the result 511 (stored in the Current Background). In the example the result 511 (identifiable with the result 305 of
Cresultαresult=Cover-blendαover-blend−Csrc-outαsrc-out (29)
Substitute in Cover-blendαover-blend (over-based blending operation) and Csrc-outαsrc-out (src-out Porter and Duff operator):
=CAαA(1−αB)+CBαB(1−αA)+B(CA,CB)αAαB−[CAαA(1−αB)]
=CAαA−CAαAαB+CBαB−CBαBαA+B(CA,CB)αAαB−CAαA+CAαAαB
=CBαB−CBαBαA+B(CA,CB)αAαB
=CBαB(1−αA)+B(CA,CB)αAαB
=Catop-blendαatop-blend (30)
and
αresult=αover-blend−αsrc-out (31)
Substitute in αover-blend and αsrc-out equations
=αA(1−αB)+αB(1−αA)+αAαB−[αA(1−αB)]
=αAαAαB+αB−αAαB+αAαB−αA+αAαB
=αB
=αatop-blend (32)
Thus the final result produced by the first arrangement is identical to the result of the atop-based ‘dodge’ blend operation.
In a second arrangement, the Foreground Correction Method 400 corrects the resultant of compositing an over-based blending operation to produce the effects of an in-based blending operation.
As in the method 400 of
In step 661 the Current Background (Object B) is obtained. Obtaining the Current Background may involve retrieving or calculating the in-memory representation of either a subset or all of the previously rendered objects. The Current Background (Object B) will be known as a First Graphic Element containing colour and opacity. Similarly Object A will be known as a Second Graphic Element containing colour and opacity values.
In step 662 a copy of the Current Background is made prior to any blending operations. The copy of the Current Background is stored in the Object A Contribution Buffer.
In step 663 the Second Graphic Element (Object A) is composited into the Object A Contribution Buffer using the Porter and Duff xor operator:
Cxorαxor=CAαA(1−αB)+CBαB(1−αA) (33)
αxor=αA+αB−2 αAαB (34)
where:
Cxor=resultant colour of xor Porter and Duff operator; and
αxor=resultant opacity of xor Porter and Duff operator.
This resultant can be considered to be a First Intermediate Result. The Second Graphic Element (Object A) is then further composited, in step 664, with the First Graphic Element using an over-based blending operation 664. The result is stored in the Current Background. In this arrangement a ‘dodge’ function will be used in the blend operation:
Cover-blendαover-blend=CAαA(1−αB)+CBαB(1−αA)+B(CA,CB)αAαB (35)
αover-blend=αA(1−αB)+αB(1−αA)+αAαB (36)
where (for a ‘dodge’ operation) B(CA, CB) is defined as:
if (CA+CB)>=1
B(CA,CB)=1 (37)
else
B(CA,CB)=CB·1/(1−CA) (38)
This resultant of the over-based blend ‘dodge’ operation can be considered to be a Second Intermediate Result.
Finally, in step 665, the opacity and colour of the First Intermediate Result (result in Object A Contribution Buffer) is subtracted from the opacity and colour values of the Second Intermediate Result (Current Background result)
Cresultαresult=Cover-blendαover-blend−Cxorαxor (39)
Substitute in Cover-blendαover-blend (over-based blending operation) and Cxorαxor (xor Porter and Duff operator)
=CAαA(1−αB)+CBαB(1−αA)+B(CA,CB)αAαB−[CAαA(1−αB)+CBαB(1−αA)]
=CAαA(1−αB)+CBαB(1−αA)+B(CA,CB)αAαB−CAαA(1−αB)−CBαB(1−αA)
=B(CA,CB)αAαB
=Cin-blendαin-blend (40)
and
αresult=αover-blend−αxor (41)
Substitute in αover-blend and αxor equations
=αA(1−αB)+αB(1−αA)+αAαB[αA+αB−2αAαB]
=αA−αAαB+αB−αAαB+αAαB−αA−αB+2αAαB
=αAαB
=αin-blend (42)
Thus the result of the step 665 is identical to the result that would have been obtained using the in-based ‘dodge’ blend operation. Thus, the second arrangement may be used to obtain the effect of an in-based blend, even though the only available blend operation is over-based.
The Foreground Correction Method 400 is used to derive a final blending result from an initial blending result. Effectively the Foreground Correction Method 400 can replace Porter and Duff based blending operations that are part of a rendering procedure. An example of such a case is illustrated in
If the desired Porter and Duff based blending operation is unavailable to the graphics or rendering system, the Foreground Correction Method 400 can be used. The Foreground Correction Method 400 is used to blend the group of objects 701 (Current Background) and Object A to produce the desired effect. From this point the graphics or rendering system could continue with the remaining rendering process 703.
As demonstrated in
The first row of Table 2 corresponds to the first arrangement, in which the effect of an atop-based blend is obtained using an over-based blend. The second row of Table 2 corresponds to the second arrangement, in which the effect of an in-based blend is obtained using an over-based blend.
The following four rows of Table 2 summarise further arrangements of method 400. The first column of Table 2 shows the blending operation used in step 404, i.e. a blending operation that is actually available in the rendering system. The second column of Table 2 shows the Porter and Duff operator that is used in step 403 in each of the arrangements. The third column of Table 2 shows the combining operation used in each of the arrangements. The final column shows the blend operation of which the effect is reproduced in the corresponding arrangement.
It is apparent from the above that the disclosed methods are applicable to the data processing industries.
The foregoing describes only some embodiments of the present invention, and modifications and/or changes can be made thereto without departing from the scope of the invention, the embodiment(s) being illustrative and not restrictive. The disclosure is presented primarily in terms of a printer engine. However, the disclosed arrangements may be used in any system that requires a renderer.
Number | Date | Country | Kind |
---|---|---|---|
2005229627 | Oct 2005 | AU | national |
2005229629 | Oct 2005 | AU | national |
Number | Name | Date | Kind |
---|---|---|---|
5745121 | Politis | Apr 1998 | A |
6028583 | Hamburg | Feb 2000 | A |
6184891 | Blinn | Feb 2001 | B1 |
6185342 | Hamburg et al. | Feb 2001 | B1 |
6421460 | Hamburg | Jul 2002 | B1 |
6480201 | Fushiki et al. | Nov 2002 | B1 |
6483519 | Long et al. | Nov 2002 | B1 |
6828985 | Long et al. | Dec 2004 | B1 |
6961067 | Moore | Nov 2005 | B2 |
6970169 | Harris | Nov 2005 | B1 |
7046253 | Long et al. | May 2006 | B2 |
7167184 | Graham | Jan 2007 | B2 |
7184055 | Hamburg | Feb 2007 | B2 |
7277102 | Moore | Oct 2007 | B2 |
7483036 | Moore | Jan 2009 | B2 |
20020015039 | Moore | Feb 2002 | A1 |
20030016221 | Long et al. | Jan 2003 | A1 |
20030179200 | Martin et al. | Sep 2003 | A1 |
20030193508 | Graham | Oct 2003 | A1 |
20040085559 | Danilo | May 2004 | A1 |
20040189656 | Moore | Sep 2004 | A1 |
20050195220 | Northway et al. | Sep 2005 | A1 |
20060114263 | Moore | Jun 2006 | A1 |
20060187235 | Hamburg | Aug 2006 | A1 |
20070126753 | Moore et al. | Jun 2007 | A1 |
Number | Date | Country | |
---|---|---|---|
20070126753 A1 | Jun 2007 | US |