EP0212016A1 - A system of graphical manipulation in a potentially windowed data display - Google Patents

A system of graphical manipulation in a potentially windowed data display Download PDF

Info

Publication number
EP0212016A1
EP0212016A1 EP85305716A EP85305716A EP0212016A1 EP 0212016 A1 EP0212016 A1 EP 0212016A1 EP 85305716 A EP85305716 A EP 85305716A EP 85305716 A EP85305716 A EP 85305716A EP 0212016 A1 EP0212016 A1 EP 0212016A1
Authority
EP
European Patent Office
Prior art keywords
data
certain
instruction
descriptor
memory means
Prior art date
Legal status (The legal status 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 status listed.)
Granted
Application number
EP85305716A
Other languages
German (de)
French (fr)
Other versions
EP0212016B1 (en
Inventor
John Pilat
David Keating
Wayne Colella
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
EMC Corp
Original Assignee
Data General Corp
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 Data General Corp filed Critical Data General Corp
Priority to DE8585305716T priority Critical patent/DE3580365D1/en
Priority to EP19850305716 priority patent/EP0212016B1/en
Publication of EP0212016A1 publication Critical patent/EP0212016A1/en
Application granted granted Critical
Publication of EP0212016B1 publication Critical patent/EP0212016B1/en
Expired legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G5/00Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
    • G09G5/14Display of multiple viewports
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2360/00Aspects of the architecture of display systems
    • G09G2360/12Frame memory handling
    • G09G2360/121Frame memory handling using a cache memory

Definitions

  • This invention relates generally to digital data systems, and more particularly to techniques for managing the display of data by such systems in an environment wherein a single display device may provide for a plurality of logical displays functioning independently of each other.
  • Each logical display is known as a "window". Windows may all be displayed concurrently in their entirety, or some windows may be partially or completely covered by other windows.
  • Windows may be thought of as independent logical displays co-existing on one physical display.
  • An analogy is several sheets of paper on a desktop; they may be arranged so that all are simultaneously visible, or as they are manipulated some may completely cover (obscure) or partially cover (occlude) others. When obscured or occluded sheets are again uncovered, they still contain all the information that was temporarily invisible.
  • Windows on a display may likewise be manipulated so that some are sometimes partially or completely invisible on the display--­i.e., they present the appearance of being "covered” by other windows.
  • a good embodiment permits the data in windows to be manipulated even while the affected windows or portions of windows are not visible on the screen, with subsequent "uncovering” revealing the manipulations that were performed on a window while invisible.
  • Windowing has heretofore been accomplished primarily by software. While such an implementation of windowing can provide sufficient capability, it does so at the expense of computational overhead-- the user's requests, taking the form of software calls, must go through levels of interpretation by software in order to derive a series of machine-language instructions that the system can execute, even for simple (i.e., unoccluded) windows. Another reason for the severity of this overhead is that the descriptive information (of which there is a much larger amount for a windowed display than for a simple unitary display) must be completely reprocessed every request-- there is no architectural provision for retaining the results of previous computations affecting those portions of the display not involved in a current change. As the windowing capabilities are made more sophisticated, this overhead becomes more and more severe.
  • the present invention discloses a method of managing displays of a data processing system which includes memory, a processor, a display, and a display interface.
  • the processor is capable of executing machine language instructions that may directly (i.e. without intervening interpretation by software) manipulate displayed data.
  • the method comprises providing a series of such instructions and providing a set of form descriptors which describe the characteristics of windows on the display.
  • the processor takes each such instruction in turn, associates it with a form descriptor, determines the previous state of the display, and modifies the set of data to which the display interface is responsive to produce the modified display specified by the instruction.
  • FIG. 1 does not purport to depict a data system in its entirety, but only those elements that are necessary to generate and produce displays.
  • the system is seen to comprise a central processing unit (CPU 101), a memory (102), a display interface (109), and a display (110).
  • User software 103 (resident in memory 102) may include all manner of soft­ware entities, including software calls for display services; such software calls invoke system software 104 (also resident in memory 102) which interprets the user's calls and presents to the CPU ins­tructions which will result in carrying out the requests issued by the user software.
  • the system software may interrogate the display database 105 to determine the previous state of the display, and will update the display database so that it reflects any changes brought about by the current call from user software.
  • machine language instructions present tooed to CPU 101 by system software 104 are decoded by element 106 which (regardless of whether by "hard-wired” or microcoded means) directs arithmetic and logic unit (ALU) 107 in executing the instructions.
  • ALU arithmetic and logic unit
  • display database 105 must all be re­processed in order to create a new screen bit map 108, which would then contain a "screen image" of the display screen as it should now appear, reflecting the manipulations called for by the current calls from user software.
  • Display interface 109 (regardless of whether by programmed I/O or Direct Memory Access means) reads and processes the bit map to generate appropriate signals to display 110 causing it to display the information specified in bit map 108.
  • bit map is used herein by convention, and may denote a character map for a character-oriented display, or a pixel map for a pixel-oriented display: -- On a character-oriented display, the smallest addressable element is a character position, which may be occupied by any character from a defined font of characters. The selec­tion of which character is to occupy a particular character position is made by placing the binary code representing that character in the corresponding position of the bit map. -- On a pixel-oriented display, the smallest addressable ele­ment is essentially determined by the size of the "dot" that would be made to appear on the screen by the electron beam if it did not move.
  • bit map This is termed a "picture element", from which the term "pixel” was coined.
  • pixel bit map a single bit position in the bit map repre­sents each pixel position on the display; a "1" at a posi­tion in the bit map denotes illumination "on” at the corres­ponding position on the screen, and "0" denotes "off".
  • several bits in the bit map represent each pixel position on the display; a combination of several bits at a position in the bit map might denote the intensity level, or the color, or both, to be displayed at the corresponding pixel position on the screen.
  • the method of the present invention overcomes these disadvantages by enabling the construction of a data system in which special-­ purpose machine-language instructions are available for manipulating data in windowed displays, above and beyond the traditional instruc­tions (ADD, MOV, and so forth). Since these instructions are direct­ly executable by the CPU, no intervening software is required to interpret them. Since they execute directly in the CPU, which can include a scratchpad memory for encaching descriptive information, there is no need to reprocess descriptive information on every ins­truction. Thus the method of the present invention uses significant­ly less of the processing power of a given machine, or permits imple­mentation of windowed displays on a smaller, less powerful machine than is possible for a prior art implementation.
  • Fig. 2 does not purport to depict all elements of a data system, but only those elements necessary to generate and produce displays. All hard­ware elements of a data system on which the method of the present invention is currently embodied are shown for reference in Figs. 10 and 11.)
  • the data system is again seen to comprise a CPU (201), a memory (202), a display interface (203) and a display; in this particular embodiment the display is a pixel-oriented video monitor (204) and not a character-oriented terminal.
  • Display interface 203 is, of course, an appropriate one to drive a video monitor. Two-bit pixels are employed; for a black-and-white monitor they connote a four-step grey scale, and for a color monitor they connote "Off" (black), "Red", "Green", or "Blue”.)
  • User software 208 is seen not to be constrained to software calls for manipulating the bit map in order to affect displays, but may now also contain instructions which will directly stimulate CPU 201 for that purpose. These are special-purpose instructions and permit CPU hardware to directly construct "screen images" in the bit map, which is inherently far more efficient than manipulating the bit map by means of traditional instructions, to which the bit map is an abs­traction.
  • form descriptors 209 are required. Some definitions are in order at this point: -- The attributes of a window (e.g., its height, width, charac­teristics of what it may contain, etc.) collectively com­prise a "form". As windows are manipulated, some may become invisible-- but their forms continue to exist. -- A data entity containing the data specifying a form is known as a "form descriptor". In order for a window to have ex­istence, a form descriptor must have been provided for it.
  • user software 208 may make software calls to a piece of system software called the window manager (210), which may produce form descriptors.
  • the window manager 210
  • a user may, if she wishes, provide her own form descriptors, but the capability exists to have the window manager provide them for her. This is desirable in a multi-user, multi-program, or multi-process environ­ment to arbitrate among the various users, programs, or processes that are contending for window space on the same physical screen.
  • Each special display instruction contains a reference to a form descriptor, which the CPU will retrieve as discussed below, and which the CPU will use to modify the effect of the instruction. This en­ables windowed display management capability to be taken out of soft­ware and placed directly into hardware.
  • Instructions for writing into windows are presented by user soft­ware 208 to CPU 201 where they are interpreted by microcode unit 205, which in response to each instruction fetches an appropriate sequence of microinstructions to direct ALU 207 in performing the instruction.
  • each such instruction contains a reference to a form descriptor.
  • ALU 207 interrogates the forms control records 212 (to be discussed in more detail further on) to determine whether the form descriptor is encached in scratchpad memory 206, or stored in forms cache overflow 213); if the latter, it is retrieved from forms cache overflow 213 and restored to scratch pad memory 206 (possibly displacing another form descriptor, which is saved in forms cache overflow 213); if neither, the form descriptor is retrieved from the list of user-supplied forms descriptors 209, transformed into inter­nal form, and encached in scratchpad memory 206.
  • the transformation to internal form consists of calculating screen-global coordinates from window-local coordinates provided by the user in the form descriptor. (The user is not required to know where on the screen her window is located. Also, a window may sub­sequently be moved around on the screen, and user convenience is enhanced if the user is not required to provide new coordinates for each new position.)
  • a window positioned on a screen is depicted. Within the window are a user-specified origin "O" (307) (the user may specify coordinates in the window relative to this origin) and a point "P" (308) at which the user may wish to operate. Listed on Fig.
  • 3 are the global coordinates of the corners of the screen, and the global and local coordinates of points of interest of the window: its four corners, the origin "O", and the point "P".
  • the user is requir­ed to specify the height and width of the window (in pixels), and the local coordinates (relative to the origin "O") of the window's ULC (upper left corner). (Note that this implicitly specifies the loca­tion of the origin "O”.
  • Fig. 4 depicts a form descriptor in internal form.
  • the transfor­mation spoken of consists in calculating and filling in the global coordinates of the window's ULC (409 and 410) and a pointer to global 0,0 (B15). Since the form descriptor can now be encached as a forms cache entry, there is no need to recalculate such information on subsequent references to the same window.
  • AE E's global coordinates 409, 410
  • OE E's local coordinates 413, 414
  • Instruction inputs supply vector OP (P's local coordinates: XL,YL relative to the origin 307).
  • the vec­tor AP is calculated as part of executing the instruction.
  • the scratchpad memory then, always contains the transformed versions of the "n” most recently used forms descrip­tors. This can greatly accelerate execution, since in practice many forms will often be used repetitively. (The determination of the value of "n” is left to the designers of a particular embodiment.)
  • bit map 215 contains an image of what is to be displayed on the screen
  • execution of the present instruction may be regarded as complete when bit map 215 is updated to contain the new display in­formation specified by the current instruction.
  • Translating the bit map to a visible display is a function of display interface 203, the timing of which is asynchronous to the timing of instruction execu­tion.
  • ALU 207 may interrogate the previous contents of bit map 215 if the operation called for by the present instruction is a function of the previous display. ALU 207 will write an appropriate new portion of bit map 215 to result in a corresponding new display on video monitor 204.
  • the method will not permit a user to write outside of the window he has referenced. For example, if a user instruction specified a horizontal line 400 pixels long in a window that is only 200 pixels wide, only that portion of the line that fits within the window is written to bit map 215, and the rest is ignored. This is known as "clipping". In order to inform the user that clipping has been per­formed, a carry indication is returned to her upon completion of the instruction.
  • bit map 215 is contained in VRAM's (video random access memory chips).
  • VRAM's video random access memory chips.
  • the VRAM's are accessible to the ALU just as any other portion of main memory. What is different about the VRAM's is that they possess a special provision for rapid unloading to display interface 203, as will be discussed later in the Display Memory sec­tion.
  • FIG. 5 it is seen that Window A (502) is partially covering Window B (501). Prior to this occlusion, the processing was able to regard Window B as a single entity, but must now regard it as a complex entity made up of several simple entities-- Panes B1, B2, and B3.
  • pane denotes a portion of a window.
  • the constraint is imposed that panes must always be rectangular-- i.e., the method does not allow consideration of the occluded rectangle and the L-shaped re­mainder, but requires division of the L-shaped remainder into two rectangles, B2 and B3.
  • window B is not required to know that this occlusion has occurred (it may have been caused by a different user, program, or process), and hence does not bear the burden of providing form descriptors for the panes-- the method does this automatically and in a manner that is transparent to the user.
  • a form descriptor de­scribing a rectangle is known as a "simple form descriptor". (The form descriptors provided by the user, describing entire windows, are simple form descriptors.)
  • the processing will automatically create new simple form descriptors for the panes, and will create a "complex form descrip­ tor" for the window.
  • this automatic creation may take place under control of microcode, but in the present embodi­ment it is done by software, invoked by the microcode-to-software fault capability, to be discussed further on, which invokes fault handlers 211.
  • a complex form descriptor for a window essentially comprises a list of pointers to the simple form descriptors for the panes making up that window.
  • these pointers exist in forms control records 212.
  • Another use of the forms control records is to keep track of the locations of bit maps of panes and windows. When a pane becomes occluded, the data that were displayed on it are not be displayed any longer, indicating that the corresponding loca­tions in bit map 215 will be overwritten by the data for the occlud­ing window.
  • Master Forms Control Record 601 contains pointers to forms control record A (602) and B (605) (for windows A and B).
  • Forms control record A points to form descriptor A and to window A's bit map (the location within bit map 215 where the information for window A is stored).
  • window B's form control record structure was similar to the structure just described for window A.
  • the processing makes up new form descriptors for panes B1, B2, and B3; moves pane B1's bit map data from bit map 215 to off-screen bit map 214; and makes up a new form control record 605, which contains pointers (606, 608, and 610) to the three new form descriptors, and pointers to B1's off-screen bit map (607), B2's bit map (609), and B3's bit map (611).
  • pane B1 since pane B1 is present severelyly occluded, line I'-J' is written into the off-screen bit map and will not presently be visible on the display. Subsequent removal of window A will result in reconstituting the simple form descriptor for window B, discarding the complex form descriptor for window B and the simple form descriptors for panes B1, B2, and B3, and moving pane B1's bit map information from the off-screen bit map 214 to bit map 215; thus the complete line I-J will become visible even though part of it was invisible when drawn.
  • the described interception of the request to draw the line I-J and resolving it into three requests may in future embodiments be performed by the CPU under microcode control, but in the present embodiment it is performed by software invoked by microcode-to-­software fault 216.
  • Microcode-to-software fault is the mechanism that permits taking complex issues out of microcode and into software in the current embodiment while leaving the way clear to construct improved future embodiments with more functions performed by microcode. It also provides a guide for implementation staging and for migration of functionality up and down.
  • microcode When an operation initiates, microcode must determine whether it can do the operation, and whether it can deal with the forms on which it must operate. If the answer is no in either case, the microcode must "fault" (or "escape") to software. A fault handler address is supplied as part of each instruction. Thus, there can be a plurality of fault handlers.
  • the fault handler will emulate the requested operation, subdivid­ing forms if necessary (as described above), and using more primitive instructions if necessary.
  • the invoking program is resumed via the WPOPJ instruction of the Data General 32-bit instruction set. Recur­sive faults are thus supported implicitly.
  • operands denoting what the user to wishes to write in her windows may be im­mediate operands (contained in the instruction), or the instruction may contain a pointer to data outside the instruction (element 217 in Fig. 2). Explanation of various data types is here provided.
  • Linestyle is a way of drawing other than solid lines. Specified as a bit string of length 32, it controls which pixels computed dur­ing line drawing are actually to be planted. For each draw position, the leftmost bit in the linestyle is examined. If set, the pixel is planted; if clear, no change occurs. The linestyle is rotated left one bit position, and the next draw position is computed.
  • FFFFFFFF solid AAAAAAAA: somewhat grey F0F0F0F0: almost dotted FFF0FFF0: long dashes FFFF0FF0: long/short dashes FFFFF060: dash-dot 88888888: very faint FFFF0660: dash-dot-dot
  • Fonts are sets of special forms that are used by character-­drawing operations. They are descriptions of how each individual character is to be drawn. This description (not necessarily in bit map form) must be translated into actual screen-relevant format be­fore drawing can occur. Conditioning for character height and width must be performed. Alignment and padding may also be required. This latter entity is a "strike font”. Character instructions deal in strike fonts specified by denoting a Strike Font Descriptor. Fig. 7 depicts this scheme.
  • a font organization has been chosen that uses one bit per pixel.
  • Scan lines are padded to a power-of-two number of bits, and occupy successive memory locations. Each scan line must start on a boundary equal to its width. The number of scan lines must also be a power of two. All characters in a font occupy the same amount of space, im­plicitly a power-of-two number of bits.
  • the first scan line of a strike cell is not drawn. It identifies with ONE's those columns which make up the proportionally spaced subset of the cell.
  • Fig. 8 shows the layout of a 12x24 strike font entry for the character "1".
  • Character drawing is controlled by a linestyle-like process.
  • a character drawn by "strip mining" its strike font entry row-wise. Each bit of the row is examined in turn, ignoring in proportional spacing mode those columns with ZERO's in the control line. If 1, then a drawing-colored (foreground) pixel is sourced. If 0, a background-colored pixel is sourced instead.
  • Sourced pixel values are subjected to print control; foreground and background pixels can be suppressed independently. This allows for trial spacing (no printing at all), drawing characters on an existing background, and drawing characters and background simul­ taneously (all subject to further combination rules outlined below).
  • a 2-bit print style is defined:
  • a scheme has been adopted in which is specified a single BOOL-­rule and a mask that applies to logical pixels.
  • the bits of the logical pixel corresponding to 0s are unchanged in the target form; those corresponding to 1s are combined according to the BOOL-rule.
  • the logical pixels are already only the rightmost bits of a physical pixel.
  • the Charac­ter Block Transfer (CHARBLT) instruction allows for arbitrary font specification in translating ASCII character strings to their pixel representations. It also checks for characters that may require special handling.
  • Drawing a line is an important part of technical computer gra­phics. It is used in CAD/CAM packages, architectural design pack­ages, and business graphics packages. Since this operation is per­formed so often, special instructions are provided. Both continuous (LINESEG) and incremental (BRESENHAM_STEP) forms of line drawing are included. Lines can be drawn closed, half-open, or fully open. The actual algorithm must be reversible so as to make things such as line erasure precise. A line width argument has been included to support this function at the low level.
  • This access method deals with individual pixels and rectangular areas of them. It can serve as the foundation of higher-level acces­sing methods, so that users can create their own display manipulation instructions (for image manipulation, conic section generation, etc.) Read Pixel and Write Pixel operators allow direct access to pixels. Although only these two operations are strictly necessary to do the job, higher level operations are much more common.
  • a Bit Block Transfer operator is a very useful pixel-level opera­tor. It is essentially a rectangular combination and assignment function. This is done especially when scrolling windows, moving windows around, and creating and destroying windows that obscure other windows. A special rectangular fill operation is also useful for dealing with clearing screens and repartitioning windows.
  • BITBLT is the only operation that takes two forms, since certain restrictions are placed on source and target forms. Source logical pixels will be padded or chopped to conform to the target form's parameters.
  • All display-affecting instructions share a common instruction stream format.
  • the first 16-bit word of all such instructions is octal 107151 (hexadecimal 8E69, Nova ADDOL# 2,0,SKP).
  • the next two 16-bit words hold a program counter-relative offset (non-­indirectable), of a software emulator/fault handler.
  • the fourth 16-bit word contains a small, unsigned integer sub-opcode that speci­fies the particular function to be performed.
  • the screen bit map (215 on Fig. 2) is maintained in a special area of main memory known as display memory or video memory.
  • display memory or video memory.
  • An embodiment of video memory for a black-and-white monitor is now de­scribed.
  • video memory 901 is composed of thirty-two 64K Video RAMs (VRAMs) and is organized into a 1024 x 1024 x 2 space, permitting two-bit-pixel representation of a screen 1024 pixels high by 1024 pixels wide.
  • RS-343A monitor timing allows display of the entire array.
  • Palette I/O and other local operations are transacted through "Graphics Space", actually encoded as the IOC Auxilliary Processor (AP) Communication channel.
  • display memory timing and control logic will arbitrate for the memory bus as a requestor through memory bus interface 902.
  • the 64K double-word (i.e., 32-bit) video memory is manipulated by the CPU as normal system memory.
  • the screen is generated from a logical bit-map packed within a linear array of double-words which are ordered in the classical sense of left-to-right and top-to-­bottom. Two bit pixels will be packed left-to-right with their msb's toward the double-word msb.
  • Texas Instruments VRAM random access cycles are essentially iden­tical with those of standard DRAMs. Their unique characteristic is the ability to transfer an entire 256 bit row of internal storage to a serial shift register (903) in one special access. This register may then be clocked independently of further random access activity. Additional controls allow multiplexing four 64 bit sections of this row register to aid in configurability.
  • Dot and CRT timing will be derived from a local oscillator operating at approximately 44 MHz. Due to the independent nature of VRAM serial clocking, no explicit synchronization with existing memory timing, other than the arbitration for register-transfer cycles, is required. A specific VRAM row and mux address sequence must be maintained to properly refresh the interlaced display. Relatively simple multiplexing will be all that is required to pass pixel values to the palette.
  • the above capabilities are opti­mally satisfied by an intelligent micro-controller (uC) (906), the Intel 8051 being the best choice in that minimal cost and CEQs will result, although an 8031/2732 EPROM implementation may be utilized in future embodiments.
  • the present embodiment uses a pixel value as simply an index into a palette.
  • a palette is a special hardware map, which translates pixel values to (digital) beam intensities. Instructions exist to set and retrieve pixel-to-color translations.
  • the palette is organized as a 4 x 2 x 2 array arranged within a single double-word of storage. Two-bit palette data written through the AP Graphics Space will encode the desired gray level to be associated with a given pixel value for each phase of the blink clock in palette multiplexor 907. Although direct reading of this register is not available, microcode will maintain an image of it in a single scratchpad location.
  • the EDH13400 DAC digital-to-analog converter 908 will be utilized to produce the analog composite-video signal.
  • Red, Green, and Blue outputs are available; for the monochrome monitor the signal will be forwarded on the Green output.
  • the DAC not only performs sync-mixing, but is capable of direct 75-Ohm drive, and will be available in a 24-pin, 600mil ceramic package.
  • the present embodiment provides a "blink clock". It toggles the palette with a 50% duty cycle at a fixed rate of about 1.0-1.5 Hz.
  • the chart below shows some of the effects possible using this palette scheme for two-bit pixels. Individual palette entries specify four intensities as 32-bit unsigned binary fractions between zero and one.
  • RS-343A video is provided, a 19" off-the-shelf monitor is used.
  • the sync-on-green analog interface will be cabled direct­ly via coax from backplane pins to the monitor BNC connector.
  • This instruction reads a single pixel from a form and returns its value masked to the form's logical pixel width. If the speci­fied pixel is outside the boundaries of the form, then no value is returned. Instead, a clipping indication is returned in Carry.
  • This instruction plants a pixel value in a form, masking it to the form's logical pixel width and biasing it by the form's logical palette base.
  • This instruction draws a single line segment.
  • the control packet contains four items that are updated for restartability: X-­and Y-offsets, epsilon, and the rotated linestyle specifier.
  • AC2 POINTER TO LINESEG Packet .INTEGER X-delta (for restart) .INTEGER Y-delta (for restart) .INTEGER Epsilon (for restart) .BIT(32) Linestyle (updated) .BIT(32) Operation Mask .BIT(32) Control Word: .BIT(01) Suppress Endpoint 1 .BIT(01) Suppress Endpoint 2 .BIT(26) Filler, must be zero .BIT(04) Combination Rule .ORDINAL Pixel Value for Drawing .ORDINAL Line Width
  • This instruction plants characters in a form using glyphs held in a Font.
  • the data manipulated by CHARBLT fall into four categories: string data, font data, form data, and other opera­tional parameter. Accordingly, this instruction takes pointers in all 4 ACs. It also is the only one of the initial GIS to take a skip return on final (sic) completion.
  • AC1 POINTER TO CHARBLT Packet .INTEGER X-start (restart value, updated) .INTEGER Y-start (restart value, updated) .ORDINAL X-delta (initially 0, updated) .ORDINAL Y-delta (initially 0, updated) .ORDINAL Foreground (drawing) Pixel Value .ORDINAL Background Pixel Value .BIT(32) Operation Mask .BIT(32) Control Word .BIT(01) Suppress Foreground .BIT(01) Suppress Background .BIT(01) Space Proportionally .BIT(25) Filler, must be zero .BIT(04) Combination Rule .POINTER TO Exception Bit-Vector
  • AC2 POINTER TO Font Descriptor .ORDINAL Height of character cell (in lines) .ORDINAL Width of monospace character cell .ORDINAL Strike font cell width (in bits) .ORDINAL Strike font cell height (in lines) .POINTER TO Strike Font Bitmap
  • PC Set to PC+4 if string denoted by AC0 exhausted. Otherwise, execution skips to PC+5 if a character exception is indi­cated by a 1 in the bit vector (like CMT) denoted through AC1.
  • Pixels starting from the ULC of the Source Rectangle in the Source Form are paired with pixels starting at the ULC of the Target Rectangle of the Target Form. Consistent with the boundar­ies of both forms, source and target pixels are (optionally) combined and the target pixel replaced.
  • BITBLT never smears pixels the way that WCMV smears characters. BITBLT must choose the correct direction for walking the two rectangles.
  • AC1 POINTER TO BITBLT Packet .INTEGER X-delta (initially 0, for restart) .INTEGER Y-delta (initially 0, for restart) .POINTER TO Source Start ULC Specifier .POINTER TO Target Start ULC Specifier .ORDINAL X-extent (in pixels) .ORDINAL Y-extent (in pixels) .BIT(32) Operation Mask .BIT(32) Combination Rule (low 4 bits)
  • This instruction retrieves the contents of a palette entry for a particular pixel value within the context of a given form. It reflects the actual intensities stored in the palette, rather than the values that were input to a prior WRPAL (Write Palette).
  • AC1 POINTER TO Phase 0 RGBL-Tuple .BIT(32) Red Intensity (ignored) .BIT(32) Green Intensity (ignored) .BIT(32) Blue Intensity (ignored) .BIT(32) Grey-Level (ignored)
  • AC2 POINTER TO Phase 1 RGBL-Tuple .BIT(32) Red Intensity (ignored) .BIT(32) Green Intensity (ignored) .BIT(32) Blue Intensity (ignored) .BIT(32) Grey-Level (ignored)
  • This instruction sets up palette entries for both phases of the blink clock (if one exists). It allows color and grey-level to be specified independently. It is assumed that control software sets up the target form's Palette Base and prevents abuse of the WRPAL.
  • AC1 POINTER TO Phase 0 RGBL-Tuple .BIT(32) Red Intensity (ignored if mono) .BIT(32) Green Intensity (ignored if mono) .BIT(32) Blue Intensity (ignored if mono) .BIT(32) Grey-Level (ignored if color)
  • AC2 POINTER TO Phase 1 RGBL-Tuple .BIT(32) Red Intensity (ignored if mono) .BIT(32) Green Intensity (ignored if mono) .BIT(32) Blue Intensity (ignored if mono) .BIT(32) Grey-Level (ignored if color)
  • This function performs the form cache equivalent of PATU (Purge the ATU) or SPTE (Set Page Table Entry).
  • LSBRS and LSBRA may also invalidate associa­tions of logical address to form descriptor information.
  • PFORMS must also occur as an implicit consequence of executing any of the above instructions.

Abstract

A method is disclosed which enhances the ability of a digital computer system to manage displays, especially in an environment where a single physical display supports a plurality of logical displays (windows). Machine-language instructions are provided to a CPU (201) from user software and data (208. 217). These instructions act in conjunction with user-supplied form descriptors (209) describing each of the windows to enable management and generation of display image data to be performed directly by the processing hardware of the digital computer system, eliminating any need for intervening interpretive software. The display image data is placed in a screen bitmap memory (215) or a reserve memory (214) for occluded image data. Data computed from form descriptors may be held in a cache (206) in order to enhance the speed of consecutive operations on windows. Graceful creation is enhanced by permitting processing control to escape to software fault handlers (211).

Description

  • This invention relates generally to digital data systems, and more particularly to techniques for managing the display of data by such systems in an environment wherein a single display device may provide for a plurality of logical displays functioning independently of each other. Each logical display is known as a "window". Windows may all be displayed concurrently in their entirety, or some windows may be partially or completely covered by other windows.
  • REFERENCES:
  • Graphics in Overlapping Bitmap Layers, Rob Pike, ACM Transactions on Graphics, April, 1983.
  • SMALLTALK-80 The Language and its Implementation, Adele Goldberg and David Robson, Addison-Wesley, 1983. (Particularly chapters 17, 18, 20.)
  • Digital data system have been equipped with display devices almost since their advent. The type of display that has taken pre­eminence as the most flexible for interfacing with the user is the cathode ray tube display. A recently evolved mode of the use of such displays is to permit several users, several programs, or several processes to share the available space on a display, with each such user, program, or process being allocated a certain amount of display area. Each such area is known as a "window".
  • Windows, then, may be thought of as independent logical displays co-existing on one physical display. An analogy is several sheets of paper on a desktop; they may be arranged so that all are simultaneously visible, or as they are manipulated some may completely cover (obscure) or partially cover (occlude) others. When obscured or occluded sheets are again uncovered, they still contain all the information that was temporarily invisible.
  • Windows on a display may likewise be manipulated so that some are sometimes partially or completely invisible on the display--­i.e., they present the appearance of being "covered" by other windows. A good embodiment permits the data in windows to be manipulated even while the affected windows or portions of windows are not visible on the screen, with subsequent "uncovering" revealing the manipulations that were performed on a window while invisible.
  • Windowing has heretofore been accomplished primarily by software. While such an implementation of windowing can provide sufficient capability, it does so at the expense of computational overhead-- the user's requests, taking the form of software calls, must go through levels of interpretation by software in order to derive a series of machine-language instructions that the system can execute, even for simple (i.e., unoccluded) windows. Another reason for the severity of this overhead is that the descriptive information (of which there is a much larger amount for a windowed display than for a simple unitary display) must be completely reprocessed every request-- there is no architectural provision for retaining the results of previous computations affecting those portions of the display not involved in a current change. As the windowing capabilities are made more sophisticated, this overhead becomes more and more severe.
  • It is an object of the present invention to provide an improved data processing system, which can efficiently manage windowed displays.
  • It is a further object of the present invention to provide a system in which user-supplied instructions directly effect windowed displays with no need for intervening software.
  • It is an additional object of the present invention to provide a system in which efficiency is enhanced by retaining the results of intermediate calculations relative to windowed displays.
  • The present invention discloses a method of managing displays of a data processing system which includes memory, a processor, a display, and a display interface. The processor is capable of executing machine language instructions that may directly (i.e. without intervening interpretation by software) manipulate displayed data. The method comprises providing a series of such instructions and providing a set of form descriptors which describe the characteristics of windows on the display. The processor takes each such instruction in turn, associates it with a form descriptor, determines the previous state of the display, and modifies the set of data to which the display interface is responsive to produce the modified display specified by the instruction.
  • The invention will now be described in more detail, by way of example, and with reference to the accompanying drawings in which:
    • Figure 1 is a schematic diagram of a conventional data processing system;
    • Figures 2-11 relate to the present invention, wherein:
    • Figure 2 is a block diagram of a typical data processing system arranged to implement the present invention;
    • Figure 3 depicts a single window displayed on a screen;
    • Figure 4 depicts a forms descriptor;
    • Figure 5 depicts two windows on a screen, one occluding the other;
    • Figure 6 depicts a form control record scheme;
    • Figure 7 depicts a character font scheme;
    • Figure 8 depicts a bit map of a typical character in a character font;
    • Figure 9 depicts a display memory sub-system;
    • Figure 10 depicts the central processing unit of a digital computer system;
    • Figure 11 depicts the control sub-system of a digital computer system.
    DESCRIPTION OF THE PREFERRED EMBODIMENT: INTRODUCTION:
  • In the prior art, the management of windowed displays has been performed by software. This is illustrated in Fig. 1. (Fig. 1 does not purport to depict a data system in its entirety, but only those elements that are necessary to generate and produce displays.) The system is seen to comprise a central processing unit (CPU 101), a memory (102), a display interface (109), and a display (110). User software 103 (resident in memory 102) may include all manner of soft­ware entities, including software calls for display services; such software calls invoke system software 104 (also resident in memory 102) which interprets the user's calls and presents to the CPU ins­tructions which will result in carrying out the requests issued by the user software. The system software may interrogate the display database 105 to determine the previous state of the display, and will update the display database so that it reflects any changes brought about by the current call from user software.
  • Still referring to Fig. 1, machine language instructions present­ed to CPU 101 by system software 104 are decoded by element 106 which (regardless of whether by "hard-wired" or microcoded means) directs arithmetic and logic unit (ALU) 107 in executing the instructions. Note that these are all "traditional" instructions (ADD, MOV, etc.) The descriptive information in display database 105 must all be re­processed in order to create a new screen bit map 108, which would then contain a "screen image" of the display screen as it should now appear, reflecting the manipulations called for by the current calls from user software. Display interface 109 (regardless of whether by programmed I/O or Direct Memory Access means) reads and processes the bit map to generate appropriate signals to display 110 causing it to display the information specified in bit map 108.
  • Note that the term "bit map" is used herein by convention, and may denote a character map for a character-oriented display, or a pixel map for a pixel-oriented display:
    -- On a character-oriented display, the smallest addressable element is a character position, which may be occupied by any character from a defined font of characters. The selec­tion of which character is to occupy a particular character position is made by placing the binary code representing that character in the corresponding position of the bit map.
    -- On a pixel-oriented display, the smallest addressable ele­ment is essentially determined by the size of the "dot" that would be made to appear on the screen by the electron beam if it did not move. (This is termed a "picture element", from which the term "pixel" was coined.) In the simplest pixel bit map, a single bit position in the bit map repre­sents each pixel position on the display; a "1" at a posi­tion in the bit map denotes illumination "on" at the corres­ponding position on the screen, and "0" denotes "off". In more complex implementations, several bits in the bit map represent each pixel position on the display; a combination of several bits at a position in the bit map might denote the intensity level, or the color, or both, to be displayed at the corresponding pixel position on the screen.
  • The prior art approach can be successfully implemented, but it has the disadvantages of introducing substantial overhead, because of the need to interpret all of the user's calls and because the soft­ware is isolated from the bit map by the CPU and is therefore con­strained to completely reprocess descriptive information whenever it is desired to change anything on the display. Such implementations have been confined to fairly powerful machines, on which they use up a substantial proportion of the processing power.
  • The method of the present invention overcomes these disadvantages by enabling the construction of a data system in which special-­ purpose machine-language instructions are available for manipulating data in windowed displays, above and beyond the traditional instruc­tions (ADD, MOV, and so forth). Since these instructions are direct­ly executable by the CPU, no intervening software is required to interpret them. Since they execute directly in the CPU, which can include a scratchpad memory for encaching descriptive information, there is no need to reprocess descriptive information on every ins­truction. Thus the method of the present invention uses significant­ly less of the processing power of a given machine, or permits imple­mentation of windowed displays on a smaller, less powerful machine than is possible for a prior art implementation.
  • DETAILED DESCRIPTION: Instruction execution and form descriptors:
  • The method of the present invention is depicted in Fig. 2. (Fig. 2 does not purport to depict all elements of a data system, but only those elements necessary to generate and produce displays. All hard­ware elements of a data system on which the method of the present invention is currently embodied are shown for reference in Figs. 10 and 11.)
  • The data system is again seen to comprise a CPU (201), a memory (202), a display interface (203) and a display; in this particular embodiment the display is a pixel-oriented video monitor (204) and not a character-oriented terminal. (Display interface 203 is, of course, an appropriate one to drive a video monitor. Two-bit pixels are employed; for a black-and-white monitor they connote a four-step grey scale, and for a color monitor they connote "Off" (black), "Red", "Green", or "Blue".)
  • User software 208 is seen not to be constrained to software calls for manipulating the bit map in order to affect displays, but may now also contain instructions which will directly stimulate CPU 201 for that purpose. These are special-purpose instructions and permit CPU hardware to directly construct "screen images" in the bit map, which is inherently far more efficient than manipulating the bit map by means of traditional instructions, to which the bit map is an abs­traction.
  • It is also seen that form descriptors 209 are required. Some definitions are in order at this point:
    -- The attributes of a window (e.g., its height, width, charac­teristics of what it may contain, etc.) collectively com­prise a "form". As windows are manipulated, some may become invisible-- but their forms continue to exist.
    -- A data entity containing the data specifying a form is known as a "form descriptor". In order for a window to have ex­istence, a form descriptor must have been provided for it.
  • Still referring to Fig. 2, it is seen that user software 208 may make software calls to a piece of system software called the window manager (210), which may produce form descriptors. A user may, if she wishes, provide her own form descriptors, but the capability exists to have the window manager provide them for her. This is desirable in a multi-user, multi-program, or multi-process environ­ment to arbitrate among the various users, programs, or processes that are contending for window space on the same physical screen.
  • Each special display instruction contains a reference to a form descriptor, which the CPU will retrieve as discussed below, and which the CPU will use to modify the effect of the instruction. This en­ables windowed display management capability to be taken out of soft­ware and placed directly into hardware.
  • Instructions for writing into windows are presented by user soft­ware 208 to CPU 201 where they are interpreted by microcode unit 205, which in response to each instruction fetches an appropriate sequence of microinstructions to direct ALU 207 in performing the instruction.
  • As mentioned, each such instruction contains a reference to a form descriptor. ALU 207 interrogates the forms control records 212 (to be discussed in more detail further on) to determine whether the form descriptor is encached in scratchpad memory 206, or stored in forms cache overflow 213); if the latter, it is retrieved from forms cache overflow 213 and restored to scratch pad memory 206 (possibly displacing another form descriptor, which is saved in forms cache overflow 213); if neither, the form descriptor is retrieved from the list of user-supplied forms descriptors 209, transformed into inter­nal form, and encached in scratchpad memory 206.
  • The transformation to internal form consists of calculating screen-global coordinates from window-local coordinates provided by the user in the form descriptor. (The user is not required to know where on the screen her window is located. Also, a window may sub­sequently be moved around on the screen, and user convenience is enhanced if the user is not required to provide new coordinates for each new position.) Referring to Fig. 3, a window positioned on a screen is depicted. Within the window are a user-specified origin "O" (307) (the user may specify coordinates in the window relative to this origin) and a point "P" (308) at which the user may wish to operate. Listed on Fig. 3 are the global coordinates of the corners of the screen, and the global and local coordinates of points of interest of the window: its four corners, the origin "O", and the point "P". In the user-supplied form descriptor, the user is requir­ed to specify the height and width of the window (in pixels), and the local coordinates (relative to the origin "O") of the window's ULC (upper left corner). (Note that this implicitly specifies the loca­tion of the origin "O".)
  • Fig. 4 depicts a form descriptor in internal form. The transfor­mation spoken of consists in calculating and filling in the global coordinates of the window's ULC (409 and 410) and a pointer to global 0,0 (B15). Since the form descriptor can now be encached as a forms cache entry, there is no need to recalculate such information on subsequent references to the same window.
  • Again with reference to Fig. 3 and Fig. 4, suppose that the user desires to operate at point P (308). The encached form descriptor supplies vectors AE (E's global coordinates 409, 410) and OE (E's local coordinates 413, 414). Instruction inputs supply vector OP (P's local coordinates: XL,YL relative to the origin 307). The vec­tor AP is calculated as part of executing the instruction.
  • Returning to Fig. 2, the scratchpad memory, then, always contains the transformed versions of the "n" most recently used forms descrip­tors. This can greatly accelerate execution, since in practice many forms will often be used repetitively. (The determination of the value of "n" is left to the designers of a particular embodiment.)
  • Since bit map 215 contains an image of what is to be displayed on the screen, execution of the present instruction may be regarded as complete when bit map 215 is updated to contain the new display in­formation specified by the current instruction. Translating the bit map to a visible display is a function of display interface 203, the timing of which is asynchronous to the timing of instruction execu­tion.
  • ALU 207 may interrogate the previous contents of bit map 215 if the operation called for by the present instruction is a function of the previous display. ALU 207 will write an appropriate new portion of bit map 215 to result in a corresponding new display on video monitor 204.
  • The method will not permit a user to write outside of the window he has referenced. For example, if a user instruction specified a horizontal line 400 pixels long in a window that is only 200 pixels wide, only that portion of the line that fits within the window is written to bit map 215, and the rest is ignored. This is known as "clipping". In order to inform the user that clipping has been per­formed, a carry indication is returned to her upon completion of the instruction.
  • Note that bit map 215 is contained in VRAM's (video random access memory chips). The VRAM's are accessible to the ALU just as any other portion of main memory. What is different about the VRAM's is that they possess a special provision for rapid unloading to display interface 203, as will be discussed later in the Display Memory sec­tion.
  • OCCLUSION: ("BROKEN WINDOWS"):
  • A complication occurs in the described processing when a window is occluded (partially covered) by another window. Referring to Fig. 5, it is seen that Window A (502) is partially covering Window B (501). Prior to this occlusion, the processing was able to regard Window B as a single entity, but must now regard it as a complex entity made up of several simple entities-- Panes B1, B2, and B3. (The term "pane" denotes a portion of a window.) In order to keep the simple entities as simple as possible, the constraint is imposed that panes must always be rectangular-- i.e., the method does not allow consideration of the occluded rectangle and the L-shaped re­mainder, but requires division of the L-shaped remainder into two rectangles, B2 and B3.
  • The user of window B is not required to know that this occlusion has occurred (it may have been caused by a different user, program, or process), and hence does not bear the burden of providing form descriptors for the panes-- the method does this automatically and in a manner that is transparent to the user. A form descriptor de­scribing a rectangle is known as a "simple form descriptor". (The form descriptors provided by the user, describing entire windows, are simple form descriptors.) When occlusion requires breaking a window into panes, the processing will automatically create new simple form descriptors for the panes, and will create a "complex form descrip­ tor" for the window. In future embodiments this automatic creation may take place under control of microcode, but in the present embodi­ment it is done by software, invoked by the microcode-to-software fault capability, to be discussed further on, which invokes fault handlers 211.
  • A complex form descriptor for a window essentially comprises a list of pointers to the simple form descriptors for the panes making up that window. In the current embodiment, these pointers exist in forms control records 212. Another use of the forms control records is to keep track of the locations of bit maps of panes and windows. When a pane becomes occluded, the data that were displayed on it are not be displayed any longer, indicating that the corresponding loca­tions in bit map 215 will be overwritten by the data for the occlud­ing window. Rather than discard this information, which would neces­sitate recomputing it later when the pane is to become visible again, or when the user wishes to manipulate data within the pane (recall that it is possible to manipulate data in an invisible pane), it is retained as an "off-screen bit map" (214) in main memory. Referring to Fig. 6, which depicts the forms control records entries that re­flect the occlusion situation depicted in Fig. 5, it is seen that Master Forms Control Record 601 contains pointers to forms control record A (602) and B (605) (for windows A and B). Forms control record A points to form descriptor A and to window A's bit map (the location within bit map 215 where the information for window A is stored).
  • Prior to occlusion, window B's form control record structure was similar to the structure just described for window A. Upon detecting the occurrence of occlusion, however, the processing makes up new form descriptors for panes B1, B2, and B3; moves pane B1's bit map data from bit map 215 to off-screen bit map 214; and makes up a new form control record 605, which contains pointers (606, 608, and 610) to the three new form descriptors, and pointers to B1's off-screen bit map (607), B2's bit map (609), and B3's bit map (611).
  • Subsequent user instructions to manipulate window B can now be handled. For example, (referring to Fig. 5) if the user specifies a line from I to J in window B, processing will automatically translate that to three requests: one for line I-I' in pane B3, one for line I'-J' in pane B1, and one for line J'-J in pane B2. (For simplicity, the three requests might each call for the full line I-J, and the clipping function previously described would result in writing in each pane only the segments that fall within those panes.) Handling these three requests will, as usual, result in recording the line in the bit maps for the three panes. However, since pane B1 is present­ly occluded, line I'-J' is written into the off-screen bit map and will not presently be visible on the display. Subsequent removal of window A will result in reconstituting the simple form descriptor for window B, discarding the complex form descriptor for window B and the simple form descriptors for panes B1, B2, and B3, and moving pane B1's bit map information from the off-screen bit map 214 to bit map 215; thus the complete line I-J will become visible even though part of it was invisible when drawn.
  • The described interception of the request to draw the line I-J and resolving it into three requests may in future embodiments be performed by the CPU under microcode control, but in the present embodiment it is performed by software invoked by microcode-to-­software fault 216.
  • MICROCODE-TO-SOFTWARE FAULT:
  • Microcode-to-software fault is the mechanism that permits taking complex issues out of microcode and into software in the current embodiment while leaving the way clear to construct improved future embodiments with more functions performed by microcode. It also provides a guide for implementation staging and for migration of functionality up and down.
  • When an operation initiates, microcode must determine whether it can do the operation, and whether it can deal with the forms on which it must operate. If the answer is no in either case, the microcode must "fault" (or "escape") to software. A fault handler address is supplied as part of each instruction. Thus, there can be a plurality of fault handlers.
  • The fault handler will emulate the requested operation, subdivid­ing forms if necessary (as described above), and using more primitive instructions if necessary. The invoking program is resumed via the WPOPJ instruction of the Data General 32-bit instruction set. Recur­sive faults are thus supported implicitly.
  • The combination of faulting mechanism, clipping, and window-local coordinate systems gives a unique benefit: a display-affecting opera­tion on a complex window is equivalent to the same operation applied in turn to all constituent simple windows. The user is thus relieved of responsibility for complex windows.
  • Displayable Data Types:
  • Depending on the particular instruction (see Appendix A) operands denoting what the user to wishes to write in her windows may be im­mediate operands (contained in the instruction), or the instruction may contain a pointer to data outside the instruction (element 217 in Fig. 2). Explanation of various data types is here provided.
  • Linestyles
  • Linestyle is a way of drawing other than solid lines. Specified as a bit string of length 32, it controls which pixels computed dur­ing line drawing are actually to be planted. For each draw position, the leftmost bit in the linestyle is examined. If set, the pixel is planted; if clear, no change occurs. The linestyle is rotated left one bit position, and the next draw position is computed. Examples of linestyle (expressed in hexadecimal) are:
    FFFFFFFF: solid
    AAAAAAAA: somewhat grey
    F0F0F0F0: almost dotted
    FFF0FFF0: long dashes
    FFFF0FF0: long/short dashes
    FFFFF060: dash-dot
    88888888: very faint
    FFFF0660: dash-dot-dot
  • Fonts
  • Fonts are sets of special forms that are used by character-­drawing operations. They are descriptions of how each individual character is to be drawn. This description (not necessarily in bit map form) must be translated into actual screen-relevant format be­fore drawing can occur. Conditioning for character height and width must be performed. Alignment and padding may also be required. This latter entity is a "strike font". Character instructions deal in strike fonts specified by denoting a Strike Font Descriptor. Fig. 7 depicts this scheme.
  • A font organization has been chosen that uses one bit per pixel. Scan lines are padded to a power-of-two number of bits, and occupy successive memory locations. Each scan line must start on a boundary equal to its width. The number of scan lines must also be a power of two. All characters in a font occupy the same amount of space, im­plicitly a power-of-two number of bits. The first scan line of a strike cell is not drawn. It identifies with ONE's those columns which make up the proportionally spaced subset of the cell. Fig. 8 shows the layout of a 12x24 strike font entry for the character "1".
  • Character drawing is controlled by a linestyle-like process. Conceptually, a character drawn by "strip mining" its strike font entry row-wise. Each bit of the row is examined in turn, ignoring in proportional spacing mode those columns with ZERO's in the control line. If 1, then a drawing-colored (foreground) pixel is sourced. If 0, a background-colored pixel is sourced instead.
  • Sourced pixel values are subjected to print control; foreground and background pixels can be suppressed independently. This allows for trial spacing (no printing at all), drawing characters on an existing background, and drawing characters and background simul­ taneously (all subject to further combination rules outlined below). A 2-bit print style is defined:
    Figure imgb0001
  • Combination Rules
  • Many of the instructions will employ a Combination Rule to deal with superposition of source pixels on destination pixels. One does not always wish strictly to replace the destination pixel with the source pixel; it may be desired to plant a pixel whose value is some function of source and destination. This implies that destination may also be an input.
  • A scheme has been adopted in which is specified a single BOOL-­rule and a mask that applies to logical pixels. The bits of the logical pixel corresponding to 0s are unchanged in the target form; those corresponding to 1s are combined according to the BOOL-rule. The logical pixels are already only the rightmost bits of a physical pixel.
  • Access Methods:
  • By way of defining the instructions, graphics practice reveals that certain "favorite" operations are performed frequently, includ­ing:
    * reading or writing a pixel's value
    * moving a rectangular area of pixels around.
    * drawing a line or series of connected line segments.
    * filling an polygonal area with a pattern.
    * drawing a string of ASCII characters.
  • These operations comprise three major methods of drawing on a display: pixels, figures, and characters.
  • Character Access Method
  • This method provide ways to plant text in a window. The Charac­ter Block Transfer (CHARBLT) instruction allows for arbitrary font specification in translating ASCII character strings to their pixel representations. It also checks for characters that may require special handling.
  • Figure Access Method
  • Drawing a line is an important part of technical computer gra­phics. It is used in CAD/CAM packages, architectural design pack­ages, and business graphics packages. Since this operation is per­formed so often, special instructions are provided. Both continuous (LINESEG) and incremental (BRESENHAM_STEP) forms of line drawing are included. Lines can be drawn closed, half-open, or fully open. The actual algorithm must be reversible so as to make things such as line erasure precise. A line width argument has been included to support this function at the low level.
  • Pixel Access Method
  • This access method deals with individual pixels and rectangular areas of them. It can serve as the foundation of higher-level acces­sing methods, so that users can create their own display manipulation instructions (for image manipulation, conic section generation, etc.) Read Pixel and Write Pixel operators allow direct access to pixels. Although only these two operations are strictly necessary to do the job, higher level operations are much more common.
  • These are the only drawing instructions that do not take a com­bination rule specifier. They are intended as the simplest of all building blocks. The model of use is one of many WRPIXELs to the same form in rapid sequence.
  • A Bit Block Transfer operator is a very useful pixel-level opera­tor. It is essentially a rectangular combination and assignment function. This is done especially when scrolling windows, moving windows around, and creating and destroying windows that obscure other windows. A special rectangular fill operation is also useful for dealing with clearing screens and repartitioning windows.
  • BITBLT is the only operation that takes two forms, since certain restrictions are placed on source and target forms. Source logical pixels will be padded or chopped to conform to the target form's parameters.
  • Instruction Repertoire:
  • All display-affecting instructions share a common instruction stream format. The first 16-bit word of all such instructions is octal 107151 (hexadecimal 8E69, Nova ADDOL# 2,0,SKP). The next two 16-bit words hold a program counter-relative offset (non-­indirectable), of a software emulator/fault handler. The fourth 16-bit word contains a small, unsigned integer sub-opcode that speci­fies the particular function to be performed.
    Figure imgb0002
  • A full delineation of the repertoire of display-affecting ins­tructions is found in Appendix A.
  • Display Memory Module:
  • The screen bit map (215 on Fig. 2) is maintained in a special area of main memory known as display memory or video memory. An embodiment of video memory for a black-and-white monitor is now de­scribed.
  • Referring to Fig. 9, video memory 901 is composed of thirty-two 64K Video RAMs (VRAMs) and is organized into a 1024 x 1024 x 2 space, permitting two-bit-pixel representation of a screen 1024 pixels high by 1024 pixels wide. RS-343A monitor timing allows display of the entire array. A free-running blink clock selects one of two complete palettes (984) capable of mapping any pixel value to one of four levels of gray (0=black to 3=white). Palette I/O and other local operations are transacted through "Graphics Space", actually encoded as the IOC Auxilliary Processor (AP) Communication channel. In order to support the "Register-Transfer" function peculiar to VRAMs and additional diagnostic and boot-time character drawing, display memory timing and control logic will arbitrate for the memory bus as a requestor through memory bus interface 902.
  • Video Memory Proper
  • The 64K double-word (i.e., 32-bit) video memory is manipulated by the CPU as normal system memory. The screen is generated from a logical bit-map packed within a linear array of double-words which are ordered in the classical sense of left-to-right and top-to-­bottom. Two bit pixels will be packed left-to-right with their msb's toward the double-word msb.
  • Texas Instruments VRAM random access cycles are essentially iden­tical with those of standard DRAMs. Their unique characteristic is the ability to transfer an entire 256 bit row of internal storage to a serial shift register (903) in one special access. This register may then be clocked independently of further random access activity. Additional controls allow multiplexing four 64 bit sections of this row register to aid in configurability.
  • Timing and Control
  • Dot and CRT timing will be derived from a local oscillator operating at approximately 44 MHz. Due to the independent nature of VRAM serial clocking, no explicit synchronization with existing memory timing, other than the arbitration for register-transfer cycles, is required. A specific VRAM row and mux address sequence must be maintained to properly refresh the interlaced display. Relatively simple multiplexing will be all that is required to pass pixel values to the palette. The above capabilities are opti­mally satisfied by an intelligent micro-controller (uC) (906), the Intel 8051 being the best choice in that minimal cost and CEQs will result, although an 8031/2732 EPROM implementation may be utilized in future embodiments.
  • Rotate and Merge Logic 905
  • In the course of analysing the microcode necessary to imple­ment the BITBLT instruction, a need was noted to accelerate graphics memory references on arbitrary bit boundaries. Consequently, the hardware required to implement this function as a Memory-Bus-resident device was developed. A control bit specifies the direction of the merge sequence. A "merge-enable" bit is also available in order not to preclude a circular "rotate-only". All references are made via Graphics Space UABAs.
  • The Palette & DAC
  • The present embodiment uses a pixel value as simply an index into a palette. A palette is a special hardware map, which translates pixel values to (digital) beam intensities. Instructions exist to set and retrieve pixel-to-color translations. The palette is organized as a 4 x 2 x 2 array arranged within a single double-word of storage. Two-bit palette data written through the AP Graphics Space will encode the desired gray level to be associated with a given pixel value for each phase of the blink clock in palette multiplexor 907. Although direct reading of this register is not available, microcode will maintain an image of it in a single scratchpad location. The EDH13400 DAC (digital-to-analog converter 908) will be utilized to produce the analog composite-video signal. Red, Green, and Blue outputs are available; for the monochrome monitor the signal will be forwarded on the Green output. The DAC not only performs sync-mixing, but is capable of direct 75-Ohm drive, and will be available in a 24-pin, 600mil ceramic package.
  • Blinking
  • The present embodiment provides a "blink clock". It toggles the palette with a 50% duty cycle at a fixed rate of about 1.0-1.5 Hz. Thus, there are two palettes, one for each phase of the Blink Clock. Entries in the two palettes are specified separately. This allows a user to program a given Pixel Value to alternate between two levels of intensity (or two colors on a color display). The chart below shows some of the effects possible using this palette scheme for two-bit pixels. Individual palette entries specify four intensities as 32-bit unsigned binary fractions between zero and one.
    Figure imgb0003
  • Monitor Characteristics
  • In that RS-343A video is provided, a 19" off-the-shelf monitor is used. The sync-on-green analog interface will be cabled direct­ly via coax from backplane pins to the monitor BNC connector.
  • Memory Programming UABA Encodings
  • The following table summarizes the display memory UABA Encod­ings which will be supported by graphics microcode:
    Figure imgb0004
  • INSTRUCTION DICTIONARY RDPIXEL [107151,000000]
  • This instruction reads a single pixel from a form and returns its value masked to the form's logical pixel width. If the speci­fied pixel is outside the boundaries of the form, then no value is returned. Instead, a clipping indication is returned in Carry.
  • INPUTS
  • AC0: ignored
  • AC1: INTEGER local X-coordinate
  • AC2: INTEGER local Y-coordinate
  • AC3: POINTER TO Form Descriptor
  • OUTPUTS
  • AC0: ORDINAL Logical Pixel Value (if in form) unchanged (if point not in form)
  • AC1: unchanged
  • AC2: unchanged
  • AC3: unchanged
  • C: SET if [X,Y] not in Form, unchanged otherwise.
  • WRPIXEL [107151,000001]
  • This instruction plants a pixel value in a form, masking it to the form's logical pixel width and biasing it by the form's logical palette base.
  • INPUTS
  • AC0: ORDINAL Logical Pixel Value
  • AC1: INTEGER local X-coordinate
  • AC2: INTEGER local Y-coordinate
  • AC3: POINTER TO Form Descriptor
  • OUTPUTS
  • AC0: unchanged
  • AC1: unchanged
  • AC2: unchanged
  • AC3: unchanged
  • C: SET if [X,Y] not in Form, unchanged otherwise.
  • METHOD
    • 1) Start with the Logical Pixel Value from AC0.
    • 2) AND it with the Form's Logical Pixel Mask to remove any stray high order bits.
    • 3) OR in the Form's Logical Palette Base to turn local color into global color.
    • 4) Plant the Physical Pixel Value at [X,Y]
    LINESEG [107151,000004]
  • This instruction draws a single line segment. The control packet contains four items that are updated for restartability: X-­and Y-offsets, epsilon, and the rotated linestyle specifier.
  • INPUTS
  • AC0: POINTER TO Endpoint 1 [X,Y] pair
  • AC1: POINTER TO Endpoint 2 [X,Y] pair
  • AC2: POINTER TO LINESEG Packet
    .INTEGER X-delta (for restart)
    .INTEGER Y-delta (for restart)
    .INTEGER Epsilon (for restart)
    .BIT(32) Linestyle (updated)
    .BIT(32) Operation Mask
    .BIT(32) Control Word:
    .BIT(01) Suppress Endpoint 1
    .BIT(01) Suppress Endpoint 2
    .BIT(26) Filler, must be zero
    .BIT(04) Combination Rule
    .ORDINAL Pixel Value for Drawing
    .ORDINAL Line Width
  • AC3: POINTER TO Form Descriptor
  • OUTPUTS
  • AC0: unchanged
  • AC1: unchanged
  • AC2: unchanged
    X-delta in packet updated
    Y-delta in packet updated
    Epsilon in packet updated
    Linestyle (rotated) in packet updated
  • AC3: unchanged
  • C: SET if clipping occurred, unchanged otherwise
  • CHARBLT [107151,000006]
  • This instruction plants characters in a form using glyphs held in a Font. The data manipulated by CHARBLT fall into four categories: string data, font data, form data, and other opera­tional parameter. Accordingly, this instruction takes pointers in all 4 ACs. It also is the only one of the initial GIS to take a skip return on final (sic) completion.
  • INPUTS
  • AC0: POINTER TO String Packet
    .BYTEPOINTER TO Character String (1-origin)
    .ORDINAL Maximum Index into String
    .ORDINAL Starting Index in String (updated)
  • AC1: POINTER TO CHARBLT Packet
    .INTEGER X-start (restart value, updated)
    .INTEGER Y-start (restart value, updated)
    .ORDINAL X-delta (initially 0, updated)
    .ORDINAL Y-delta (initially 0, updated)
    .ORDINAL Foreground (drawing) Pixel Value
    .ORDINAL Background Pixel Value
    .BIT(32) Operation Mask
    .BIT(32) Control Word
    .BIT(01) Suppress Foreground
    .BIT(01) Suppress Background
    .BIT(01) Space Proportionally
    .BIT(25) Filler, must be zero
    .BIT(04) Combination Rule
    .POINTER TO Exception Bit-Vector
  • AC2: POINTER TO Font Descriptor
    .ORDINAL Height of character cell (in lines)
    .ORDINAL Width of monospace character cell
    .ORDINAL Strike font cell width (in bits)
    .ORDINAL Strike font cell height (in lines)
    .POINTER TO Strike Font Bitmap
  • AC3: POINTER TO Form Descriptor
  • OUTPUTS
  • AC0: unchanged (string index updated in packet)
  • AC1: unchanged (X-start, Y-start, X-delta, Y-delta updated)
  • AC2: unchanged
  • AC3: unchanged
  • C: SET if any clipping occurred, unchanged otherwise
  • PC: Set to PC+4 if string denoted by AC0 exhausted. Otherwise, execution skips to PC+5 if a character exception is indi­cated by a 1 in the bit vector (like CMT) denoted through AC1.
  • METHOD
    • 1) If XDELTA, YDELTA not both zero then resume character drawing from interrupt point within character.
    • 2) For each character in the string starting at SINDEX, repeat the following steps:
    • 3) Fetch current character, STRING[SINDEX], and call it C.
    • 4) If EXCEPTIONS [C] is 1 then "done" and skip, PC := PC+5;
    • 5) Locate the strike font cell for C's glyph. The first bit is at the offset given by the product of the integer value of the character, the strike cell width, and the strike cell height.
    • 6) If proportional, use the first scan line as a control mask, ignoring columns corresponding to 0s in the mask. The number of 1s is therefore the width of the particular character in proportional spacing. If monospace, ignore the first line.
    • 7) Scan the lines of the font entry, determining and planting foreground and background pixels as described in GIS.002, under control of the operation mask, print control, and combo rule.
    • 8) Bump XSTART by character width and SINDEX by one.
    • 9) If SINDEX > MAXINDEX then done at PC := PC+4, else repeat.
    • 10) When done, SINDEX = MAXINDEX+1, and XDELTA and YDELTA are both zero.
    BITBLT [107151,000005]
  • Pixels starting from the ULC of the Source Rectangle in the Source Form are paired with pixels starting at the ULC of the Target Rectangle of the Target Form. Consistent with the boundar­ies of both forms, source and target pixels are (optionally) combined and the target pixel replaced.
  • This must be done in such a way that no target pixel is modified before it is used as a source pixel, since source and target boxes may overlap. BITBLT never smears pixels the way that WCMV smears characters. BITBLT must choose the correct direction for walking the two rectangles.
  • INPUTS
  • AC0: ignored
  • AC1: POINTER TO BITBLT Packet
    .INTEGER X-delta (initially 0, for restart)
    .INTEGER Y-delta (initially 0, for restart)
    .POINTER TO Source Start ULC Specifier
    .POINTER TO Target Start ULC Specifier
    .ORDINAL X-extent (in pixels)
    .ORDINAL Y-extent (in pixels)
    .BIT(32) Operation Mask
    .BIT(32) Combination Rule (low 4 bits)
  • AC2: POINTER TO (Source) Form Descriptor
  • AC3: POINTER TO (Target) Form Descriptor
  • OUTPUTS
  • AC0: unchanged
  • AC1: unchanged (X-delta, Y-delta updated)
  • AC2: unchanged
  • AC3: unchanged
  • C: SET if clipping occurred, unchanged otherwise
  • RDPAL [107151,000002]
  • This instruction retrieves the contents of a palette entry for a particular pixel value within the context of a given form. It reflects the actual intensities stored in the palette, rather than the values that were input to a prior WRPAL (Write Palette).
  • INPUTS
  • AC0: ORDINAL Logical Pixel Value (relative to Form)
  • AC1: POINTER TO Phase 0 RGBL-Tuple
    .BIT(32) Red Intensity (ignored)
    .BIT(32) Green Intensity (ignored)
    .BIT(32) Blue Intensity (ignored)
    .BIT(32) Grey-Level (ignored)
  • AC2: POINTER TO Phase 1 RGBL-Tuple
    .BIT(32) Red Intensity (ignored)
    .BIT(32) Green Intensity (ignored)
    .BIT(32) Blue Intensity (ignored)
    .BIT(32) Grey-Level (ignored)
  • AC3: POINTER TO Form Descriptor
  • OUTPUTS
  • AC0: unchanged
  • AC1: unchanged, POINTER TO Phase 0 RGBL-Tuple
    .BIT(32) Red Intensity (undefined if mono)
    .BIT(32) Green Intensity (undefined if mono)
    .BIT(32) Blue Intensity (undefined if mono)
    .BIT(32) Grey-Level (undefined if color)
  • AC2: unchanged, POINTER TO Phase 1 RGBL-Tuple
    .BIT(32) Red Intensity (undefined if mono)
    .BIT(32) Green Intensity (undefined if mono)
    .BIT(32) Blue Intensity (undefined if mono)
    .BIT(32) Grey-Level (undefined if color)
  • AC3: unchanged
  • METHOD
    • 1) The physical palette unit is identified using the unit designation cell of the form descriptor.
    • 2) The logical pixel value input in AC0 is masked with the Logical Pixel Mask of the form denoted by AC3.
    • 3) The actual physical palette index is computed by ORing the Logical Palette Base from that same form descriptor.
    • 4) The RGBL-tuples returned reflect the actual resolutions of the implementation.
    • 5) Color implementations render L-slots undefined; Monochrome implementations render RGB-slots undefined.
    • 6) Blink-less implementations render Phase-1 tuples undefined.
    WRPAL [107151,000003]
  • This instruction sets up palette entries for both phases of the blink clock (if one exists). It allows color and grey-level to be specified independently. It is assumed that control software sets up the target form's Palette Base and prevents abuse of the WRPAL.
  • INPUTS
  • AC0: ORDINAL Logical Pixel Value (relative to Form)
  • AC1: POINTER TO Phase 0 RGBL-Tuple
    .BIT(32) Red Intensity (ignored if mono)
    .BIT(32) Green Intensity (ignored if mono)
    .BIT(32) Blue Intensity (ignored if mono)
    .BIT(32) Grey-Level (ignored if color)
  • AC2: POINTER TO Phase 1 RGBL-Tuple
    .BIT(32) Red Intensity (ignored if mono)
    .BIT(32) Green Intensity (ignored if mono)
    .BIT(32) Blue Intensity (ignored if mono)
    .BIT(32) Grey-Level (ignored if color)
  • AC3: POINTER TO Form Descriptor
  • OUTPUTS
  • AC0: unchanged
  • AC1: unchanged
  • AC2: unchanged
  • AC3: unchanged
  • METHOD
    • 1) The physical palette unit is identified using the unit designation cell of the form descriptor.
    • 2) The logical pixel value input in AC0 is masked using the Form Mask found in the form descriptor denoted by AC3.
    • 3) The physical palette index is computed by ORing the indi­cated form's Logical Palette Base to the masked pixel value.
    • 4) Non-color implementations ignore RGB intensities; color implementations ignoret grey-level.
    • 5) RGBL values are truncated on the right to internal palette resolution.
    • 6) Blink-less implementations ignore Phase-1 color.
    PFORMS [107151,000007]
  • This function performs the form cache equivalent of PATU (Purge the ATU) or SPTE (Set Page Table Entry). LSBRS and LSBRA (Load Some/All Segment Base Registers) may also invalidate associa­tions of logical address to form descriptor information. Thus PFORMS must also occur as an implicit consequence of executing any of the above instructions.
  • INPUTS
  • AC0: ignored
  • AC1: ignored
  • AC2: ignored
  • AC3: POINTER TO Form Descriptor
  • OUTPUTS
  • AC0: unchanged
  • AC1: unchanged
  • AC2: unchanged
  • AC3: unchanged

Claims (10)

1. A digital computer system comprising main memory means (202) for storing instructions and data; processing means (201) for performing operations on data in response to the instructions; and display means (203, 204) for displaying representations of data; characterised in that the system is arranged to control the display by the method comprising the steps of:
(a) storing in the main memory means (202) form descriptors (209) for describing organisation of data to be displayed:
(b) storing in the main memory means instructions for specifying first data and for specifying representations of first data which are to be displayed, and for describing the position within the organisation described by the form descriptors at which the representations of the first data are to be displayed;
(c) selecting an instruction and a form descriptor to obtain a selected instruction and a selected form descriptor;
(d) calculating, in the processing means, second certain data which is a function of the selected instruction, the selected form descriptor, and certain first data specified by the selected instruction, the second certain data being a representation of what is to be displayed; and
(e) forwarding the second certain data to the display means for representations of the second certain datas to be displayed.
2. A system according to claim 1, characterised in that the second certain data in step (d) is further a function of previous second certain data, in addition to being a function of the selected instruction, the selected form descriptor, and certain first data specified by the selected instruction.
3. A system according to claim 1 or 2, characterised in that the processing means (201) includes a scratchpad memory means (206), in which data can be stored significantly more rapidly than in the main memory means (202) and from which data can be retrieved significantly more rapidly than from the main memory means; and in that step (d) is immediately preceded by:
(c1) determining whether the selected form descriptor is encached in the scratchpad memory means;
(c2) if the selected form descriptor is encached in the scratchpad memory means, retrieving it therefrom;
(c3) if the selected form descriptor is not encached in the scratchpad memory means, retrieving it from the main memory means and encaching it in the scratchpad memory means.
4. A system according to claim 1, 2 or 3, characterised in that the processing means (201) includes a control store; and in that in step (d) the processing means performs the calculating under control of a sequence of microinstructions from a plurality of sequences of microinstructions provided in the control store.
5. A system according to claim 4, characterised in that a sequence of microinstructions currently controlling the processing means may relinquish control of the processing means and direct that the processing means be placed under control of a sequence of instructions from a plurality of sequences of instructions provided in the main memory means (202).
6. A system according to any of claims 1 to 5, characterised in that if it is determined in step (d) that the selected instruction has specified that certain portions of the data representations displayed on the display means are to become obscured or occluded by other data representations, the portions of the second certain data corresponding to the certain portions of the data representations are removed to a retention area (214) within the main memory means; and in that, if it is determined in step (d) that the selected instruction has specified that certain portions of the data representations that previously became obscured or occluded are again to become visible, the corresponding portions of the second certain data are restored from the retention area, whereby there is no need to recompute those portions of the second certain data.
7. A system according to any of claims 1 to 6, characterised in that if it is determined in step (d) that a first certain selected form descriptor delimits a portion of the second certain data already delimited by a second certain selected form descriptor, and if in step (d) it is further determined that the second certain selected form descriptor also delimits a portion of the second certain data not delimited by the first certain selected form descriptor, the second certain specified form descriptor are resolved into subform descriptors, namely a first subform descriptor delimiting the portion of the second certain data delimited by both the first certain and second certain selected form descriptors; and one or more next subform descriptors delimiting the portion of second certain data delimited by the second certain selected form descriptor but not by the first certain selected form descriptor.
8. A system according to claim 7, characterised in that if it is determined in step (d) that a selected form descriptor has previously been resolved into subform descriptors, the function of the selected instruction, the selected form descriptor, and certain first data specified by the selected instruction is resolved into a function of the selected instruction, the subform descriptors, and certain first data specified by the selected instruction.
9. A system according to claim 7 or 8, characterised in that if it is determined in step (d) that a portion of the second certain data that was previously delimited by two or more form descriptors becomes delimited by only one form descriptor, subform descriptors delimiting that portion of the second certain data are discarded.
10. A digital computer system with improved display control capabilities, comprising memory means (202) for storing instructions and data; display means (203, 204) for producing displays in response to first certain data (215) stored in the main memory means; and processing means (201) for performing operations on data in response to the instructions; characterised in that the processing means (201) has the ability to generate the first certain data (215) in response to certain of the instructions which each specify a form descriptor from a plurality of form descriptors (209) stored in the memory means (202) for specifying organisation of data to be displayed; and second certain data (217) in the main memory means, representations of which are to be displayed; and in that the processing means (201) produces the first certain data (215) as a function of each certain instruction, the form descriptor specified by that instruction, and the second certain data specified by that instruction.
EP19850305716 1985-08-12 1985-08-12 A system of graphical manipulation in a potentially windowed data display Expired EP0212016B1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
DE8585305716T DE3580365D1 (en) 1985-08-12 1985-08-12 SYSTEM FOR GRAPHIC MANIPULATION IN A DISPLAY DEVICE WITH POSSIBILITY TO DISPLAY WINDOWS.
EP19850305716 EP0212016B1 (en) 1985-08-12 1985-08-12 A system of graphical manipulation in a potentially windowed data display

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
EP19850305716 EP0212016B1 (en) 1985-08-12 1985-08-12 A system of graphical manipulation in a potentially windowed data display

Publications (2)

Publication Number Publication Date
EP0212016A1 true EP0212016A1 (en) 1987-03-04
EP0212016B1 EP0212016B1 (en) 1990-10-31

Family

ID=8194324

Family Applications (1)

Application Number Title Priority Date Filing Date
EP19850305716 Expired EP0212016B1 (en) 1985-08-12 1985-08-12 A system of graphical manipulation in a potentially windowed data display

Country Status (2)

Country Link
EP (1) EP0212016B1 (en)
DE (1) DE3580365D1 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0622774A1 (en) * 1993-04-28 1994-11-02 Microsoft Corporation System-provided window elements having adjustable dimensions
EP0624863A2 (en) * 1993-05-14 1994-11-17 Microsoft Corporation Scalable three-dimensional window borders
WO1995012194A1 (en) * 1993-10-25 1995-05-04 Taligent, Inc. Object-oriented display system
WO1995016960A1 (en) * 1993-12-17 1995-06-22 Taligent, Inc. Rendering cache in an object oriented system
US5903265A (en) * 1993-04-28 1999-05-11 Microsoft Corporation System-provided window elements having adjustable dimensions
WO2001041117A1 (en) * 1999-12-02 2001-06-07 Koninklijke Philips Electronics N.V. Identification of the position of a video window to be enhanced within a display signal
EP1909258A2 (en) * 2006-10-04 2008-04-09 Samsung Electronics Co., Ltd. Off-screen buffering management device and method

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2517448A1 (en) * 1981-11-27 1983-06-03 Hitachi Ltd APPARATUS FOR CONTROLLING AN IMAGE DISPLAY DEVICE AND METHOD FOR CONTROLLING SUCH A DEVICE
WO1984001655A1 (en) * 1982-10-07 1984-04-26 Western Electric Co Dynamic generation and overlaying of graphic windows for multiple active program storage areas
EP0121015A1 (en) * 1983-03-31 1984-10-10 International Business Machines Corporation Presentation space management and viewporting on a multifunction virtual terminal

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2517448A1 (en) * 1981-11-27 1983-06-03 Hitachi Ltd APPARATUS FOR CONTROLLING AN IMAGE DISPLAY DEVICE AND METHOD FOR CONTROLLING SUCH A DEVICE
WO1984001655A1 (en) * 1982-10-07 1984-04-26 Western Electric Co Dynamic generation and overlaying of graphic windows for multiple active program storage areas
EP0121015A1 (en) * 1983-03-31 1984-10-10 International Business Machines Corporation Presentation space management and viewporting on a multifunction virtual terminal

Cited By (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0622774A1 (en) * 1993-04-28 1994-11-02 Microsoft Corporation System-provided window elements having adjustable dimensions
US6297837B1 (en) 1993-04-28 2001-10-02 Microsoft Corporation Method of maintaining characteristics information about a system component either modified by an application program or a user initiated change
US6262733B1 (en) 1993-04-28 2001-07-17 Microsoft Corporation Method of storing and providing icons according to application program calls and user-prompted system metric changes
US6031534A (en) * 1993-04-28 2000-02-29 Microsoft Corporation Operating system function for specifying a checked image representation and an unchecked image representation of a menu item
US5977966A (en) * 1993-04-28 1999-11-02 Microsoft Corporation System-provided window elements having adjustable dimensions
US5903265A (en) * 1993-04-28 1999-05-11 Microsoft Corporation System-provided window elements having adjustable dimensions
US5590267A (en) * 1993-05-14 1996-12-31 Microsoft Corporation Method and system for scalable borders that provide an appearance of depth
EP0814455A1 (en) * 1993-05-14 1997-12-29 Microsoft Corporation Scalable three-dimensional window borders
US5452406A (en) * 1993-05-14 1995-09-19 Microsoft Corporation Method and system for scalable borders that provide an appearance of depth
EP0624863A3 (en) * 1993-05-14 1995-05-10 Microsoft Corp Scalable three-dimensional window borders.
EP0624863A2 (en) * 1993-05-14 1994-11-17 Microsoft Corporation Scalable three-dimensional window borders
US5522025A (en) * 1993-10-25 1996-05-28 Taligent, Inc. Object-oriented window area display system
WO1995012194A1 (en) * 1993-10-25 1995-05-04 Taligent, Inc. Object-oriented display system
US6750858B1 (en) * 1993-10-25 2004-06-15 Object Technology Licensing Corporation Object-oriented window area display system
US5530799A (en) * 1993-12-17 1996-06-25 Taligent Inc. Rendering cache in an object oriented system
WO1995016960A1 (en) * 1993-12-17 1995-06-22 Taligent, Inc. Rendering cache in an object oriented system
WO2001041117A1 (en) * 1999-12-02 2001-06-07 Koninklijke Philips Electronics N.V. Identification of the position of a video window to be enhanced within a display signal
EP1909258A2 (en) * 2006-10-04 2008-04-09 Samsung Electronics Co., Ltd. Off-screen buffering management device and method
EP1909258A3 (en) * 2006-10-04 2009-08-05 Samsung Electronics Co., Ltd. Off-screen buffering management device and method

Also Published As

Publication number Publication date
DE3580365D1 (en) 1990-12-06
EP0212016B1 (en) 1990-10-31

Similar Documents

Publication Publication Date Title
US5091720A (en) Display system comprising a windowing mechanism
US5995120A (en) Graphics system including a virtual frame buffer which stores video/pixel data in a plurality of memory areas
EP0568078B1 (en) External interface for a high performance graphics adapter allowing for graphics compatibility
US7262776B1 (en) Incremental updating of animated displays using copy-on-write semantics
EP0279229B1 (en) A graphics display system
US5218674A (en) Hardware bit block transfer operator in a graphics rendering processor
US5021974A (en) Method for updating a display bitmap with a character string or the like
US5751979A (en) Video hardware for protected, multiprocessing systems
US6078306A (en) Basic input-output system (BIOS) read-only memory (ROM) with capability for vertical scrolling of bitmapped graphic text by columns
US4873652A (en) Method of graphical manipulation in a potentially windowed display
US5056041A (en) Data processing apparatus with improved bit masking capability
JPH0469794B2 (en)
US5522082A (en) Graphics display processor, a graphics display system and a method of processing graphics data with control signals connected to a central processing unit and graphics circuits
EP0279225B1 (en) Reconfigurable counters for addressing in graphics display systems
JP3734226B2 (en) Method and apparatus for high speed block transfer of compressed, word aligned bitmaps
US5185859A (en) Graphics processor, a graphics computer system, and a process of masking selected bits
US5448688A (en) Image position interpretation in a graphics system
US5986661A (en) Graphics output system with bounded updating
EP0279227B1 (en) Raster display vector generator
JP2548765B2 (en) Display device
EP0212016B1 (en) A system of graphical manipulation in a potentially windowed data display
US6344856B1 (en) Text optimization
EP0223557A2 (en) Display control in a data processing system
CA1229439A (en) Data display system
CA1237199A (en) Method of graphical manipulation in a potentially windowed data display

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): DE FR GB

17P Request for examination filed

Effective date: 19870811

17Q First examination report despatched

Effective date: 19890803

GRAA (expected) grant

Free format text: ORIGINAL CODE: 0009210

AK Designated contracting states

Kind code of ref document: B1

Designated state(s): DE FR GB

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: FR

Effective date: 19901031

REF Corresponds to:

Ref document number: 3580365

Country of ref document: DE

Date of ref document: 19901206

EN Fr: translation not filed
PLBE No opposition filed within time limit

Free format text: ORIGINAL CODE: 0009261

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT

26N No opposition filed
PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: GB

Payment date: 19930701

Year of fee payment: 9

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: DE

Payment date: 19930723

Year of fee payment: 9

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: GB

Effective date: 19940812

GBPC Gb: european patent ceased through non-payment of renewal fee

Effective date: 19940812

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: DE

Effective date: 19950503