EP0099645A2 - Stroke display apparatus - Google Patents

Stroke display apparatus Download PDF

Info

Publication number
EP0099645A2
EP0099645A2 EP83303447A EP83303447A EP0099645A2 EP 0099645 A2 EP0099645 A2 EP 0099645A2 EP 83303447 A EP83303447 A EP 83303447A EP 83303447 A EP83303447 A EP 83303447A EP 0099645 A2 EP0099645 A2 EP 0099645A2
Authority
EP
European Patent Office
Prior art keywords
vector
stroke
angle
character
display
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
EP83303447A
Other languages
German (de)
French (fr)
Other versions
EP0099645B1 (en
EP0099645A3 (en
Inventor
Jay Roland Dettmer
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.)
Honeywell Inc
Original Assignee
Honeywell Inc
Sperry 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 Honeywell Inc, Sperry Corp filed Critical Honeywell Inc
Publication of EP0099645A2 publication Critical patent/EP0099645A2/en
Publication of EP0099645A3 publication Critical patent/EP0099645A3/en
Application granted granted Critical
Publication of EP0099645B1 publication Critical patent/EP0099645B1/en
Anticipated expiration legal-status Critical
Expired - Lifetime 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
    • G09G1/00Control arrangements or circuits, of interest only in connection with cathode-ray tube indicators; General aspects or details, e.g. selection emphasis on particular characters, dashed line or dotted line generation; Preprocessing of data
    • G09G1/06Control arrangements or circuits, of interest only in connection with cathode-ray tube indicators; General aspects or details, e.g. selection emphasis on particular characters, dashed line or dotted line generation; Preprocessing of data using single beam tubes, e.g. three-dimensional or perspective representation, rotation or translation of display pattern, hidden lines, shadows
    • G09G1/08Control arrangements or circuits, of interest only in connection with cathode-ray tube indicators; General aspects or details, e.g. selection emphasis on particular characters, dashed line or dotted line generation; Preprocessing of data using single beam tubes, e.g. three-dimensional or perspective representation, rotation or translation of display pattern, hidden lines, shadows the beam directly tracing characters, the information to be displayed controlling the deflection and the intensity as a function of time in two spatial co-ordinates, e.g. according to a cartesian co-ordinate system
    • G09G1/10Control arrangements or circuits, of interest only in connection with cathode-ray tube indicators; General aspects or details, e.g. selection emphasis on particular characters, dashed line or dotted line generation; Preprocessing of data using single beam tubes, e.g. three-dimensional or perspective representation, rotation or translation of display pattern, hidden lines, shadows the beam directly tracing characters, the information to be displayed controlling the deflection and the intensity as a function of time in two spatial co-ordinates, e.g. according to a cartesian co-ordinate system the deflection signals being produced by essentially digital means, e.g. incrementally

Definitions

  • the invention relates to symbol generators or stroke display apparatus, with particular but exclusive, regard to digital-to-stroke generators.
  • Prior art stroke generators typically have a fixed character memory with fixed A x and ⁇ y steps that define the strokes that make up a character to be displayed.
  • a prior art stroke generator reference is made to U.S. Patent Specification No.4,115,863.
  • the use of a fixed character memory is often undesirable in that it prevents any dynamic rotation of the character set.
  • a minor improvement can be had by replacing the fixed character memory with a programmable memory (RAM).
  • RAM programmable memory
  • This approach enables the rotation of characters through direct manipulation of the ⁇ x and ⁇ y steps which make up the character as generated by the host processor.
  • the host processor must'compute the rotated stroke angle and the corresponding A x and ⁇ y steps. For displays that contain many different_rotating characters, the computation burden of rotating many characters may be prohibitive.
  • stroke display apparatus having display means with display face and writing means positionable along x and y display axes for writing vectors of predetermined length, origin, and slope, and for dynamically rotating the vectors by a predetermined offset angle characterised in that the apparatus comprises means for representing said vectors in terms of a vector angle with respect to a reference axis of the display face, means for summing the vector angle and the offset angle, thereby providing a draw angle, means responsive to the draw angle for providing first and second orthogonal signals representing incremental steps defining the vector rotated by the offset angle, and means responsive to the first and second orthogonal signals for writing the vector rotated by the offset angle on the display face.
  • the present invention enables a host processor dynamically to rotate characters simply by specifying the angle of rotation or offset angle for the rotated characters.
  • the fixed character memory specifies the non-rotated character in terms of stroke angles rather than in terms ⁇ x and ⁇ y steps.
  • each stroke or vector of each character is specified in terms of a vector angle with respect to a reference axis, which may be the x axis or y axis of the display face.
  • the offset angle is stored in a latch and summed with each vector angle in an angle adder which provides draw angles corresponding to each vector angle rotated by the pre-determined offset angle.
  • the invention thus requires the host processor to furnish only the rotation angle or offset angle, whereby the new drawing angle is computed.
  • the drawing angle may be supplied to an angle-to-( ⁇ x, ⁇ y) converter which may be a look-up memory (PROM).
  • the converter computes the A x and a y steps corresponding to the drawing angle, thereby-relieving the host processor of this computation burden.
  • the ⁇ x anda y steps so computed are stored in respective accumulators for ultimate conversion into analogue format by respective digital-to-analogue converters.
  • the analogue signals are then used to drive a conventional writing means such as a cathode ray tube display having x and y deflection means for deflecting a beam along the x and y axes of the display face.
  • the character memory also provides character attribute information, such as brightness, colour, or blanking, as well as character stroke information relative to the length of each vector making up a character.
  • character attribute information such as brightness, colour, or blanking
  • the present invention is useful for displaying characters or symbols such as vectors, circles, and alphanumeric characters on the display face of any display apparatus having x and y display axes and having means for positioning or writing a symbol or character along those axes.
  • the invention will be described in part by reference to a typical character or symbol which might be drawn on the display face.
  • Figures la and lb illustrate one such typical character, namely the letter "A”.
  • the letter "A" is centred at position x o' y o
  • this same letter, centred at x o ,y o is rotated by an offset angle ⁇ o clockwise from the vertical.
  • the vertical axis or y axis serves-as the reference axis against which vector angles are measured. It will be apparent that the selection of the y axis is merely for convenience, other reference axes being equally applicable to the invention.
  • the letter "A” may be drawn by making the six strokes indicated by reference numerals 1 to 6.
  • bold or solid lines denote visible strokes
  • blanked strokes denote blanked strokes.
  • the quality of being visible or blanked will be referred to herein as attributes.
  • Other attributes such as brightness or colour may also be implemented in particular applications, as will be apparent to those skilled in the art.
  • Table 1 below sets forth six stroke commands as might be executed by the invention to generate a typical letter "A".
  • the angles delineated in Table 1 are measured with respect to the vertical of y axis and the length of each stroke are scaled for a 0.125 inch high character.
  • the presently preferred embodiment is shown in conjunction with a conventional host processor 10 for supplying digital commands which specify a particular vector, symbol, or character including its position in an x, y Cartesian reference frame, as well as its offset angle or degree of rotation with respect to a reference axis.
  • the host processor 10 may be implemented using a commercially available microprocessor in the fashion taught in U.S. Patent Specification No.4,115,863 referenced above.
  • the host processor 10 might place the following commands into a stroke instruction memory 12 via a data bus 14 under the control of an address bus 16.
  • the stroke instruction memory 12 may be any conventional, commercially available memory device having a data bus 18 on which output data may be placed and having an address bus 20 coupled from a stroke instruction counter 22.
  • the address bus 20 is coupled to the stroke instruction counter 22 which generates stroke instruction addresses, in response to control signals received from a stroke state machine 26, and places them on the address bus 20.
  • the stroke instruction counter 22 is also coupled to receive data from the data bus 18 in response to signals from the stroke state machine 26.
  • the stroke state machine 26 is coupled to the data bus 18 and fetches stroke instructions from the stroke instruction memory 12. Furthermore, the stroke state machine 26 identifies each instruction and executes it, receiving status signals and distributing control signals as delineated in Table II below.
  • the display means 36 may be a conventional cathode ray tube display (CRT) wherein an electron beam is swept across a phosphorescent display face 37.
  • CTR cathode ray tube display
  • the beam is positionable along x and y display axes of the display face by means of x and y deflection plates (not shown) under the control of signals from the x.deflection section 34 and y deflection section 38.
  • the conventional display means also includes a blanking section 40 for blanking or interrupting the beam thereby to render any strokes invisible. While the invention is described herein in connection with a conventional CRT display, it will be appreciated that other equivalent displays may be utilised. These include liquid crystal displays, dot matrix printers, x, y plotters, colour displays, and so forth.
  • the output of the y accumulator 42 is coupled to a y deflection digital-to-analogue converter 44 whose output is coupled to the y deflection section 38 of the display means.
  • the attribute refers to the quality of a particular stroke being visible or blanked, and it will be seen that this attribute information ultimately controls the blanking section 40 of the display means.
  • the attribute signal may be extended to control other qualities such as brightness, dashed/solid lines, blinking, or colour, for example.
  • the offset angle ⁇ o shown in Figure lb, is a measure of the desired character rotation referenced to some predetermined reference axis. In the preferred embodiment, the y display axis is chosen as the reference axis.
  • the stroke display apparatus of the present invention is now set up to draw the character constituting a series of concatenated strokes or vectors.
  • the stroke commands specifying the stroke number, direction or angle, length, attributes, and last stroke flag needed to generate the unrotated character are stored in a character memory 54.
  • Table I sets forth the stroke commands for the letter "A" as already mentioned.
  • the character memory is addressed via a character address bus 56 which is coupled to a character address counter 58.
  • the character address counter 58 is in turn coupled to the data bus 18.
  • the stroke state machine 26 upon fetching the instruction "Draw Character A", loads the starting address contained in this instruction of the stroke commands for the character into the character address counter 58 via the data bus 18.
  • the character address counter 58 generates the address for the first stroke or vector of the character to be drawn and places this on the character address bus 56, thereby fetching the unrotated first stroke data from character memory 54.
  • This unrotated first stroke data includes the character stroke angle which is placed on a character angle bus 62, character length which is placed on a length bus 64, character attributes which is placed on a character attributes bus 66, and last stroke flag which is placed on a last stroke flag bus 68.
  • a bus buffer 69 isolates the buses 62, 64, 66, and 68 from the bus 18 by storing data coupled thereto from the bus 18 for subsequent distribution.
  • the character angle on the character angle bus 62 is loaded into an angle adder 70. Also loaded into the angle adder 70 via a lead 72 is the offset angle ⁇ o which is stored in the offset angle latch 50.
  • the angle adder 70 adds the unrotated character stroke angle to the offset angle, thereby generating a draw angle ⁇ d which is placed on a draw angle bus 74.
  • the draw angle bus 74 is coupled to an angle-to- ( ⁇ x, ⁇ y) converter 76.
  • the converter 76 which may be implemented by means of a look-up table stored in a memory such as a programmable read only memory (PROM), converts the drawing angle into orthogonal incremental signals or A x and ⁇ y steps defining the stroke or vector rotated by the offset angle.
  • the conversion may be viewed as transforming the character angle from a polar coordinate system to a Cartesian coordinate system where the following relationship applies:
  • k denotes the length or magnitude of an incremental vector segment equal to the hypotenuse of the right triangle having legs ⁇ x and A y respectively.
  • the length k and its relationship to A x and ⁇ y is shown in the inset of Figure 3.
  • the Ax value is outputed on the bus 80 to the x accumulator 30 and the ⁇ y value is outputed on bus 82 to the y accumulator42.
  • the ⁇ x and A y values are summed with the initial or starting values x 0 and y 0 and the sums stored in the accumulators, replacing the initial values.
  • the new values stored in the accumulators 30 and 42 thus represent the x and y coordinates of the end point of an incremental stroke or vector originating at x o , y o .
  • the digital-to-analogue converters 32 and 44 convert this digital vector information into analogue voltages for deflecting or drawing the incremental vector or stroke on the display face 37 of the display means.
  • the first stroke is drawn by concatenating a series of these incremental vectors until the desired stroke length is reached. If the draw angle is held constant for the series of concatenations, the stroke will appear as a straight line on the display face; however, if the draw angle is changed during concatenation, a curve is drawn. It will be understood that by concatenating a large number of very small incremental steps, a smooth curve dr circle can be closely approximated.
  • the apparent smoothness of a line or curve is dependent upon the diameter or radius of the smallest spot, pixel, or dot reproducible by the particular display means.
  • the spot diameter or spot radius affects the apparent smoothness of a line or curve.
  • a typical stroke comprising a series of concatenated incremental vectors is shown. Also shown are a plurality of consecutively drawn spots 100, 101, 102,... 100 +n corresponding to the concatenated incremental steps.
  • the length of each incremental vector segment k is restricted to be less than, or equal to, the spot radius. This assures the apparent smoothness of a line or curve.
  • a stroke or vector line of lengtn L may thus be generated by successively adding A x and A y steps to the current x, y position n times; where n is the number of iterations.
  • L nk.
  • the number of iterations n is controlled by a character stroke counter 90 which receives the stroke length information from the character memory 54 on the length bus 64.
  • the character stroke counter 90 thus counts the number of iterations or incremental vector segments drawn and signifies when the appropriate stroke length is reached.
  • Character memory 54 also outputs the character attribute signal on the lead 66 which controls the blanking section 40 to determine whether the stroke being drawn is visible or blanked.
  • the character memory 54 also outputs a last stroke flag on the bus 68 signifying when the character is complete.
  • the status of the last stroke flag is checked to determine whether the last stroke flag is set. If the last stroke flag is not set, such as for the first five strokes of the letter "A" of Table I, then the character address counter 58 is incremented to address the next stroke of the character stored in character memory 54 and the process is repeated for that stroke. If the last stroke flag is set, then the character is complete and the stroke state machine 26 executes the next instruction.
  • the present invention enables the host processor dynamically to rotate characters simply by specifying the angle of rotation for the rotated characters.
  • the present invention significantly relieves the host processor of much of its computation burden by providing hardware for representing stroke vectors in terms of stroke angles rather than A x and A y steps.
  • the hardware then computes the new drawing angle and then converts this new drawing angle into the corresponding ⁇ x and A y steps.
  • the invention is, therefore, compatible with prior art display means utilising ⁇ x and ⁇ y deflection commands.
  • Another advantage of the present invention is that it may be used to position or reposition a character or symbol by translating it to a different location on the display face.
  • the invention accomplishes this task without the need to perform multiplications. For example, the problem of drawing a character or symbol at a point (x 2 ,y 2 ) rotating about a known fixed point (x 1 ,y 1 ), the prior art host processor needed to compute the point (x 2 ,y 2 ) as follows:
  • Figure 4 illustrates this translation problem.
  • the character to be drawn has the appearance of an aircraft wing and is denoted by reference numeral 200.
  • the known fixed point (x 1 ,y 1 ) is shown for purposes of illustration to be located at the origin of an x,y Cartesian coordinate system.
  • a remote point (x 2 ,y 2 ) located a distance R1 from point (x 1 ,y 1 ) at an angle ⁇ 1 from the y axis defines one point on the character 200.
  • R 1 may be considered as a translation/rotation positioning vector, and is shown in broken lines in Figure 4 to denote that it would be drawn with the beam blanked.
  • the point (x 1 ,y 1 ) becomes the centre of translation/rotation.
  • the character 200 in order to produce the character 200 translated by the vector R l , it is necessary only to include an additional stroke command for vector R 1 prior to the stroke commands used to generate the character 200. A blanked stroke is utilised for this purpose. Then if it is also desired to rotate the translated character by offset angle ⁇ 2 , this is accomplished by loading the value e 2 into the offset latch 50 as discussed above. It will be seen that the character 200 may be given apparent motion by dynamically varying 9 1 , R 1 and ⁇ 2 over successive iterations of the stroke display.

Abstract

Stroke display apparatus generates symbols or characters on a display screen (37) and permits dynamic rotation or translation of those characters without placing a computation burden on the host processor (10). The characters are represented as a series of connected line segments, or blank segments, each having a characteristic direction or vector angle. Each of the line segments is generated by successively adding incremental A x and A y steps (76) to an x, y position until the desired length is achieved. The character is rotated by adding (at 70) a predetermined offset angle to each characteristic vector angle and then by converting the rotated vector angle into incremental A x and Δ y steps. Character translation is accomplished by including an extra, typically blanked, line segment command before the character is drawn.

Description

  • The invention relates to symbol generators or stroke display apparatus, with particular but exclusive, regard to digital-to-stroke generators.
  • Prior art stroke generators typically have a fixed character memory with fixed A x and Δ y steps that define the strokes that make up a character to be displayed. As an example of a prior art stroke generator, reference is made to U.S. Patent Specification No.4,115,863. The use of a fixed character memory is often undesirable in that it prevents any dynamic rotation of the character set. A minor improvement can be had by replacing the fixed character memory with a programmable memory (RAM). This approach enables the rotation of characters through direct manipulation of the Δx and Δ y steps which make up the character as generated by the host processor. The host processor must'compute the rotated stroke angle and the corresponding A x and Δ y steps. For displays that contain many different_rotating characters, the computation burden of rotating many characters may be prohibitive.
  • According to the present invention there is provided stroke display apparatus having display means with display face and writing means positionable along x and y display axes for writing vectors of predetermined length, origin, and slope, and for dynamically rotating the vectors by a predetermined offset angle characterised in that the apparatus comprises means for representing said vectors in terms of a vector angle with respect to a reference axis of the display face, means for summing the vector angle and the offset angle, thereby providing a draw angle, means responsive to the draw angle for providing first and second orthogonal signals representing incremental steps defining the vector rotated by the offset angle, and means responsive to the first and second orthogonal signals for writing the vector rotated by the offset angle on the display face.
  • The present invention enables a host processor dynamically to rotate characters simply by specifying the angle of rotation or offset angle for the rotated characters. The fixed character memory specifies the non-rotated character in terms of stroke angles rather than in terms Δ x and Δ y steps. Thus each stroke or vector of each character is specified in terms of a vector angle with respect to a reference axis, which may be the x axis or y axis of the display face. The offset angle is stored in a latch and summed with each vector angle in an angle adder which provides draw angles corresponding to each vector angle rotated by the pre-determined offset angle. The invention thus requires the host processor to furnish only the rotation angle or offset angle, whereby the new drawing angle is computed.
  • The drawing angle may be supplied to an angle-to-(Δ x, Δ y) converter which may be a look-up memory (PROM). The converter computes the A x and a y steps corresponding to the drawing angle, thereby-relieving the host processor of this computation burden. The Δ x anda y steps so computed are stored in respective accumulators for ultimate conversion into analogue format by respective digital-to-analogue converters. The analogue signals are then used to drive a conventional writing means such as a cathode ray tube display having x and y deflection means for deflecting a beam along the x and y axes of the display face.
  • The character memory also provides character attribute information, such as brightness, colour, or blanking, as well as character stroke information relative to the length of each vector making up a character.
  • A stroke generator in accordance with the invention will now be described in greater detail, by way of example, with reference to the accompanying drawings, in which:-
    • Figure la illustrates a typical symbol or character in its unrotated state, specifically the letter "A".
    • Figure lb illustrates the same symbol or character rotated by a predetermined offset angle.
    • Figure 2a and 2b together show a schematic block diagram of the stroke generator,
    • Figure 3 is a graph illustrating parameters utilised in the vector generation of the present invention, and
    • Figure 4 is a graph illustrating the figure repositioning feature of the present invention.
  • The present invention is useful for displaying characters or symbols such as vectors, circles, and alphanumeric characters on the display face of any display apparatus having x and y display axes and having means for positioning or writing a symbol or character along those axes. The invention will be described in part by reference to a typical character or symbol which might be drawn on the display face. Figures la and lb illustrate one such typical character, namely the letter "A". In Figure la, the letter "A" is centred at position xo' yo, and in Figure lb this same letter, centred at xo,yo, is rotated by an offset angle θo clockwise from the vertical. Thus in the preferred embodiment, the vertical axis or y axis serves-as the reference axis against which vector angles are measured. It will be apparent that the selection of the y axis is merely for convenience, other reference axes being equally applicable to the invention.
  • With continued reference to Figure la, it will be seen that the letter "A" may be drawn by making the six strokes indicated by reference numerals 1 to 6. In Figure 1 bold or solid lines denote visible strokes, and'broken or dashed lines denote blanked strokes. The quality of being visible or blanked will be referred to herein as attributes. Other attributes such as brightness or colour may also be implemented in particular applications, as will be apparent to those skilled in the art.
  • Table 1 below sets forth six stroke commands as might be executed by the invention to generate a typical letter "A". The angles delineated in Table 1 are measured with respect to the vertical of y axis and the length of each stroke are scaled for a 0.125 inch high character.
  • Figure imgb0001
  • With reference to Figure 2, the presently preferred embodiment is shown in conjunction with a conventional host processor 10 for supplying digital commands which specify a particular vector, symbol, or character including its position in an x, y Cartesian reference frame, as well as its offset angle or degree of rotation with respect to a reference axis. The host processor 10 may be implemented using a commercially available microprocessor in the fashion taught in U.S. Patent Specification No.4,115,863 referenced above.
  • For example, considering the task of drawing the letter "A" centred at postion xo,yo and rotated at an angle θo clockwise from the vertical, as depicted in Figure lb, the host processor 10 might place the following commands into a stroke instruction memory 12 via a data bus 14 under the control of an address bus 16.
    • Set x = x 0
    • Set y = y0
    • Set Attributes = A0
    • Set Offset Angle = 90
    • Draw Character "A"
  • The stroke instruction memory 12 may be any conventional, commercially available memory device having a data bus 18 on which output data may be placed and having an address bus 20 coupled from a stroke instruction counter 22. The address bus 20 is coupled to the stroke instruction counter 22 which generates stroke instruction addresses, in response to control signals received from a stroke state machine 26, and places them on the address bus 20. The stroke instruction counter 22 is also coupled to receive data from the data bus 18 in response to signals from the stroke state machine 26. The stroke state machine 26 is coupled to the data bus 18 and fetches stroke instructions from the stroke instruction memory 12. Furthermore, the stroke state machine 26 identifies each instruction and executes it, receiving status signals and distributing control signals as delineated in Table II below.
  • Figure imgb0002
  • When the instruction "Set x = xo" is fetched by the stroke state machine 26 and executed, the value x0 is loaded via the data bus 18 into an x accumulator 30. The output of the x accumulator 30 is coupled to an x deflection digital-to-analogue converter 32 which provides x deflection signals to the x deflection section 34 of a display means 36. The display means 36 may be a conventional cathode ray tube display (CRT) wherein an electron beam is swept across a phosphorescent display face 37. It will be understood that the beam is positionable along x and y display axes of the display face by means of x and y deflection plates (not shown) under the control of signals from the x.deflection section 34 and y deflection section 38. The conventional display means also includes a blanking section 40 for blanking or interrupting the beam thereby to render any strokes invisible. While the invention is described herein in connection with a conventional CRT display, it will be appreciated that other equivalent displays may be utilised. These include liquid crystal displays, dot matrix printers, x, y plotters, colour displays, and so forth.
  • After loading the value x0 in the x accumulator 30, the stroke state machine 26 fetches and executes the next command stored in stroke instruction memory 12. In the generation of the letter "A", the next command or instructions is "Set y = yo". It will, of course, be appreciated that the sequence of command described herein is for the generation of the typical letter "A". Different command sequences would be stored in the stroke instruction memory 12 for different symbols or characters as might be readily constructed by those skilled in the art. The stroke state machine 28 executes the command "Set y = yo" by fetching the y0 value and loading that value into the y accumulator 42 via the data bus 18. The output of the y accumulator 42 is coupled to a y deflection digital-to-analogue converter 44 whose output is coupled to the y deflection section 38 of the display means.
  • Next, the instruction "Set attributes = Ao" is fetched and executed by the stroke state machine 26, by loading the value A0 into an attribute latch 46 via the data bus 18. it will be recalled that for the generation of the letter "A" the attribute refers to the quality of a particular stroke being visible or blanked, and it will be seen that this attribute information ultimately controls the blanking section 40 of the display means. In more elaborate displays, the attribute signal may be extended to control other qualities such as brightness, dashed/solid lines, blinking, or colour, for example.
  • Next, the stroke state machine 26 fetches the instruction "Set Offset Angle = θo" and loads θo into an offset angle latch 50 via a bus 52 coupled to data bus 18. The offset angle θo, shown in Figure lb, is a measure of the desired character rotation referenced to some predetermined reference axis. In the preferred embodiment, the y display axis is chosen as the reference axis.
  • Having loaded the centre position (xo,yo) about which the letter "A" is centred, the attribute instruction, and the offset angle θo, the stroke display apparatus of the present invention is now set up to draw the character constituting a series of concatenated strokes or vectors. The stroke commands specifying the stroke number, direction or angle, length, attributes, and last stroke flag needed to generate the unrotated character are stored in a character memory 54. As an example, Table I sets forth the stroke commands for the letter "A" as already mentioned. The character memory is addressed via a character address bus 56 which is coupled to a character address counter 58. The character address counter 58 is in turn coupled to the data bus 18. The stroke state machine 26, upon fetching the instruction "Draw Character A", loads the starting address contained in this instruction of the stroke commands for the character into the character address counter 58 via the data bus 18. The character address counter 58 generates the address for the first stroke or vector of the character to be drawn and places this on the character address bus 56, thereby fetching the unrotated first stroke data from character memory 54. This unrotated first stroke data includes the character stroke angle which is placed on a character angle bus 62, character length which is placed on a length bus 64, character attributes which is placed on a character attributes bus 66, and last stroke flag which is placed on a last stroke flag bus 68. A bus buffer 69 isolates the buses 62, 64, 66, and 68 from the bus 18 by storing data coupled thereto from the bus 18 for subsequent distribution.
  • The character angle on the character angle bus 62 is loaded into an angle adder 70. Also loaded into the angle adder 70 via a lead 72 is the offset angle θo which is stored in the offset angle latch 50. The angle adder 70 adds the unrotated character stroke angle to the offset angle, thereby generating a draw angle θd which is placed on a draw angle bus 74. The draw angle bus 74 is coupled to an angle-to- ( Δ x, Δ y) converter 76. The converter 76, which may be implemented by means of a look-up table stored in a memory such as a programmable read only memory (PROM), converts the drawing angle into orthogonal incremental signals or A x and Δ y steps defining the stroke or vector rotated by the offset angle. The conversion may be viewed as transforming the character angle from a polar coordinate system to a Cartesian coordinate system where the following relationship applies:
    Figure imgb0003
    Figure imgb0004
    In the above relationships, k denotes the length or magnitude of an incremental vector segment equal to the hypotenuse of the right triangle having legs Δ x and A y respectively. The length k and its relationship to A x and Δ y is shown in the inset of Figure 3. The Ax value is outputed on the bus 80 to the x accumulator 30 and the Δy value is outputed on bus 82 to the y accumulator42. Inthe accumulators, the Δx and A y values are summed with the initial or starting values x0 and y0 and the sums stored in the accumulators, replacing the initial values. The new values stored in the accumulators 30 and 42 thus represent the x and y coordinates of the end point of an incremental stroke or vector originating at xo, yo. The digital-to- analogue converters 32 and 44 convert this digital vector information into analogue voltages for deflecting or drawing the incremental vector or stroke on the display face 37 of the display means. The first stroke is drawn by concatenating a series of these incremental vectors until the desired stroke length is reached. If the draw angle is held constant for the series of concatenations, the stroke will appear as a straight line on the display face; however, if the draw angle is changed during concatenation, a curve is drawn. It will be understood that by concatenating a large number of very small incremental steps, a smooth curve dr circle can be closely approximated.
  • The apparent smoothness of a line or curve is dependent upon the diameter or radius of the smallest spot, pixel, or dot reproducible by the particular display means. In a cathode ray tube display system the spot diameter or spot radius affects the apparent smoothness of a line or curve. Referring to Figure 3, a typical stroke comprising a series of concatenated incremental vectors is shown. Also shown are a plurality of consecutively drawn spots 100, 101, 102,... 100 +n corresponding to the concatenated incremental steps. In the preferred embodiment, the length of each incremental vector segment k is restricted to be less than, or equal to, the spot radius. This assures the apparent smoothness of a line or curve. Utilising the Pythagorean theorem, it will be seen that the incremental length k = (Δ x + A y ) . A stroke or vector line of lengtn L may thus be generated by successively adding A x and A y steps to the current x, y position n times; where n is the number of iterations. Thus it will be seen that L = nk.
  • The number of iterations n is controlled by a character stroke counter 90 which receives the stroke length information from the character memory 54 on the length bus 64. The character stroke counter 90 thus counts the number of iterations or incremental vector segments drawn and signifies when the appropriate stroke length is reached. Character memory 54 also outputs the character attribute signal on the lead 66 which controls the blanking section 40 to determine whether the stroke being drawn is visible or blanked. The character memory 54 also outputs a last stroke flag on the bus 68 signifying when the character is complete.
  • After the first stroke of the character is completed, the status of the last stroke flag is checked to determine whether the last stroke flag is set. If the last stroke flag is not set, such as for the first five strokes of the letter "A" of Table I, then the character address counter 58 is incremented to address the next stroke of the character stored in character memory 54 and the process is repeated for that stroke. If the last stroke flag is set, then the character is complete and the stroke state machine 26 executes the next instruction.
  • It will thus be seen that the present invention enables the host processor dynamically to rotate characters simply by specifying the angle of rotation for the rotated characters. The present invention significantly relieves the host processor of much of its computation burden by providing hardware for representing stroke vectors in terms of stroke angles rather than A x and A y steps. The hardware then computes the new drawing angle and then converts this new drawing angle into the corresponding Δ x and A y steps. The invention is, therefore, compatible with prior art display means utilising Δ x andΔ y deflection commands.
  • Another advantage of the present invention is that it may be used to position or reposition a character or symbol by translating it to a different location on the display face. The invention accomplishes this task without the need to perform multiplications. For example, the problem of drawing a character or symbol at a point (x2,y2) rotating about a known fixed point (x1,y1), the prior art host processor needed to compute the point (x2,y2) as follows:
    Figure imgb0005
    Figure imgb0006
  • The steps required to multiply R1 times either the sine or cosine terms requires a number of time-consuming host processor computaticns.
  • Figure 4 illustrates this translation problem. In Figure 4 the character to be drawn has the appearance of an aircraft wing and is denoted by reference numeral 200. The known fixed point (x1,y1) is shown for purposes of illustration to be located at the origin of an x,y Cartesian coordinate system. A remote point (x2,y2) located a distance R1 from point (x1,y1) at an angle θ1 from the y axis defines one point on the character 200. R1 may be considered as a translation/rotation positioning vector, and is shown in broken lines in Figure 4 to denote that it would be drawn with the beam blanked. Thus the point (x1,y1) becomes the centre of translation/rotation. It may be desired that the character 200 be rotated by an offset angle θ2 as shown in Figure 4.
  • With the present invention, in order to produce the character 200 translated by the vector Rl, it is necessary only to include an additional stroke command for vector R1 prior to the stroke commands used to generate the character 200. A blanked stroke is utilised for this purpose. Then if it is also desired to rotate the translated character by offset angle θ2, this is accomplished by loading the value e2 into the offset latch 50 as discussed above. It will be seen that the character 200 may be given apparent motion by dynamically varying 91, R1 and θ2 over successive iterations of the stroke display.

Claims (15)

1. Stroke display apparatus having display means with display face and writing means positionable along x and y display axes for writing vectors of predetermined length, origin, and slope, and for dynamically rotating the vectors by a predetermined offset angle characterised in that the apparatus comprises means (12) for representing said vectors in terms of a vector angle with respect to a reference axis of the display face (37), means (70) for summing the vector angle and the offset angle, thereby providing a draw angle, means (76) responsive to the draw angle for providing first and second orthogonal signals representing incremental steps defining the vector rotated by the offset angle, and means (30, 42) responsive to the first and second orthogonal signals for writing the vector rotated by the offset angle on the display face (37).
2. Apparatus according to claim 1, characterised in that the reference axis is parallel to either of the x and y display axes.
3. Apparatus according to claim 1 or 2, characterised in that the means for representing the vectors comprises first memory means (54) for storing a plurality of vector angles, and first memory addressing means (58) coupled to the first memory means (54) for addressing the plurality of vector angles.
4. Apparatus according to any of the preceding claims, characterised in that it further comprises means (50) for latching the offset angle.
5. Apparatus according to any of the preceding claims, characterised in that the means for providing first and second orthogonal signals comprises second memory means (76) responsive to the summing means for providing a A x signal representing incremental steps parallel to the x display axis, and providing a A y signal representing incremental steps parallel to the y display axis.
6. Apparatus according to claim 5, characterised in that the Δ x signal is proportional to the sine of the draw angle and the A y signal is proportional to the cosine of the draw angle.
7. Apparatus according to any of the preceding claims, characterised in that the writing means comprises cathode ray tube means (36) having a beam and x and ydeflection means for deflecting the beam along the x and y axes respectively.
8. Apparatus according to claim 7, characterised in that it further comprises first digital-to-analogue converter means (32) responsive to the first orthogonal signal and coupled to one of the x and y deflections means for providing a beam deflection signal thereto, and second digital-to-analogue converter means (44) responsive to the second orthogonal signal and coupled to the other of the x and y deflection means for providing a beam deflection signal thereto.
9. Apparatus according to claim 5, characterised in that the display means comprises a cathode ray tube means (36) having a beam providing a predetermined spot radius, and in that the square root of the sum of the A x signal squared and the Δ y signal squared is less than, or equal to the spot radius.
10. Stroke display apparatus for writing characters centred at a predetermined position, the characters comprising a series of concatenated vectors on the display face according to claim 1 characterised in that the apparatus further comprises first memory means (54) for storing a plurality of vector angles corresponding to the series of concatenated vectors, respectively, and first memory addressing means (58) coupled to the first memory (54) for addressing the plurality of vector angles.
11. Apparatus according to claim 10, characterised in that the first memory means (54) includes means for storing a plurality of vector length signals corresponding to each of the vector angles.
12. Apparatus according to claim 10 or 11, characterised in that the first memory means (54) includes means for storing a vector attribute signal corresponding to ea=h of the vector angles.
13. Apparatus according to claim 12, characterised in that the vector attributes represent blanking signals.
14. Apparatus according to any of claims 11 to 13, characterised in that it further comprises character stroke counter means (90) responsive to the vector length signals for generating a length number indicative of said pre- determined length.
15. Apparatus according to any of claims 10 to 14, characterised in that the first memory means (54) includes means for storing a last stroke flag signal indicating that the character being written is complete.
EP83303447A 1982-07-01 1983-06-15 Stroke display apparatus Expired - Lifetime EP0099645B1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US394362 1982-07-01
US06/394,362 US4553214A (en) 1982-07-01 1982-07-01 Angle based stroke generator

Publications (3)

Publication Number Publication Date
EP0099645A2 true EP0099645A2 (en) 1984-02-01
EP0099645A3 EP0099645A3 (en) 1987-07-01
EP0099645B1 EP0099645B1 (en) 1991-01-23

Family

ID=23558642

Family Applications (1)

Application Number Title Priority Date Filing Date
EP83303447A Expired - Lifetime EP0099645B1 (en) 1982-07-01 1983-06-15 Stroke display apparatus

Country Status (6)

Country Link
US (1) US4553214A (en)
EP (1) EP0099645B1 (en)
JP (1) JPS599694A (en)
DE (1) DE3382132D1 (en)
ES (1) ES8405183A1 (en)
IL (1) IL68882A0 (en)

Families Citing this family (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4736437A (en) * 1982-11-22 1988-04-05 View Engineering, Inc. High speed pattern recognizer
US4736330A (en) * 1984-09-04 1988-04-05 Capowski Joseph J Computer graphics display processor for generating dynamic refreshed vector images
US4660028A (en) * 1984-11-01 1987-04-21 Microtel Limited Stroke-vector character generator
US4658248A (en) * 1984-11-01 1987-04-14 Microtel Limited Method for generating stroke-vector characters for use in a display system
US4672370A (en) * 1984-11-01 1987-06-09 Microtel Limited Technique for scaling characters in a stroke-vector display system
US4785391A (en) * 1986-02-07 1988-11-15 Bitstream Inc. Automated bitmap character generation from outlines
US4959801A (en) * 1986-02-07 1990-09-25 Bitstream Inc. Outline-to-bitmap character generator
US4791595A (en) * 1986-07-11 1988-12-13 Tektronix, Inc. Digital vector generation with velocity correction by tabulation of counter control signals
JPS63142123A (en) * 1986-12-02 1988-06-14 Tobishima Kensetsu Kk Leveling work of rubble foundation under water
US5280577A (en) * 1988-01-19 1994-01-18 E. I. Du Pont De Nemours & Co., Inc. Character generation using graphical primitives
US5562350A (en) * 1988-04-18 1996-10-08 Canon Kabushiki Kaisha Output apparatus that selects a vector font based on character size
US5167015A (en) * 1988-06-13 1992-11-24 Industrial Technology Research Institute Line drawing method and apparatus
US5052834A (en) * 1989-04-14 1991-10-01 International Business Machines Corporation System and method of printing sideways
JPH035742U (en) * 1989-06-09 1991-01-21
US5233335A (en) * 1989-06-22 1993-08-03 Hughes Aircraft Company Symbol/raster generator for CRT display
CA2025782A1 (en) * 1989-10-16 1991-04-17 Sampo Kaasila Method for determining the optimum angle for displaying a line on raster output devices
JP2906202B2 (en) * 1993-03-31 1999-06-14 日立ソフトウエアエンジニアリング株式会社 Text and figure input method
US5664086A (en) 1993-04-16 1997-09-02 Adobe Systems Incorporated Method and apparatus for generating digital type font, and resulting fonts using generic font and descriptor file
US5899062A (en) * 1997-01-22 1999-05-04 Ford Global Technologies, Inc. Catalyst monitor using arc length ratio of pre- and post-catalyst sensor signals

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4115863A (en) * 1976-12-07 1978-09-19 Sperry Rand Corporation Digital stroke display with vector, circle and character generation capability
US4146925A (en) * 1977-08-04 1979-03-27 Smiths Industries, Inc. Graphics generator
FR2488426A1 (en) * 1980-08-05 1982-02-12 Sundstrand Data Control DIGITAL GENERATOR OF SYMBOLS WITH ERROR CONTROL
US4507656A (en) * 1982-09-13 1985-03-26 Rockwell International Corporation Character/vector controller for stroke written CRT displays

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS5121529B1 (en) * 1971-07-23 1976-07-03
US3899662A (en) * 1973-11-30 1975-08-12 Sperry Rand Corp Method and means for reducing data transmission rate in synthetically generated motion display systems
JPS5162940A (en) * 1974-11-29 1976-05-31 Kokusai Denshin Denwa Co Ltd BEKUTORUHYO JISHIKI PATAANKIROKUJOHONO HENKANHOSHIKI
US4027148A (en) * 1975-09-10 1977-05-31 Lawrence David Rosenthal Vector generator
US4205309A (en) * 1978-02-21 1980-05-27 Documation Incorporated Character generator
US4245321A (en) * 1979-02-16 1981-01-13 The United States Of America As Represented By The Secretary Of The Navy Rotating raster generator
US4228432A (en) * 1979-08-28 1980-10-14 The United States Of America As Represented By The Secretary Of The Navy Raster scan generator for plan view display
US4467412A (en) * 1981-05-18 1984-08-21 Atari, Inc. Slave processor with clock controlled by internal ROM & master processor

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4115863A (en) * 1976-12-07 1978-09-19 Sperry Rand Corporation Digital stroke display with vector, circle and character generation capability
US4146925A (en) * 1977-08-04 1979-03-27 Smiths Industries, Inc. Graphics generator
FR2488426A1 (en) * 1980-08-05 1982-02-12 Sundstrand Data Control DIGITAL GENERATOR OF SYMBOLS WITH ERROR CONTROL
US4507656A (en) * 1982-09-13 1985-03-26 Rockwell International Corporation Character/vector controller for stroke written CRT displays

Also Published As

Publication number Publication date
US4553214A (en) 1985-11-12
IL68882A0 (en) 1983-10-31
EP0099645B1 (en) 1991-01-23
JPS599694A (en) 1984-01-19
ES523456A0 (en) 1984-05-16
ES8405183A1 (en) 1984-05-16
DE3382132D1 (en) 1991-02-28
EP0099645A3 (en) 1987-07-01

Similar Documents

Publication Publication Date Title
EP0099645B1 (en) Stroke display apparatus
US4412296A (en) Graphics clipping circuit
US4532605A (en) True zoom of a displayed image
US4896275A (en) Full page graphics image display data reduction
US4245321A (en) Rotating raster generator
EP0124986B1 (en) Apparatus and method for generating multiple cursors in a raster scan display system
WO1981000022A1 (en) Ppi display for radar and synthetic symbology
CA1224290A (en) Method of storing character in a display system
EP0231060A2 (en) Fixed character string clipping in a graphics display system
US4309700A (en) Cathode ray tube controller
JPS60225190A (en) Method and apparatus for overlapping raster display and vector display
JP2761890B2 (en) Line generator and display device
JPH05204363A (en) High-speed vertical scanning-conversion and charging method and device for formation of outline character style character in dot matrix device
EP0095536B1 (en) The representation of character images in a compact form for computer storage
US4672370A (en) Technique for scaling characters in a stroke-vector display system
US3437869A (en) Display apparatus
KR900008144B1 (en) Spherical horizintal transfer method and apparatus
US5146551A (en) System for generating a circular or elliptic arc on a digital display
US4975973A (en) Image processing device suitable for obtaining the volume and center of gravity of a three-dimensional binary image
US5297244A (en) Method and system for double error antialiasing in a computer display system
EP0403126A2 (en) Anti-aliased font translation
EP0313789A1 (en) Method and apparatus for representing three-dimensional color data in a one-dimensional reference system
US5077681A (en) System for source image transformation
KR900004950B1 (en) Character interpolation control method
WO1984004832A1 (en) Vector attribute generating method and apparatus

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

Designated state(s): DE FR GB IT

PUAL Search report despatched

Free format text: ORIGINAL CODE: 0009013

AK Designated contracting states

Kind code of ref document: A3

Designated state(s): DE FR GB IT

17P Request for examination filed

Effective date: 19870806

RAP1 Party data changed (applicant data changed or rights of an application transferred)

Owner name: HONEYWELL INC.

17Q First examination report despatched

Effective date: 19891213

GRAA (expected) grant

Free format text: ORIGINAL CODE: 0009210

ITF It: translation for a ep patent filed

Owner name: BARZANO' E ZANARDO ROMA S.P.A.

AK Designated contracting states

Kind code of ref document: B1

Designated state(s): DE FR GB IT

REF Corresponds to:

Ref document number: 3382132

Country of ref document: DE

Date of ref document: 19910228

ET Fr: translation 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: DE

Payment date: 19940319

Year of fee payment: 12

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

Ref country code: DE

Effective date: 19960301

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

Ref country code: GB

Payment date: 20010502

Year of fee payment: 19

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

Ref country code: FR

Payment date: 20010531

Year of fee payment: 19

REG Reference to a national code

Ref country code: GB

Ref legal event code: IF02

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

Ref country code: GB

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20020615

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

Effective date: 20020615

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

Ref country code: FR

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20030228

REG Reference to a national code

Ref country code: FR

Ref legal event code: ST

P01 Opt-out of the competence of the unified patent court (upc) registered

Effective date: 20230525