|Publication number||US5030945 A|
|Application number||US 07/262,645|
|Publication date||Jul 9, 1991|
|Filing date||Oct 26, 1988|
|Priority date||Oct 26, 1987|
|Also published as||DE3871902D1, DE3871902T2, EP0314395A1, EP0314395B1|
|Publication number||07262645, 262645, US 5030945 A, US 5030945A, US-A-5030945, US5030945 A, US5030945A|
|Inventors||Andrew J. V. Yeomans|
|Original Assignee||Crosfield Electronics Limited|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (7), Non-Patent Citations (5), Referenced by (14), Classifications (9), Legal Events (7)|
|External Links: USPTO, USPTO Assignment, Espacenet|
The invention relates to methods and apparatus for interactively controlling the display of an image on a monitor screen.
Current image modification systems, such as our Studio 800 system, allow an operator to view an image on a monitor screen, the original image being stored in digital form. The operator is then able to modify the shape of the image and its orientation by sending appropriate commands to a controlling computer. The effect of these modifications is then displayed on the monitor screen. In the past, in order to achieve image modifications such as lateral movement across the screen of the entire image, rotation of the image, or enlargement, contraction or perspective distortion of the image it has been necessary for the operator to enter the rotation angle or scale factor either numerically or by manipulating an analogue control (sometimes simulated using a digitizing tablet), after which the computer calculates the effect on the image and displays the resultant image form.
An alternative method used in the past is to define two points on the image, after which the computer calculates the appropriate enlargement factor so that the portion of the image between these points exactly fills a predefined rectangular shape.
The disadvantages of these methods are firstly that there is a significant time between the operator indicating the type of change he requires and the computer displaying the final form of the image; and secondly it is difficult to make small adjustments to the transformation to achieve the desired result, since only one parameter (rotation, enlargement, shear, perspective) is changed at a time. Also the operation of a numerical or analogue control does not always directly correspond to the modification required.
In accordance with one aspect of the present invention, a method of interactively controlling the display of an image on a monitor screen, the image being stored in the form of digital data defining the colour content of pixels of the image comprises
i) displaying a representation of the image on the monitor screen;
ii) selecting a first point on the image and a first point on the monitor screen at which the first image point is to be located;
iii) selecting with a cursor a second point on the image;
iv) moving the cursor relative to the monitor screen;
v) and during the cursor movement repeatedly adjusting the representation of the image displayed in accordance with one or more predetermined algorithms so that the second image point remains coincident with the cursor position while the first image point is fixed at the first screen point.
In a simple operation, the first screen and image points may already be coincident so that the movement of a second image point to a new screen point will result in a simple rotation or rotation and enlargement/contraction of the image. Thus, in this case, the algorithm applied to the remaining pixels of the image will be a conventional rotation algorithm possibly combined with an enlargement or contraction algorithm.
The method may further comprise selecting with the cursor a third point on the image and moving the cursor relative to the monitor screen, and during the cursor movement repeatedly adjusting the representation of the image displayed in accordance with one or more predetermined algorithms so that the third image point remains coincident with the cursor position while the first and second image points are fixed relatively to the screen.
Thus, after two image points have been correctly positioned, the choice of a third image point and subsequent cursor movement will result in an adjustment of the remainder of the image about the two points which are now fixed. Such an adjustment might comprise an enlargement or contraction or shear of the image.
This process can be continued with further points although in general when a predetermined number of image points have been selected, the selection of a further pair of image and monitor screen points will cause the deselection of the oldest pair of image and monitor screen points.
In some cases, step (ii) will comprise selecting the first image point with the cursor, moving the cursor relative to the monitor screen, and during the cursor movement continuously adjusting the representation of the image displayed in accordance with one or more predetermined algorithms so that the first image point remains coincident with the cursor position. This corresponds to a simple displacement of the image.
Typically, in order to achieve interactive display, the image will be displayed at a relatively low resolution. For example, if the monitor screen can display a highest resolution of n×m pixels, then the initial display may be at a resolution of n/4×m/4 pixels. This process is described in more detail in EP-A-0256816.
In accordance with a second aspect of the present invention, an apparatus for interactively controlling the display of an image on a monitor screen by carrying out a method in accordance with the first aspect of the invention, the image being stored in the form of digital data defining the colour content of pixels of the image, comprises a monitor having a monitor screen; a first store for storing the digital data defining the image; processing means; operator actuable control means to enable an operator to move a cursor relative to an image displayed on the monitor screen by the processing means; and a second store for storing a digital representation of the image to be displayed on the monitor screen, the processing means being responsive to signals from the operator actuable control means to cause a modified form of the image to be stored in the second store, the modified form of the image being generated by applying one or more of the predetermined algorithms to data from the first store.
Typically, the operator actuable control means will comprise a digitizing table and a manual element for moving across the table to cause a cursor symbol to move in a corresponding manner on the monitor screen. Alternatively, the operator actuable control means could comprise a light pen or similar instrument for moving directly across the monitor screen itself.
The processing means will typically comprise a computer.
An example of a method and apparatus for interactively controlling the display of an image on a monitor screen in accordance with the present invention will now be described with reference to the accompanying drawings, in which:
FIG. 1 is a block diagram of the apparatus; and,
FIGS. 2A-2G illustrate different monitor screen displays; and,
FIG. 3 is a flow diagram illustrating operation of the apparatus.
The apparatus shown in FIG. 1 comprises a disc store 1 which holds sets of digital data defining a number of images at a relatively high resolution, in a conventional manner. Thus, for each pixel of a coloured image, there will be four sets of digital data defining the intensity of each colour component, typically cyan, magenta, yellow, and black. The digital data defining a selected image can be loaded from the disc store 1 into a smaller image store 2 under the control of a microcomputer 3. An operator controls operation of the microcomputer 3 via an indicator assembly 4 such as a digitizing table 5 and cursor member 6.
The microcomputer 3 then controls the form of the image in the image store 2 to be displayed on a monitor 7 by suitably controlling address counters in a transform generator 8 with data defining certain transform algorithms. A simple algorithm could be rotation of the image through a certain angle with the resultant rotated form of the image being stored in a transform store 9 defining a two dimensional array corresponding directly on a one to one basis with pixels in the monitor screen 10 of the monitor 7. In addition, if the original image in the store 2 is defined in terms of four printing colour components (as previously mentioned) then the transform generator 8 will also convert the information to monitor colour components, typically red, green, and blue.
In operation, the operator initially requests the microcomputer 3 to display an unmodified form 12 of the image in the image store 2 on the monitor screen 10 (step 30, FIG. 3). This is shown in FIG. 2A. The operator then moves the cursor member 6 relative to the digitizing table 5 to cause a cursor mark 11 on the screen to move relative to the displayed image 12. The operator positions the cursor mark 11 at a particular position within the image 12 and this location 12' (first image point) is communicated and stored by the microcomputer 3 (step 31). The operator then moves the cursor 11 to a different part of the monitor screen 10. During this movement the position 12" (screen point) of the cursor relative to the screen is repeatedly communicated to the microcomputer 3 (step 32). The microcomputer 3 then continuously responds to each new cursor position by determining the type of image transformation required to adjust the representation of the image relative to the monitor screen 10 so as to bring the initially defined image point 12' into coincidence with the current cursor position 12" (step 33). In this initial case, the transformation will be a simple displacement or lateral movement. The displayed image 12 will thus be scrolled downwardly as shown in FIG. 2B as the cursor is moved. This is achieved by the microcomputer 3 determining which pixels of the original image should be displayed with the current cursor position (step 34) and causing the transform generator to address that pixel data which is downloaded into the correct locations in the transform store 9 (step 35).
The microcomputer then repeats steps 32 to 35 until the operator indicates that the image point 12' is to be fixed at the current point 12" (step 36). At this stage, these fixed positions are stored by the microcomputer 3 (step 37).
With the first image and screen points fixed as indicated by reference numeral 13 in FIG. 2C, the operator selects using the cursor a second image point 14 (step 38). The cursor is then moved relative to the screen and the microcomputer 3 responds to the current cursor position 15 (FIG. 2D) by calculating the transformation which must be made to the remainder of the image to allow the second image point to be brought into coincidence with the cursor position while the initial points remain fixed at the location 13 (steps 32-33). This transformation of the image could take one of a number of forms depending on the algorithms which the microcomputer 3 is allowed to apply. For example, if a rotation algorithm is provided while differential enlargement is not allowed, then the microcomputer 3 will cause the image 12 to rotate about the point 13. This is indicated in FIG. 2D. Alternatively, if rotation is not allowed but differential enlargement is allowed, this will result in a contraction of the image 12 in the vertical direction and an enlargement of the image in the horizontal direction as shown in FIG. 2E.
During movement of the cursor, the transformed images are displayed as previously described (steps 34-35) until the next fixed screen position is indicated and stored (steps 36-37).
Assuming that the image now displayed has the form shown in FIG. 2D, there will now be two fixed pairs of image and monitor screen points 13, 16. The selection of a third point in the image (step 38) and further movement of the cursor will result in the application by the microcomputer 3 of a shear algorithm in combination with the rotation algorithm and the lateral movement algorithm to generate a further series of pixel addresses in the store 2 which the transform generator 8 accesses to produce the display shown in FIG. 2F.
Finally, the selection of a fourth image point and subsequent movement of the cursor will result in the application of the previous three algorithms in combination with a perspective distortion algorithm in which the first, second, and third image points 13, 16, 17 remain fixed relative to the monitor screen 10.
After each image/screen point pair is fixed, the total number of such pairs is compared with a threshold (step 39) e.g. 4. When the threshold is exceeded the oldest screen/image point pair is deselected (step 40) prior to selection of the next image point.
Once the final desired form of the image has been achieved, the microcomputer 3 may update the information in the image store 2 to define the image in the final form.
The transformation algorithms have a conventional form and comprise one or more simultaneous equations which need to be solved, the number of equations depending on the number of fixed image/screen point pairs. For example, when four image points (xn, yn) are to be transformed into points (xtn, ytn), the transformation equations state that
xtn =(a·xn +b·yn +c)/(g·xn +h·yn +1)
ytn =(d·xn +e·yn +f)/(g·xn +h·yn +1)
for n=1, 2, 3, 4. This gives 8 simultaneous equations of the form:
a·xn +b·yn +c-g·xn ·xtn -h·yn ·xtn -xtn =0
d·xn +e·yn +f-g·xn ·ytn -h·yn ·ytn -ytn =0
which can be solved for a, b, c, d, e, f, g, h, in the usual way.
If fewer than 4 pairs of points are defined, some other constraints must be imposed to uniquely define the transformation. Suitable constraints are as follows:
______________________________________One point: Translation onlyConstraints: b = d = g = h = 0 a = e = 1Solution: c = xt1 - x1 f = yt1 - x1Two points: (i) Rotation and uniform scaling (and translation)Constraints: g = h = 0 b = -d e = aSolution: a = [(x2 - x1)(xt2 - xt1) + (y2 - y1) (yt2 - yt1)]/[ (x2 - x1)2 + (y2 - y1)2 ] d = [(x2 - x1)(yt2 - yt1) - (y2 - y1) (xt2 - xt1)]/[ (x2 - x1)2 + (y2 - y1)2 ] c = xt1 - a.x1 + d.y1 (= xt2 - a.x2 + d.y2) f = yt1 - d.x1 - a.y1 (= yt2 - d.x2 - a.y2)Two points: (ii) Non-uniform stretch (and translation) Constraints: b = d = g = h = 0Solution: a = (xt2 - xt1)/(x2 - x1) e = (yt2 - yt1)/(y2 - y1) c = xt1 - a.x1 + d.y1 (= xt2 - a.x2 + d.y2) = (x2.xt1 - x1.xt2)/(x2 - x1) f = yt1 - d.x1 - a.y1 (= yt2 - d.x2 - a.y2) = (y2.yt1 - y1.yt2)/(y2 - y1)Three points: General affine transformationConstraints: g = h = 0Solution: By solving the six simultaneous equations given by n = 1, 2, 3: a.xn + b.yn + c - xtn = 0 d.xn + e.yn + f - ytn = 0______________________________________
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US4523188 *||Oct 25, 1982||Jun 11, 1985||The United States Of America As Represented By The Secretary Of The Army||Automated map and display alignment|
|US4701752 *||Oct 24, 1985||Oct 20, 1987||International Business Machines Corp.||Mirror inverse function in an interactive graphics system|
|US4703321 *||Sep 30, 1985||Oct 27, 1987||International Business Machines Corporation||Method for editing a graphic object in an interactive draw graphic system|
|US4710758 *||Apr 26, 1985||Dec 1, 1987||Westinghouse Electric Corp.||Automatic touch screen calibration method|
|US4755809 *||Oct 11, 1983||Jul 5, 1988||Fujitsu Limited||Method for controlling windows displayed in a card image data processing system|
|US4903012 *||Sep 24, 1987||Feb 20, 1990||Alps Electric Co., Ltd.||Coordinate system input device providing registration calibration and a mouse function|
|EP0283159A1 *||Feb 29, 1988||Sep 21, 1988||Quantel Limited||Electronic image processing|
|1||*||Appel A., et al., Interactive Graphics Trajectory Design Method, IBM Technical Disclosure Bulletin, vol. 18, No. 10, Mar. 1976.|
|2||*||Brewster Jon A., et al., A Friendly Unix Operating System User Interface, Hewlett Packard Journal, Oct. 1985.|
|3||Brewster Jon A., et al., A Friendly Unix Operating System User Interface, Hewlett-Packard Journal, Oct. 1985.|
|4||*||Gujar Uday G., et al., A Flexible Software Character Generator, Software Practice and Experience, vol. 15(2), 191 218 (Feb. 1985).|
|5||Gujar Uday G., et al., A Flexible Software Character Generator, Software--Practice and Experience, vol. 15(2), 191-218 (Feb. 1985).|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US5357603 *||Jun 15, 1992||Oct 18, 1994||Microsoft Corporation||Method and system for changing a shape type while maintaining existing graphic characteristics|
|US5396590 *||Sep 17, 1992||Mar 7, 1995||Apple Computer, Inc.||Non-modal method and apparatus for manipulating graphical objects|
|US5563720 *||Jan 11, 1995||Oct 8, 1996||International Business Machines Corporation||Expert system for image enhancement|
|US5579026 *||May 13, 1994||Nov 26, 1996||Olympus Optical Co., Ltd.||Image display apparatus of head mounted type|
|US5781165 *||Apr 19, 1996||Jul 14, 1998||Olympus Optical Co., Ltd.||Image display apparatus of head mounted type|
|US5852431 *||Apr 29, 1997||Dec 22, 1998||Nanao Corporation||Video monitor adjustment system|
|US7834893 *||Jul 24, 2007||Nov 16, 2010||Canon Kabushiki Kaisha||Mixed-reality presentation system and control method therefor|
|US7865423||Aug 3, 2006||Jan 4, 2011||Bridgetech Capital, Inc.||Systems and methods for providing investment opportunities|
|US8731327 *||Aug 25, 2011||May 20, 2014||Pentax Ricoh Imaging Company, Ltd.||Image processing system and image processing method|
|US20100060588 *||Mar 11, 2010||Microsoft Corporation||Temporally separate touch input|
|US20120057747 *||Aug 25, 2011||Mar 8, 2012||Hoya Corporation||Image processing system and image processing method|
|EP2329347A2 *||Sep 10, 2009||Jun 8, 2011||Microsoft Corporation||Temporally separate touch input|
|WO2007021876A2 *||Aug 10, 2006||Feb 22, 2007||Agontrader Inc||Systems and methods for providing investment opportunities|
|WO2010030765A2||Sep 10, 2009||Mar 18, 2010||Microsoft Corporation||Temporally separate touch input|
|International Classification||G06F3/048, G06T3/00, G06F3/033, G06T11/80|
|Cooperative Classification||G06T3/00, G06F3/04845|
|European Classification||G06F3/0484M, G06T3/00|
|May 2, 1991||AS||Assignment|
Owner name: CROSFIELD ELECTRONICS LIMITED A BRITISH COMPANY
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST.;ASSIGNOR:YEOMANS, ANDREW J. V.;REEL/FRAME:005693/0353
Effective date: 19881018
|Dec 23, 1994||FPAY||Fee payment|
Year of fee payment: 4
|Apr 27, 1998||AS||Assignment|
Owner name: FUJIFILM ELECTRONIC IMAGING LIMITED, ENGLAND
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:CROSFIELD ELECTRONICS LIMITED;REEL/FRAME:009138/0216
Effective date: 19980226
|Feb 2, 1999||REMI||Maintenance fee reminder mailed|
|Mar 29, 1999||FPAY||Fee payment|
Year of fee payment: 8
|Mar 29, 1999||SULP||Surcharge for late payment|
|Dec 20, 2002||FPAY||Fee payment|
Year of fee payment: 12