WO2009009896A1 - Method for manipulating regions of a digital image - Google Patents

Method for manipulating regions of a digital image Download PDF

Info

Publication number
WO2009009896A1
WO2009009896A1 PCT/CA2008/001311 CA2008001311W WO2009009896A1 WO 2009009896 A1 WO2009009896 A1 WO 2009009896A1 CA 2008001311 W CA2008001311 W CA 2008001311W WO 2009009896 A1 WO2009009896 A1 WO 2009009896A1
Authority
WO
WIPO (PCT)
Prior art keywords
region
processing
processing tool
tool
gesture
Prior art date
Application number
PCT/CA2008/001311
Other languages
French (fr)
Inventor
Shymmon Banerjee
Wallace Kroeker
Erik Benner
Andy Leung
Original Assignee
Smart Technologies Ulc
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 Smart Technologies Ulc filed Critical Smart Technologies Ulc
Priority to CA2693775A priority Critical patent/CA2693775C/en
Priority to AU2008278242A priority patent/AU2008278242A1/en
Priority to EP08772887A priority patent/EP2168095A4/en
Priority to NZ582553A priority patent/NZ582553A/en
Priority to CN200880025134A priority patent/CN101765860A/en
Publication of WO2009009896A1 publication Critical patent/WO2009009896A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T11/002D [Two Dimensional] image generation
    • G06T11/60Editing figures and text; Combining figures or text
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0484Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range
    • G06F3/04845Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range for image manipulation, e.g. dragging, rotation, expansion or change of colour
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0487Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser
    • G06F3/0488Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures
    • G06F3/04883Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures for inputting data by handwriting, e.g. gesture or text

Definitions

  • the present invention relates generally to image processing, and more particularly to a method and apparatus for manipulating regions of a digital image.
  • a Web page often contains several visual and functional elements, including columns of text, advertisements, images, hyperlinks, live stock quote tickers, embedded programs, and the like.
  • the image is typically manually edited prior to transmission. This is done to remove regions of the image that are not relevant to the subject-matter of the story, and/or to scale regions of the image such that they are more readable on the television screen once transmitted. For example, a newscaster may wish to draw the attention of a television audience to a particular quote on a particular Web page, but remove advertisements and other extraneous items.
  • production staff typically employ an image cropping tool that is packaged with a set of editing tools as part of an image editing application (such as Microsoft 1 M Paint, for example).
  • image manipulation image regions are manually copied from the original Web page image and pasted into a separate image for combining with other image elements.
  • image editing application such as Microsoft 1 M Paint, for example.
  • image regions are manually copied from the original Web page image and pasted into a separate image for combining with other image elements.
  • it is advantageous to identify and isolate image regions with pixel accuracy To do so typically requires that production staff sequentially select regions and employ zoom-in, zoom-out, cropping and perhaps other digital image processing tools.
  • U.S. Patent No. 6,337,925 to Cohen et al. discloses a method for determining borders of objects in a digital image in order to assist with masking of an object bound by the border.
  • a user is required to choose an area of interest of the digital image that includes a portion of a border to be identified.
  • the border portion is then modeled by estimating a position, direction and width of the edge zone of the border. Based on the modeled border portion, the border of an entire object in the scene is identified.
  • 6,593,944 to Nicolas et al. discloses a method and electronic system for modifying a Web page such that its content can be read by a user on an electronic device having a small screen.
  • the method presupposes that the Web page is divided into frames, and arranges the Web page such that the frames can be displayed individually on the small screen. Each frame is scaled to the full size of the display.
  • the commentator may employ a computer workstation directly, or some other user interface such as a touch system.
  • Touch systems are well known in the art and typically include a touch screen having a touch surface on which contacts are made using a pointer in order to generate user input.
  • the user input is then automatically conveyed to a computer executing one or more application programs.
  • the computer uses the user input to update the image being presented on the touch screen, or to perform other actions via the application programs as though they were being operated using mouse and keyboard, for example.
  • Many types of touch systems exist that utilize disparate technologies to identify contacts with the touch surface. These technologies include for example analog resistive, surface acoustic wave, capacitive, infrared, electromagnetic, laser-based and machine-vision detection arrangements to identify contacts with the touch surface.
  • the commentator In order to select a region and a processing tool (such as zoom-in, zoom- out, spotlight, highlight, or crop, as a few examples), the commentator typically preselects the processing tool application from a menu, picks up a pointer, and draws a border around the region of interest in the image displayed on the touch screen.
  • the processing tool application running on the computer, which receives the user input, performs the desired processing action on the selected image region, and updates the image presented on the touch screen.
  • the commentator may first select the region in the displayed image with the pointer and then select the desired processing tool application from a menu. Once selected, the processing tool application performs its processing action on the selected region, and the image presented on the touch screen is updated.
  • a method of dividing a digital image into regions comprising: identifying potential region borders based on edge content in the digital image; and dividing the digital image into regions based on user-selected ones of the identified potential region borders.
  • the potential region borders are identified at locations along rows and columns in the digital image that have a significant amount of edge content.
  • the identifying comprises calculating pixel intensity profiles for each row and column of pixels in the digital image. Adjacent ones of the pixel intensity profiles are compared to determine where differences between adjacent pixel intensity profiles exceed a threshold level, thereby establishing row and column positions of the potential region borders.
  • a method of processing a region of a digital image comprising: receiving gesture data for characterizing the region; automatically launching a processing tool associated with the gesture data; and processing the region using the processing tool.
  • a computer readable medium embodying a computer program for dividing a digital image into regions comprising: computer program code identifying potential region borders based on edge content in the digital image; and computer program code dividing the digital image into regions based on user-selected ones of the identified potential region borders.
  • a computer readable medium embodying a computer program for processing a region of a digital image comprising: computer program code receiving gesture data for characterizing the region; computer program code automatically launching a processing tool associated with the gesture data; and computer program code processing the region using the processing tool.
  • an interactive display system comprising: a touch screen that defines a touch surface on which a computer-generated image is presented; a sensor assembly detecting pointer contacts on the touch surface and in response, generating gesture data for characterizing a region of the computer- generated image; and processing structure receiving the gesture data and automatically launching a processing tool associated with the gesture data for processing the region.
  • the method for processing a region of a digital image is beneficial as it provides for the accurate identification and processing of image regions, particularly during live broadcasting of the images.
  • a user is able to identify both a region of interest, and the processing tool for processing the region, with a single gesture. As such, time spent by a user identifying the image region and selecting a processing tool is significantly reduced.
  • Figure 1 is a flowchart showing steps for dividing a digital image into regions
  • Figure 2 is a flowchart showing the steps performed during identification of potential region borders in the digital image
  • Figure 3 is a captured image of a Web page
  • Figure 4 is a grayscale image of the Web page of Figure 3, showing computed column and row intensity profiles
  • Figure 5 is the grayscale Web page image of Figure 4, showing thresholded column and row intensity profiles to identify locations of reference lines;
  • Figure 6 shows the identified reference lines overlaid on the captured Web page image
  • Figure 7 is a flowchart showing steps for selecting and manipulating reference lines
  • Figure 8 shows the captured Web page image of Figure 3 from a user's point of view, in which a vertical sweep tool for selecting from the identified reference lines is invoked;
  • Figure 9 shows the captured Web page image of Figure 8 after vertical and horizontal sweeps for selecting reference lines has been completed
  • Figure 10 shows the captured Web page image of Figure 8 after a subset of image regions have been discarded
  • Figure 11 shows degrees of freedom for manipulating the sizes of undiscarded image regions of the Web page image of Figure 10;
  • Figure 12 shows the undiscarded image regions of the Web page image of
  • Figure 13 is a front plan view of a touch system
  • Figure 14 is a flowchart showing steps for processing a region of a digital image using the touch system
  • Figure 15a shows a region of a digital image delineated by a generally rectangular boundary drawn on a touch surface of the touch system
  • Figure 15b shows the delineated region of the digital image of Figure 15a enlarged by application of a zoom tool associated with the drawn rectangular boundary;
  • Figure 16a shows a region of another digital image delineated by a generally circular boundary drawn on the touch surface of the touch system; and
  • Figure 16b shows the delineated region of the digital image of Figure 16a having been spotlighted by application of a spotlighting tool associated with the drawn circular boundary.
  • the methods and apparatuses may be embodied in a software application comprising computer executable instructions executed by a processing unit including but not limited to a personal computer, interactive display or touch system, a digital image or video capture device such as for example a digital camera, camcorder or electronic device with video capabilities, or other computing system environment.
  • the software application may run as a stand-alone digital image tool, an embedded function or may be incorporated into other available digital image applications to provide enhanced functionality to those digital image applications.
  • the software application may comprise program modules including routines, programs, object components, data structures etc.
  • the computer readable medium is any data storage device that can store data, which can thereafter be read by a computer system. Examples of computer readable media include for example read-only memory, random-access memory, CD- ROMs, magnetic tape and optical data storage devices.
  • the computer readable program code can also be distributed over a network including coupled computer systems so that the computer readable program code is stored and executed in a distributed fashion. Embodiments will now be described with reference to Figures 1 to 15.
  • the digital image is captured (step 100) as a computer screenshot or using an image capture device (such as a digital camera, for example). Potential or candidate region borders within the digital image are then identified as reference lines (step 200), and user selected reference lines are determined (step 300). Based on the selected reference lines, the captured image is divided into regions (step 400) for further manipulation by the user.
  • a grayscale image is created by extracting the pixel luminance channel from the captured image (step 210).
  • Intensity profiles are then computed for each row and column of the grayscale image (step 212).
  • the luminance values of the pixels in each row of the grayscale image are averaged thereby yielding, for each row, an intensity profile that is the average luminance of all pixels in the row. The same is performed for the columns of the grayscale image.
  • the intensity profiles for the rows are thresholded to identify the locations of significant horizontal edges in the grayscale image, as set forth in the following pseudo code:
  • a fixed threshold value of 0.125 intensity units has been found to be suitable.
  • An adaptive threshold value or one obtained based on a measurement of intensity volatility in the grayscale image i.e. standard deviation of intensity, for example may of course be employed.
  • Figures 3 to 6 show processing of a Web page image according to the steps described above. More particularly, Figure 3 shows a captured Web page image as it would appear to a user.
  • Figure 4 shows the corresponding grayscale image and the computed column and row intensity profiles.
  • Figure 5 illustrates the column and row intensity profiles of the grayscale image having been thresholded to identify the vertical and horizontal reference lines.
  • Figure 6 shows the reference lines overlaid on the captured Web page image. It will be understood that, while the reference lines are visible in Figure 6, this is for ease of understanding. As will be described in further detail below, according to this embodiment it is not necessary at this point for users to see them displayed onscreen simultaneously.
  • a vertical sweep tool is invoked. Once invoked, the user begins a left-to-right sweep of the captured image with the pointer (step 310). During the left-to-right sweep, the vertical reference lines are made visible to the user as they are "encountered” by the pointer (step 312). More particularly, a vertical reference line appears on the display when the x-position of the pointer is determined to match or at least be within a predetermined distance of the x- coordinate of that vertical reference line.
  • the vertical reference line remains visible as the user continues to sweep the pointer past the x-coordinate of the vertical reference line and disappears when the actual x-coordinate of the pointer exceeds the vertical reference line x-coordinate by a threshold amount (i.e. 10 pixels, for example).
  • a threshold amount i.e. 10 pixels, for example.
  • the display includes a pointer icon (i.e., an arrow)
  • the arrow "sticks" to the vertical reference line. This "sticking" effect also assists the user with identifying and selecting the vertical reference line. If a visible reference line is to be selected, the user simply needs to temporarily halt the sweep and click the mouse button to select the vertical reference line that has been made temporarily visible.
  • the vertical reference line is toggled "ON" and remains permanently visible, despite the pointer's position (step 316). If the user desires to continue the left-to-right sweep to select additional vertical reference lines (step 318), then the method continues from step 312. While the vertical sweep tool is selected, the user is able to go back and re- sweep to select further vertical reference lines that had previously been missed. [0051] In order to view and select horizontal reference lines, the user invokes a horizontal sweep tool and begins a top-to-bottom sweep of the captured image with the pointer (step 320) to encounter and select from horizontal reference lines.
  • each selected horizontal reference line is toggled "ON" and remains visible, despite the pointer's position. While the horizontal sweep tool is selected, the user is able to go back and re-sweep to select further horizontal references lines that had previously been missed. [0052] Should the user desire, a selected reference line can be deselected and thereby toggled "OFF" to render it invisible again.
  • the captured image is divided into a grid of regions, delineated by the selected reference lines (step 330).
  • the user can then adjust the selected reference lines to fine-tune their positions as desired (step 332). For example, one of the horizontal reference lines in Figure 6 runs through the Headline "Microsoft Releases Windows CE 6 beta". If this horizontal reference line, once selected, were not adjusted, the Headline would be undesirably cropped. Thus, the user adjusts the selected reference line as if resizing a tiled window.
  • Figures 9 to 12 show the selected reference line having been adjusted to ensure that the Headline is not undesirably cropped.
  • the reference lines are divided automatically into segments based on intersection points of horizontal and vertical reference lines, and the user can selectively adjust individual segments of the reference lines thereby to adjust the borders of individual image regions.
  • the user can select individual image regions for further manipulation. For example, the user may wish to discard some image regions and reposition and/or resize other image regions. An image region may be discarded by selecting the image region using the pointer and pressing the "delete" key on a keyboard, for example. Once selected image regions have been discarded, size adjustment of the remaining image regions can be performed by selecting with a pointer a horizontal or vertical region border and dragging it using the pointer through empty space (i.e.
  • the "snapping" functionality is facilitated by detecting when the x-coordinate of the selected image region border while being dragged becomes equal to or greater than the x-coordinate of the facing image region border of the next undiscarded image region. Upon release the x-coordinate of the selected image region border is re-set to be equal to the x-coordinate of the facing image region border.
  • the aligned borders themselves may be merged as a single border such that adjustment of the single border enlarges one of the two adjacent image regions and diminishes the other.
  • Figures 8 to 12 show processing of the captured Web page of Figure 3 according to the above steps when a user selects from the set of reference lines to identify image regions. More particularly, Figure 8 shows the Web page image from a user's point of view, in which the vertical sweep tool for selecting reference lines has been invoked. Figure 9 shows the Web page image after vertical and horizontal sweeps for selecting reference lines is complete. Figure 10 shows the Web page image after a user has discarded a subset of the image regions. Figure 11 shows undiscarded image regions of the Web page image of Figure 10 being manipulated thereby to adjust their respective sizes.
  • Figure 12 shows the undiscarded image regions of the Web page image of Figure 10 having been manipulated as described above to form a complete, simplified - 1 7 -
  • touch system 50 includes a touch screen 52 having a touch surface 54 defining a region of interest on which pointer contacts are to be made using pointer 70.
  • pointer 70 has a body 72 and a tip 74
  • the touch screen 52 is the generally planar surface of a flat panel display device such as for example an LCD, plasma, HDTV or other television display device.
  • a sensor assembly 56 extends along one side of the touch screen 52.
  • the sensor assembly 56 includes a valence 58 secured to one side edge of the touch screen 52.
  • Digital cameras 60 are positioned adjacent opposite ends of the valence 58. The fields of view of the digital cameras 60 overlap over the entire active area of the touch surface 54 so that pointer contacts made on the touch surface 54 can be visually detected.
  • An infrared (IR) receiver 62 is positioned adjacent to and communicates with an associated digital camera 60.
  • Each IR receiver 62 is similar to those found on consumer electronics and comprises a lensed IR detector coupled to a gain controlled amplifier.
  • the digital cameras 60 are coupled to a computer 64 or other suitable processing device via a USB hub 65 and high speed data bus 66 such as for example USB-2.
  • Computer 64 includes memory and a processor that executes one or more application programs and provides display output that is made visible on the touch screen 52.
  • the touch screen 52, computer 64 and display device form a closed-loop so that pointer contacts with the touch screen 52 can be recorded as writing or drawing, and/or as gestures used to control execution of application programs executed by the computer 64.
  • Figure 14 is a flowchart showing steps for selecting and processing an identified region of a digital image during a live television broadcast with the touch system of Figure 13.
  • a software-accessible processing tool table or tables associating shapes of gestures with processing tools is stored in memory of computer 64 (step 600).
  • An example of the conceptual contents of the processing tool table is shown in Table 1 below.
  • an elliptical-shaped gesture is associated with a "Spotlight” processing tool that brightens an identified region relative to its surroundings.
  • a rectangular-shaped gesture is associated with a "Zoom” processing tool.
  • gesture data is received by computer 64 (step 700), and gesture ink is displayed on the display device in a known manner based on the received gesture data.
  • the gesture data is a set of sampled coordinates based on pointer contacts that in combination form a closed figure such as an ellipse, a rectangle, a triangle etc. Individual sampled coordinates are considered part of a set if together received while the pointer remains in contact with the touch surface 54. Other similar criteria may be used.
  • the gesture data directly characterizes the identified region because it defines the shape, size and position of the region.
  • the shape of the gesture is determined (step 800) by the computer 64 using a shape recognition algorithm.
  • the gesture shape as described above, is considered a closed figure (i.e. one of a rectangle, ellipse, triangle etc.).
  • Error handling algorithms may be employed by computer 64 to handle cases in which the gesture data cannot reasonably be considered to define a closed figure (i.e. a straight or only slightly curved line).
  • Other pre-processing algorithms may be employed by computer 64 to handle cases in which the gesture data, while not inherently defining a closed figure, may reasonably be considered to represent a closed figure. For example, a "C" shape or swirl may each be considered as imprecisely-drawn ellipses.
  • the shape recognition algorithm it is advantageous, from a user's perspective, for the shape recognition algorithm to be robust so as to handle such partially-closed figures.
  • the pre-processing algorithms process the set of sampled points and perhaps add additional points to the set to result in a closed figure that completely encloses the region being delineated.
  • Shape recognition algorithms are known in the art, and include those that compare the characteristics of a set of sampled coordinates to predefined characteristics respectively defining shapes or shape templates. For example, if a set of coordinates is a 93% match with a given shape template but only a 22% match with another shape template, then the shape template with the 93% match is chosen as the matching gesture template, thereby to determine the gesture shape.
  • the original gesture ink on the display device is removed and replaced with gesture ink corresponding to the determined gesture shape scaled and positioned so as to correspond to the size and position of the user's original gesture.
  • the size and position of the gesture are determined by processing the set of sampled points using geometrical analysis to determine a center of the gesture and its boundaries.
  • the gesture shape is then used by the computer 64 as a key into the index of the processing tool table to identify the associated processing tool.
  • Table 1 for example, should the gesture shape be determined to be an ellipse "O", the Spotlight processing tool is identified.
  • processing tool input arguments may include the gesture data itself, or the determined gesture shape with corresponding size and position information.
  • processing may occur automatically, or alternatively an option given to the user to specify further the nature of the processing. For example, if the processing tool is a zoom tool, the user is given the option of zooming in, zooming out, or doing nothing. Furthermore, the user is able to translate the zoom tool so as to process a region having the same shape and size as was drawn but at a different position.
  • the processing tool is closed or otherwise de-activated by clicking the mouse or contacting the touch surface 54 outside of the region delineated by the gesture ink.
  • a region 82 of a digital image 80 delineated by a generally rectangular boundary drawn using the touch system 50 is shown in Figure 15a.
  • the identified region 82 of digital image 80 enlarged by application of a zoom processing tool associated with the gestured rectangular boundary is shown in Figure 15b.
  • the original gesture ink of Figure 15a is automatically removed and, as shown in Figure 15b, is replaced with gesture ink identifying the bounds of the rectangular region 82 that was enlarged by the zoom processing tool.
  • FIG. 16a A region 92 of different digital image 90 delineated by a circular/elliptical boundary drawn by a user using the touch system 50 is shown in Figure 16a.
  • the identified region 92 of digital image 90 spotlighted by application of a spotlighting tool associated with the gestured circular/elliptical boundary is shown in Figure 16b.
  • the original gesture ink of Figure 16a is automatically removed and, as shown in Figure 16b, is replaced with gesture ink identifying the bounds of the circular/elliptical region 92 that was spotlighted by the spotlighting processing tool.
  • gesture shapes stored in the processing tool table previously described are those shapes that serve to directly characterize a region (i.e., clearly identify its size, shape and position), or can be reasonably assumed by implementing software to clearly characterize the region.
  • an ellipse inherently encloses a region thereby fully characterizing the region, whereas a "C" shape does not inherently characterize a region but may be considered by the implementing software to be a similarly-sized ellipse that has been incompletely drawn.
  • the implementing software would then consider the ' 1 C" shape to characterize a region that would have been enclosed by a similarly-sized ellipse, and the "C" and ellipse would, for the purpose of processing tool selection, be the same gesture and therefore result in selection of the same processing tool.
  • the processing tool table is configured such that both a "C” and an ellipse "O", while characterizing the same region (in terms of shape, size and position), respectively cause the selection of a different processing tool for processing the region. For example, drawing a "C” shape causes an elliptical region to be spotlighted, whereas drawing an actual ellipse "O" causes the elliptical region to be cropped. Other gestures that do not directly characterize regions, but can be respectively associated with a closed figure and specify its size and position, are supported.
  • a "+" sign gesture in this embodiment characterizes a similarly-sized rectangular region as would an actual rectangular gesture surrounding the region, but causes the selection of a different processing tool than the drawing of a rectangle.
  • the "+" sign gesture could alternatively characterize a similarly-sized elliptical region. Therefore, it can be seen that the shape, size and position of a particular region may be characterized using several different gesture shapes, whereby the actual gesture shape is the key into the index of the processing tool table.
  • Table 2 An example of the conceptual contents of such an alternative processing table is shown in Table 2 below.
  • Table 2 [0073] According to the contents of Table 2, if a "+” is drawn by a user, it signifies that an "O", or elliptical-shaped region corresponding in size and position to the drawn ⁇ '+” is to be processed using the Crop processing tool. However, if an "O” is drawn by the user, it signifies that the same elliptical-shaped region corresponding in size and position to the drawn "O” is to be processed, but this time using the Zoom in/out processing tool.
  • gesture shapes drawn using dashed lines invoke a different processing tool than gesture shapes of the same size and position drawn using a solid line.
  • An example of the conceptual contents of such an alternative processing table is shown in Table 3 below.
  • the dashed lines differentiate between region shapes, size and position but invoke the same tool.
  • a dashed "+” is used to identify a circle and a cropping processing action
  • a solid "+” is used to identify a square and the cropping processing action.
  • the determined gesture shape can be dependent on the orientation of the sampled points.
  • a special gesture pen may be used for drawing gesture shapes on the touch screen and launching corresponding processing tools/applications, whereas other pens are used simply for drawing.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Image Processing (AREA)
  • User Interface Of Digital Computer (AREA)

Abstract

A method for dividing a digital image into regions comprises identifying potential region borders based on edge content in the digital image. The digital image is divided into regions based on user-selected ones of the potential region borders. A method of processing a region of a digital image comprises receiving gesture data for characterizing the region. A processing tool associated with the gesture data is automatically launched, and the region is processed using the processing tool.

Description

METHOD FOR MANIPULATING REGIONS OF A DIGITAL IMAGE
Field of the Invention
[0001] The present invention relates generally to image processing, and more particularly to a method and apparatus for manipulating regions of a digital image. Background of The Invention
[0002] In a newsroom or other broadcast environment, it is often desirable to transmit digital images taken from a variety of sources as part of a newscast, a sportscast, or for advertising. It is increasingly common for such transmitted digital images to include World Wide Web (WWW) pages or portions thereof that have been screen captured from the Internet using a personal computer, computer workstation or the like.
[0003] As is well known, a Web page often contains several visual and functional elements, including columns of text, advertisements, images, hyperlinks, live stock quote tickers, embedded programs, and the like. In the case where it is desired to broadcast a screen-captured image of a Web page for display on television screens, the image is typically manually edited prior to transmission. This is done to remove regions of the image that are not relevant to the subject-matter of the story, and/or to scale regions of the image such that they are more readable on the television screen once transmitted. For example, a newscaster may wish to draw the attention of a television audience to a particular quote on a particular Web page, but remove advertisements and other extraneous items.
[0004] It can be time-consuming to manually identify, isolate and manipulate regions in an image of a Web page. For this purpose, production staff typically employ an image cropping tool that is packaged with a set of editing tools as part of an image editing application (such as Microsoft1 M Paint, for example). During image manipulation, image regions are manually copied from the original Web page image and pasted into a separate image for combining with other image elements. In order to ensure that the final image is attractive and useful, it is advantageous to identify and isolate image regions with pixel accuracy. To do so typically requires that production staff sequentially select regions and employ zoom-in, zoom-out, cropping and perhaps other digital image processing tools. Careful control of the pointer (i.e., mouse, stylus etc.) to identify the bounds of each selected image region in the digital image is required. [0005] Techniques to crop images have been considered. For example, U.S. Patent No. 6,337,925 to Cohen et al. discloses a method for determining borders of objects in a digital image in order to assist with masking of an object bound by the border. A user is required to choose an area of interest of the digital image that includes a portion of a border to be identified. The border portion is then modeled by estimating a position, direction and width of the edge zone of the border. Based on the modeled border portion, the border of an entire object in the scene is identified. [0006] U.S. Patent No. 6,593,944 to Nicolas et al. discloses a method and electronic system for modifying a Web page such that its content can be read by a user on an electronic device having a small screen. The method presupposes that the Web page is divided into frames, and arranges the Web page such that the frames can be displayed individually on the small screen. Each frame is scaled to the full size of the display.
[0007] Although manipulating digital images prior to transmission is often required as described above, in some instances it is also desired to manipulate broadcasted images. For example, during a live television broadcast, it is often desirable to have images available to the commentator for real-time display and further manipulation. In order to provide emphasis during a newscast, a commentator may wish to spotlight an image region that includes a popular quote. As another example, during a sportscast a commentator may wish to encircle an image region showing a goal being scored in a hockey game, then zoom in on the region to show the puck crossing the goal line.
[0008] In order to achieve real-time digital image processing, the commentator may employ a computer workstation directly, or some other user interface such as a touch system. Touch systems are well known in the art and typically include a touch screen having a touch surface on which contacts are made using a pointer in order to generate user input. The user input is then automatically conveyed to a computer executing one or more application programs. The computer uses the user input to update the image being presented on the touch screen, or to perform other actions via the application programs as though they were being operated using mouse and keyboard, for example. Many types of touch systems exist that utilize disparate technologies to identify contacts with the touch surface. These technologies include for example analog resistive, surface acoustic wave, capacitive, infrared, electromagnetic, laser-based and machine-vision detection arrangements to identify contacts with the touch surface.
[0009] In order to select a region and a processing tool (such as zoom-in, zoom- out, spotlight, highlight, or crop, as a few examples), the commentator typically preselects the processing tool application from a menu, picks up a pointer, and draws a border around the region of interest in the image displayed on the touch screen. The processing tool application running on the computer, which receives the user input, performs the desired processing action on the selected image region, and updates the image presented on the touch screen. Alternatively, the commentator may first select the region in the displayed image with the pointer and then select the desired processing tool application from a menu. Once selected, the processing tool application performs its processing action on the selected region, and the image presented on the touch screen is updated.
[0010] The manual selection of processing tools and identification of image regions can be time-consuming, particularly in the context of a live broadcast. This concern is addressed somewhat by application programs that permit users to first identify an image region and then select particular image processing tools using specific pointer gestures (such as an up-right motion indicating zoom, and a right-left motion indicating highlight). Other applications require receipt of a particular sequence of pointer gestures to perform various functions. For example, the video game Black & White, (developed by Lionhead Studios and published by Electronic Arts and Feral Interactive), allows players to cast spells and perform miracles by forming shapes using a sequence of mouse movements. The Web browser Opera enables a user to perform browsing gestures, as opposed to image processing operations, using small, quick mouse movements.
[0011] It is known to assign a different processing tool application to each of a set of pointers. With such an approach, the processing tool application associated with the selected pointer is automatically invoked when input is generated using that pointer. For example, a user may use a zoom pointer to identify an image region upon which zoom processing is to be conducted. [0012] Although techniques to manipulate images prior to and after transmission are known as described above, improvements are desired. It is therefore an object of the present invention to provide a novel method and apparatus for dividing a digital image into regions for individual manipulation and for performing an image processing operation on a region in a digital image.
Summary of the Invention
[0013] In accordance with one aspect, there is provided a method of dividing a digital image into regions, comprising: identifying potential region borders based on edge content in the digital image; and dividing the digital image into regions based on user-selected ones of the identified potential region borders.
[0014] In one embodiment, the potential region borders are identified at locations along rows and columns in the digital image that have a significant amount of edge content. The identifying comprises calculating pixel intensity profiles for each row and column of pixels in the digital image. Adjacent ones of the pixel intensity profiles are compared to determine where differences between adjacent pixel intensity profiles exceed a threshold level, thereby establishing row and column positions of the potential region borders.
[0015] In accordance with another aspect, there is provided a method of processing a region of a digital image, comprising: receiving gesture data for characterizing the region; automatically launching a processing tool associated with the gesture data; and processing the region using the processing tool.
[0016] In accordance with another aspect, there is provided a computer readable medium embodying a computer program for dividing a digital image into regions, the computer program comprising: computer program code identifying potential region borders based on edge content in the digital image; and computer program code dividing the digital image into regions based on user-selected ones of the identified potential region borders. [0017] In accordance with yet another aspect, there is provided a computer readable medium embodying a computer program for processing a region of a digital image, the computer program comprising: computer program code receiving gesture data for characterizing the region; computer program code automatically launching a processing tool associated with the gesture data; and computer program code processing the region using the processing tool. [0018] In accordance with another aspect, there is provided an interactive display system comprising: a touch screen that defines a touch surface on which a computer-generated image is presented; a sensor assembly detecting pointer contacts on the touch surface and in response, generating gesture data for characterizing a region of the computer- generated image; and processing structure receiving the gesture data and automatically launching a processing tool associated with the gesture data for processing the region. [0019] The above method for dividing a digital image into regions is beneficial as it provides for the accurate identification and manipulation of image regions during editing of the digital image. A user is able to select from pre-defined region borders to divide the image into regions and is thereby not necessarily required to laboriously define the image regions manually. As such, time spent by a user defining image regions and editing the image using the image regions, particularly for digital images having certain types of content (i.e. Web pages), is significantly reduced. [0020] The method for processing a region of a digital image is beneficial as it provides for the accurate identification and processing of image regions, particularly during live broadcasting of the images. A user is able to identify both a region of interest, and the processing tool for processing the region, with a single gesture. As such, time spent by a user identifying the image region and selecting a processing tool is significantly reduced. Brief Description of the Drawings
[0021] Embodiments will now be described more fully with reference to the accompanying drawings, in which: [0022] Figure 1 is a flowchart showing steps for dividing a digital image into regions;
[0023] Figure 2 is a flowchart showing the steps performed during identification of potential region borders in the digital image;
[0024] Figure 3 is a captured image of a Web page;
[0025] Figure 4 is a grayscale image of the Web page of Figure 3, showing computed column and row intensity profiles;
[0026] Figure 5 is the grayscale Web page image of Figure 4, showing thresholded column and row intensity profiles to identify locations of reference lines;
[0027] Figure 6 shows the identified reference lines overlaid on the captured Web page image;
[0028] Figure 7 is a flowchart showing steps for selecting and manipulating reference lines;
[0029] Figure 8 shows the captured Web page image of Figure 3 from a user's point of view, in which a vertical sweep tool for selecting from the identified reference lines is invoked;
[0030] Figure 9 shows the captured Web page image of Figure 8 after vertical and horizontal sweeps for selecting reference lines has been completed;
[0031] Figure 10 shows the captured Web page image of Figure 8 after a subset of image regions have been discarded;
[0032] Figure 11 shows degrees of freedom for manipulating the sizes of undiscarded image regions of the Web page image of Figure 10;
[0033] Figure 12 shows the undiscarded image regions of the Web page image of
Figure 10 having been manipulated to form a complete, simplified Web page image;
[0034] Figure 13 is a front plan view of a touch system;
[0035] Figure 14 is a flowchart showing steps for processing a region of a digital image using the touch system;
[0036] Figure 15a shows a region of a digital image delineated by a generally rectangular boundary drawn on a touch surface of the touch system;
[0037] Figure 15b shows the delineated region of the digital image of Figure 15a enlarged by application of a zoom tool associated with the drawn rectangular boundary; [0038] Figure 16a shows a region of another digital image delineated by a generally circular boundary drawn on the touch surface of the touch system; and [0039] Figure 16b shows the delineated region of the digital image of Figure 16a having been spotlighted by application of a spotlighting tool associated with the drawn circular boundary. Detailed Description of the Embodiments
[0040] In the following description, methods, apparatuses and computer readable media embodying computer programs for dividing a digital image into regions and processing a region of a digital image are disclosed. The methods and apparatuses may be embodied in a software application comprising computer executable instructions executed by a processing unit including but not limited to a personal computer, interactive display or touch system, a digital image or video capture device such as for example a digital camera, camcorder or electronic device with video capabilities, or other computing system environment. The software application may run as a stand-alone digital image tool, an embedded function or may be incorporated into other available digital image applications to provide enhanced functionality to those digital image applications. The software application may comprise program modules including routines, programs, object components, data structures etc. and may be embodied as computer readable program code stored on a computer readable medium. The computer readable medium is any data storage device that can store data, which can thereafter be read by a computer system. Examples of computer readable media include for example read-only memory, random-access memory, CD- ROMs, magnetic tape and optical data storage devices. The computer readable program code can also be distributed over a network including coupled computer systems so that the computer readable program code is stored and executed in a distributed fashion. Embodiments will now be described with reference to Figures 1 to 15.
[0041] Turning now to Figure 1, a method of dividing a digital image into regions is shown. During the method, the digital image is captured (step 100) as a computer screenshot or using an image capture device (such as a digital camera, for example). Potential or candidate region borders within the digital image are then identified as reference lines (step 200), and user selected reference lines are determined (step 300). Based on the selected reference lines, the captured image is divided into regions (step 400) for further manipulation by the user.
[0042] The steps for identifying potential region borders (step 200) are shown in Figure 2. First, a grayscale image is created by extracting the pixel luminance channel from the captured image (step 210). Intensity profiles are then computed for each row and column of the grayscale image (step 212). During computation of the intensity profiles, the luminance values of the pixels in each row of the grayscale image are averaged thereby yielding, for each row, an intensity profile that is the average luminance of all pixels in the row. The same is performed for the columns of the grayscale image.
[0043] After computation of the intensity profiles, the intensity profiles for the rows are thresholded to identify the locations of significant horizontal edges in the grayscale image, as set forth in the following pseudo code:
If I IntensityProfile(row (i-1 )) - Intensity Profile(row(i)) | >= Threshold IntensityProfile(row(i)) — 1
Else
IntensityProfile(row(i)) = 0
End If
[0044] A fixed threshold value of 0.125 intensity units has been found to be suitable. An adaptive threshold value or one obtained based on a measurement of intensity volatility in the grayscale image (i.e. standard deviation of intensity, for example) may of course be employed.
[0045] The intensity profiles for the columns are then thresholded in a manner similar to that described above for the rows.
[0046] With the intensity profiles thresholded, the positions of intensity profiles having a designation of "1" correspond to positions of region borders or reference lines in the captured image. Accordingly, horizontal reference lines are identified in the captured image at rows having an intensity profile = 1 (step 214), and vertical reference lines are identified in the captured image at columns having an intensity profile=l (step 216). Each horizontal reference line spans the entire width of the captured image, and each vertical reference line spans the entire height of the captured image. [0047] Figures 3 to 6 show processing of a Web page image according to the steps described above. More particularly, Figure 3 shows a captured Web page image as it would appear to a user. Figure 4 shows the corresponding grayscale image and the computed column and row intensity profiles. It will be understood that, while intensity profiles are visible in Figure 4, this is for ease of understanding. It is not necessary for the intensity profiles to be displayed. Figure 5 illustrates the column and row intensity profiles of the grayscale image having been thresholded to identify the vertical and horizontal reference lines. Figure 6 shows the reference lines overlaid on the captured Web page image. It will be understood that, while the reference lines are visible in Figure 6, this is for ease of understanding. As will be described in further detail below, according to this embodiment it is not necessary at this point for users to see them displayed onscreen simultaneously.
[0048] With the horizontal and vertical reference lines identified, the user is able to select reference lines in order to divide the captured image into regions for individual manipulation (step 300). The steps performed during reference line selection are shown in Figure 7, as described below.
[0049] In order to view and select vertical reference lines, a vertical sweep tool is invoked. Once invoked, the user begins a left-to-right sweep of the captured image with the pointer (step 310). During the left-to-right sweep, the vertical reference lines are made visible to the user as they are "encountered" by the pointer (step 312). More particularly, a vertical reference line appears on the display when the x-position of the pointer is determined to match or at least be within a predetermined distance of the x- coordinate of that vertical reference line. The vertical reference line remains visible as the user continues to sweep the pointer past the x-coordinate of the vertical reference line and disappears when the actual x-coordinate of the pointer exceeds the vertical reference line x-coordinate by a threshold amount (i.e. 10 pixels, for example). This facility eases selection by the user of the vertical reference line. Furthermore, where the display includes a pointer icon (i.e., an arrow), the arrow "sticks" to the vertical reference line. This "sticking" effect also assists the user with identifying and selecting the vertical reference line. If a visible reference line is to be selected, the user simply needs to temporarily halt the sweep and click the mouse button to select the vertical reference line that has been made temporarily visible. [0050] After the user selects the vertical reference line (step 314), the vertical reference line is toggled "ON" and remains permanently visible, despite the pointer's position (step 316). If the user desires to continue the left-to-right sweep to select additional vertical reference lines (step 318), then the method continues from step 312. While the vertical sweep tool is selected, the user is able to go back and re- sweep to select further vertical reference lines that had previously been missed. [0051] In order to view and select horizontal reference lines, the user invokes a horizontal sweep tool and begins a top-to-bottom sweep of the captured image with the pointer (step 320) to encounter and select from horizontal reference lines. The top-to-bottom sweep and selection of horizontal reference lines is conducted in a similar manner to that described above with respect to vertical reference lines. Once the user has completed the top-to-bottom sweep, each selected horizontal reference line is toggled "ON" and remains visible, despite the pointer's position. While the horizontal sweep tool is selected, the user is able to go back and re-sweep to select further horizontal references lines that had previously been missed. [0052] Should the user desire, a selected reference line can be deselected and thereby toggled "OFF" to render it invisible again.
[0053] Once the horizontal and vertical reference lines have been selected, the captured image is divided into a grid of regions, delineated by the selected reference lines (step 330). The user can then adjust the selected reference lines to fine-tune their positions as desired (step 332). For example, one of the horizontal reference lines in Figure 6 runs through the Headline "Microsoft Releases Windows CE 6 beta". If this horizontal reference line, once selected, were not adjusted, the Headline would be undesirably cropped. Thus, the user adjusts the selected reference line as if resizing a tiled window. Figures 9 to 12 show the selected reference line having been adjusted to ensure that the Headline is not undesirably cropped. The reference lines are divided automatically into segments based on intersection points of horizontal and vertical reference lines, and the user can selectively adjust individual segments of the reference lines thereby to adjust the borders of individual image regions. [0054] Once the captured image has been divided into the desired image regions by the adjusted reference lines, the user can select individual image regions for further manipulation. For example, the user may wish to discard some image regions and reposition and/or resize other image regions. An image region may be discarded by selecting the image region using the pointer and pressing the "delete" key on a keyboard, for example. Once selected image regions have been discarded, size adjustment of the remaining image regions can be performed by selecting with a pointer a horizontal or vertical region border and dragging it using the pointer through empty space (i.e. where discarded image regions were once positioned) to the closest border of the next undiscarded image region. If the selected border is dragged so as to overlap the next undiscarded image region, it is "snapped" into alignment with the closest border of that undiscarded image region. As such, the image region is made to neatly align with the next undiscarded image region. For vertical image region borders, the "snapping" functionality is facilitated by detecting when the x-coordinate of the selected image region border while being dragged becomes equal to or greater than the x-coordinate of the facing image region border of the next undiscarded image region. Upon release the x-coordinate of the selected image region border is re-set to be equal to the x-coordinate of the facing image region border. The same is done with horizontal borders by detecting and re-setting y-coordinates in a similar manner. [0055] Upon "snapping" of the selected image region border into alignment with the closest border, the now-adjacent image regions may, as desired, be merged as a single region. Alternatively, the aligned borders themselves may be merged as a single border such that adjustment of the single border enlarges one of the two adjacent image regions and diminishes the other.
[0056] Figures 8 to 12 show processing of the captured Web page of Figure 3 according to the above steps when a user selects from the set of reference lines to identify image regions. More particularly, Figure 8 shows the Web page image from a user's point of view, in which the vertical sweep tool for selecting reference lines has been invoked. Figure 9 shows the Web page image after vertical and horizontal sweeps for selecting reference lines is complete. Figure 10 shows the Web page image after a user has discarded a subset of the image regions. Figure 11 shows undiscarded image regions of the Web page image of Figure 10 being manipulated thereby to adjust their respective sizes.
[0057] Figure 12 shows the undiscarded image regions of the Web page image of Figure 10 having been manipulated as described above to form a complete, simplified - 1 7 -
Web page image suitable for broadcasting.
[0058] Although manipulating digital images prior to transmission is often required as described above, in some instances it is also desired to spotlight, zoom-in on, or otherwise manipulate regions of digital images during, for example, a live television broadcast. Manipulation of a digital image during a live television broadcast may be performed using an interactive display, or touch system 50 such as that shown in Figure 13. The touch system is similar to that described in United States Patent Application Serial No. 11/331 ,448, assigned to SMART Technologies Inc., assignee of the subject application, the content of which is incorporated herein by reference in its entirety. As can be seen, touch system 50 includes a touch screen 52 having a touch surface 54 defining a region of interest on which pointer contacts are to be made using pointer 70. In this embodiment, pointer 70 has a body 72 and a tip 74, and the touch screen 52 is the generally planar surface of a flat panel display device such as for example an LCD, plasma, HDTV or other television display device. A sensor assembly 56 extends along one side of the touch screen 52. The sensor assembly 56 includes a valence 58 secured to one side edge of the touch screen 52. Digital cameras 60 are positioned adjacent opposite ends of the valence 58. The fields of view of the digital cameras 60 overlap over the entire active area of the touch surface 54 so that pointer contacts made on the touch surface 54 can be visually detected.
[0059] An infrared (IR) receiver 62 is positioned adjacent to and communicates with an associated digital camera 60. Each IR receiver 62 is similar to those found on consumer electronics and comprises a lensed IR detector coupled to a gain controlled amplifier. The digital cameras 60 are coupled to a computer 64 or other suitable processing device via a USB hub 65 and high speed data bus 66 such as for example USB-2. Computer 64 includes memory and a processor that executes one or more application programs and provides display output that is made visible on the touch screen 52. The touch screen 52, computer 64 and display device form a closed-loop so that pointer contacts with the touch screen 52 can be recorded as writing or drawing, and/or as gestures used to control execution of application programs executed by the computer 64. [0060] Figure 14 is a flowchart showing steps for selecting and processing an identified region of a digital image during a live television broadcast with the touch system of Figure 13. A software-accessible processing tool table or tables associating shapes of gestures with processing tools is stored in memory of computer 64 (step 600). An example of the conceptual contents of the processing tool table is shown in Table 1 below.
Figure imgf000015_0001
Table 1
[0061] In Table 1 , an elliptical-shaped gesture is associated with a "Spotlight" processing tool that brightens an identified region relative to its surroundings. Similarly, a rectangular-shaped gesture is associated with a "Zoom" processing tool. [0062] When the user gestures on the touch screen 52 to identify a region of the displayed digital image, gesture data is received by computer 64 (step 700), and gesture ink is displayed on the display device in a known manner based on the received gesture data. The gesture data is a set of sampled coordinates based on pointer contacts that in combination form a closed figure such as an ellipse, a rectangle, a triangle etc. Individual sampled coordinates are considered part of a set if together received while the pointer remains in contact with the touch surface 54. Other similar criteria may be used. In this embodiment, the gesture data directly characterizes the identified region because it defines the shape, size and position of the region.
[0063] Once the gesture data is received, the shape of the gesture is determined (step 800) by the computer 64 using a shape recognition algorithm. The gesture shape, as described above, is considered a closed figure (i.e. one of a rectangle, ellipse, triangle etc.). Error handling algorithms may be employed by computer 64 to handle cases in which the gesture data cannot reasonably be considered to define a closed figure (i.e. a straight or only slightly curved line). Other pre-processing algorithms may be employed by computer 64 to handle cases in which the gesture data, while not inherently defining a closed figure, may reasonably be considered to represent a closed figure. For example, a "C" shape or swirl may each be considered as imprecisely-drawn ellipses. It is advantageous, from a user's perspective, for the shape recognition algorithm to be robust so as to handle such partially-closed figures. In order to achieve this, the pre-processing algorithms process the set of sampled points and perhaps add additional points to the set to result in a closed figure that completely encloses the region being delineated.
[0064] Shape recognition algorithms are known in the art, and include those that compare the characteristics of a set of sampled coordinates to predefined characteristics respectively defining shapes or shape templates. For example, if a set of coordinates is a 93% match with a given shape template but only a 22% match with another shape template, then the shape template with the 93% match is chosen as the matching gesture template, thereby to determine the gesture shape. [0065] Once the gesture shape is determined, the original gesture ink on the display device is removed and replaced with gesture ink corresponding to the determined gesture shape scaled and positioned so as to correspond to the size and position of the user's original gesture. The size and position of the gesture are determined by processing the set of sampled points using geometrical analysis to determine a center of the gesture and its boundaries.
[0066] The gesture shape is then used by the computer 64 as a key into the index of the processing tool table to identify the associated processing tool. In Table 1, for example, should the gesture shape be determined to be an ellipse "O", the Spotlight processing tool is identified.
[0067] The identified processing tool is then automatically launched and both the digital image and the gesture data are provided as input arguments to the processing tool for processing the region (step 1000). Processing tool input arguments may include the gesture data itself, or the determined gesture shape with corresponding size and position information. Depending upon the processing tool with which the gesture shape is associated in the processing tool table, processing may occur automatically, or alternatively an option given to the user to specify further the nature of the processing. For example, if the processing tool is a zoom tool, the user is given the option of zooming in, zooming out, or doing nothing. Furthermore, the user is able to translate the zoom tool so as to process a region having the same shape and size as was drawn but at a different position. Once used, the processing tool is closed or otherwise de-activated by clicking the mouse or contacting the touch surface 54 outside of the region delineated by the gesture ink.
[0068] A region 82 of a digital image 80 delineated by a generally rectangular boundary drawn using the touch system 50 is shown in Figure 15a. The identified region 82 of digital image 80 enlarged by application of a zoom processing tool associated with the gestured rectangular boundary is shown in Figure 15b. The original gesture ink of Figure 15a is automatically removed and, as shown in Figure 15b, is replaced with gesture ink identifying the bounds of the rectangular region 82 that was enlarged by the zoom processing tool.
[0069] A region 92 of different digital image 90 delineated by a circular/elliptical boundary drawn by a user using the touch system 50 is shown in Figure 16a. The identified region 92 of digital image 90 spotlighted by application of a spotlighting tool associated with the gestured circular/elliptical boundary is shown in Figure 16b. The original gesture ink of Figure 16a is automatically removed and, as shown in Figure 16b, is replaced with gesture ink identifying the bounds of the circular/elliptical region 92 that was spotlighted by the spotlighting processing tool. [0070] While a novel method of processing an identified region of a digital image has been described above, it will be understood that many alternatives are available. For example, other figure shapes, such as triangles or trapezoids may be included in the processing tool table in association with respective processing tools. [0071] It will be understood that the gesture shapes stored in the processing tool table previously described are those shapes that serve to directly characterize a region (i.e., clearly identify its size, shape and position), or can be reasonably assumed by implementing software to clearly characterize the region. For example, an ellipse inherently encloses a region thereby fully characterizing the region, whereas a "C" shape does not inherently characterize a region but may be considered by the implementing software to be a similarly-sized ellipse that has been incompletely drawn. The implementing software would then consider the '1C" shape to characterize a region that would have been enclosed by a similarly-sized ellipse, and the "C" and ellipse would, for the purpose of processing tool selection, be the same gesture and therefore result in selection of the same processing tool.
[0072] According to another embodiment, the processing tool table is configured such that both a "C" and an ellipse "O", while characterizing the same region (in terms of shape, size and position), respectively cause the selection of a different processing tool for processing the region. For example, drawing a "C" shape causes an elliptical region to be spotlighted, whereas drawing an actual ellipse "O" causes the elliptical region to be cropped. Other gestures that do not directly characterize regions, but can be respectively associated with a closed figure and specify its size and position, are supported. For example, a "+" sign gesture in this embodiment characterizes a similarly-sized rectangular region as would an actual rectangular gesture surrounding the region, but causes the selection of a different processing tool than the drawing of a rectangle. The "+" sign gesture could alternatively characterize a similarly-sized elliptical region. Therefore, it can be seen that the shape, size and position of a particular region may be characterized using several different gesture shapes, whereby the actual gesture shape is the key into the index of the processing tool table. An example of the conceptual contents of such an alternative processing table is shown in Table 2 below.
Figure imgf000018_0001
Table 2 [0073] According to the contents of Table 2, if a "+" is drawn by a user, it signifies that an "O", or elliptical-shaped region corresponding in size and position to the drawn ς'+" is to be processed using the Crop processing tool. However, if an "O" is drawn by the user, it signifies that the same elliptical-shaped region corresponding in size and position to the drawn "O" is to be processed, but this time using the Zoom in/out processing tool.
[0074] According to another embodiment, gesture shapes drawn using dashed lines invoke a different processing tool than gesture shapes of the same size and position drawn using a solid line. An example of the conceptual contents of such an alternative processing table is shown in Table 3 below.
Figure imgf000019_0001
Table 3
[0075] Alternatively, the dashed lines differentiate between region shapes, size and position but invoke the same tool. For example, a dashed "+" is used to identify a circle and a cropping processing action, whereas a solid "+" is used to identify a square and the cropping processing action. Other alternatives will be apparent to those of skill in the art. For example, in some embodiments the determined gesture shape can be dependent on the orientation of the sampled points. [0076] According to another embodiment, a special gesture pen may be used for drawing gesture shapes on the touch screen and launching corresponding processing tools/applications, whereas other pens are used simply for drawing.
[0077] It can be seen that the above described method for processing a region of a digital image advantageously allows a user to both select a region and a tool for operating on the region with a single gesture.
[0078] Although particular embodiments have been described above, those of skill in the art will appreciate that variations and modifications may be made without departing from the spirit and scope thereof as defined by the appended claims.

Claims

What is claimed is:
1. A method of dividing a digital image into regions, comprising: identifying potential region borders based on edge content in the digital image; and dividing the digital image into regions based on user-selected ones of the identified potential region borders.
2. The method of claim 1 , wherein the potential region borders are identified at locations along rows and columns in the digital image that have a significant amount of edge content.
3. The method of claim 2, wherein said identifying comprises: calculating pixel intensity profiles for each row and column of pixels in the digital image; and comparing adjacent ones of the pixel intensity profiles to determine where differences between adjacent pixel intensity profiles exceed a threshold level, thereby establishing row and column positions of the potential region borders.
4. The method of claim 3, wherein the threshold level is fixed.
5. The method of claim 4, wherein the threshold level is 0.125 intensity units.
6. The method of claim 3, wherein the threshold level is calculated based on a measurement of intensity volatility in the digital image.
7. The method of claim 6, wherein the intensity volatility is the standard deviation of pixel intensity values in the digital image.
8. The method of claim 1, further comprising: receiving a selection of a subset of the regions; and removing the content of unselected regions from the digital image.
9. The method of claim 8, further comprising: scaling selected regions in response to user instructions.
10. The method of claim 9, wherein said scaling comprises: receiving a user selection of a region border; and in response to user instructions moving the region border thereby to scale the region.
11. The method of claim 1 , comprising: modifying a position of at least one potential region border in response to user instructions.
12. The method of claim 1, further comprising: merging regions in response to user instructions.
13. The method of claim 12, wherein said merging comprises: receiving a selection of at least two adjacent regions to be merged; removing a portion of any potential region borders that divide the at least two adjacent regions; and merging the at least two adjacent regions to form a single continuous region.
14. A method of processing a region of a digital image, comprising: receiving gesture data for characterizing the region; automatically launching a processing tool associated with the gesture data; and processing the region using the processing tool.
15. The method of claim 14, wherein the gesture data defines a gesture shape that is a closed figure thereby to characterize the shape, size and location of the region.
16. The method of claim 14, wherein the gesture data defines a gesture shape, the gesture shape associated with a shape of, and defining the size and position of, a closed figure thereby to characterize the region.
17. The method of claim 14, wherein the gesture data defines a gesture shape, the gesture shape being associated with the processing tool.
18. The method of claim 17, wherein the gesture shape is a closed figure.
19. The method of claim 14, wherein the gesture data includes coordinates along the boundaries of the region.
20. The method of claim 14, wherein said automatically launching a processing tool comprises: identifying a gesture shape from the gesture data; searching a processing tool table to determine a processing tool associated in the processing tool table with the identified gesture shape; automatically launching the processing tool; and providing the gesture data to the processing tool.
21. The method of claim 20, wherein identifying the gesture shape comprises: comparing the gesture data to a plurality of shape templates each representing a unique shape; and determining which of the shape templates is the most similar to the region thereby to identify the gesture shape.
22. The method of claim 14, wherein the processing tool is selected from the group consisting of a zoom tool, a cropping tool, a highlighting tool, and a spotlighting tool.
23. The method of claim 20, wherein the gesture shape is a rectangle and the processing tool associated with the rectangle in the processing tool table is a zoom tool.
24. The method of claim 20, wherein the gesture shape is an ellipse and the processing tool associated with the ellipse in the processing tool table is a highlight/spotlight tool.
25. The method of claim 14, wherein processing of the region by the processing tool is controllable by a user.
26. The method of claim 25, wherein the processing tool is a zoom tool and the magnification level of the zoom tool is further controllable by the user.
27. A computer readable medium embodying a computer program for dividing a digital image into regions, the computer program comprising: computer program code identifying potential region borders based on edge content in the digital image; and computer program code dividing the digital image into regions based on user- selected ones of the identified potential region borders.
28. A computer readable medium embodying a computer program for processing a region of a digital image, the computer program comprising: computer program code receiving gesture data for characterizing the region; computer program code automatically launching a processing tool associated with the gesture data; and computer program code processing the region using the processing tool.
29. An interactive display system comprising: a touch screen that defines a touch surface on which a computer-generated image is presented; a sensor assembly detecting pointer contacts on the touch surface and in response, generating gesture data for characterizing a region of the computer- generated image; and processing structure receiving the gesture data and automatically launching a processing tool associated with the gesture data for processing the region.
30. The system of claim 29, further comprising: memory storing a processing tool table associating at least one processing tool with a respective gesture shape; wherein the processing structure identifies a gesture shape from the gesture data, and selects an associated processing tool from the processing tool table for processing the region.
31. The system of claim 29, wherein the processing tool is selected from the group consisting of a zoom tool, a cropping tool, a highlighting tool, and a spotlighting tool.
32. The system of claim 30, wherein the gesture shape is a rectangle and the processing tool associated with the rectangle in the processing tool table is a zoom tool.
33. The system of claim 30, wherein the gesture shape is an ellipse and the processing tool associated with the ellipse in the processing tool table is a highlight/ spotlight tool.
34. The system of claim 30, wherein processing of the region by the processing tool is controllable by a user.
35. The system of claim 30, wherein the processing tool is a zoom tool and the magnification level of the zoom tool is further controllable by the user.
PCT/CA2008/001311 2007-07-17 2008-07-16 Method for manipulating regions of a digital image WO2009009896A1 (en)

Priority Applications (5)

Application Number Priority Date Filing Date Title
CA2693775A CA2693775C (en) 2007-07-17 2008-07-16 Method for manipulating regions of a digital image
AU2008278242A AU2008278242A1 (en) 2007-07-17 2008-07-16 Method for manipulating regions of a digital image
EP08772887A EP2168095A4 (en) 2007-07-17 2008-07-16 Method for manipulating regions of a digital image
NZ582553A NZ582553A (en) 2007-07-17 2008-07-16 Method for manipulating regions of a digital image
CN200880025134A CN101765860A (en) 2007-07-17 2008-07-16 Method for manipulating regions of a digital image

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/779,006 US8238662B2 (en) 2007-07-17 2007-07-17 Method for manipulating regions of a digital image
US11/779,006 2007-07-17

Publications (1)

Publication Number Publication Date
WO2009009896A1 true WO2009009896A1 (en) 2009-01-22

Family

ID=40259262

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/CA2008/001311 WO2009009896A1 (en) 2007-07-17 2008-07-16 Method for manipulating regions of a digital image

Country Status (8)

Country Link
US (1) US8238662B2 (en)
EP (1) EP2168095A4 (en)
KR (1) KR20100051648A (en)
CN (1) CN101765860A (en)
AU (1) AU2008278242A1 (en)
CA (1) CA2693775C (en)
NZ (1) NZ582553A (en)
WO (1) WO2009009896A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10203852B2 (en) 2016-03-29 2019-02-12 Microsoft Technology Licensing, Llc Content selection in web document

Families Citing this family (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101513024B1 (en) * 2008-04-22 2015-04-17 엘지전자 주식회사 Terminal and method of recognizing image therein
KR101534789B1 (en) * 2008-05-28 2015-07-07 구글 인코포레이티드 Motion-controlled views on mobile computing devices
DE102009003995A1 (en) * 2008-08-06 2010-02-11 Rohde & Schwarz Gmbh & Co. Kg Method for enlarging a display area on a presentation device
JP5326802B2 (en) * 2009-05-19 2013-10-30 ソニー株式会社 Information processing apparatus, image enlargement / reduction method, and program thereof
US8532435B1 (en) * 2009-08-18 2013-09-10 Adobe Systems Incorporated System and method for automatically adapting images
KR101669618B1 (en) * 2010-01-15 2016-10-26 삼성전자주식회사 Display apparatus and display method thereof
US9235452B2 (en) * 2010-02-05 2016-01-12 Microsoft Technology Licensing, Llc Graphics remoting using augmentation data
WO2012012915A1 (en) 2010-07-30 2012-02-02 Hewlett-Packard Development Co Detecting separator lines in a web page
CN102420969A (en) * 2010-09-27 2012-04-18 比亚迪股份有限公司 Car-reversing auxiliary system and method
US8542396B2 (en) * 2010-10-21 2013-09-24 Yi-Lin Chen System of making a personalized photo album
US8861797B2 (en) * 2010-11-12 2014-10-14 At&T Intellectual Property I, L.P. Calibrating vision systems
JP2012118832A (en) * 2010-12-02 2012-06-21 Sony Corp Information processor, information processing method and program
US20120210200A1 (en) * 2011-02-10 2012-08-16 Kelly Berger System, method, and touch screen graphical user interface for managing photos and creating photo books
JP2013080326A (en) * 2011-10-03 2013-05-02 Sony Corp Image processing device, image processing method, and program
US20130143657A1 (en) * 2011-11-14 2013-06-06 Amazon Technologies, Inc. Input Mapping Regions
KR102030754B1 (en) 2012-03-08 2019-10-10 삼성전자주식회사 Image edting apparatus and method for selecting region of interest
KR101390561B1 (en) * 2013-02-15 2014-05-27 한양대학교 에리카산학협력단 Method and apparatus for subtitles detection
CN104020935A (en) * 2013-02-28 2014-09-03 国际商业机器公司 Method and device used for controlling display object on display screen
US10296808B2 (en) * 2013-03-21 2019-05-21 Koninklijke Philips N.V. Method and X-ray system for computer aided detection of structures in X-ray images
US20150058710A1 (en) * 2013-08-21 2015-02-26 Microsoft Corporation Navigating fixed format document in e-reader application
US10769446B2 (en) 2014-02-28 2020-09-08 Second Spectrum, Inc. Methods and systems of combining video content with one or more augmentations
US10713494B2 (en) 2014-02-28 2020-07-14 Second Spectrum, Inc. Data processing systems and methods for generating and interactive user interfaces and interactive game systems based on spatiotemporal analysis of video content
US11120271B2 (en) 2014-02-28 2021-09-14 Second Spectrum, Inc. Data processing systems and methods for enhanced augmentation of interactive video content
US11861906B2 (en) 2014-02-28 2024-01-02 Genius Sports Ss, Llc Data processing systems and methods for enhanced augmentation of interactive video content
US10521671B2 (en) 2014-02-28 2019-12-31 Second Spectrum, Inc. Methods and systems of spatiotemporal pattern recognition for video content development
ES2569578B1 (en) * 2014-10-07 2017-01-25 Maxwell & Lorentz, S.L. HEAT GENERATION SYSTEM BY MAGNETIC INDUCTION
US20160246488A1 (en) * 2015-02-24 2016-08-25 Jonathan Sassouni Media Reveal Feature
EP3091427A1 (en) * 2015-05-06 2016-11-09 Thomson Licensing Apparatus and method for selecting an image area
KR102518219B1 (en) 2018-10-15 2023-04-06 현대자동차주식회사 Vehicle and controlling method of vehicle
US11113535B2 (en) 2019-11-08 2021-09-07 Second Spectrum, Inc. Determining tactical relevance and similarity of video sequences

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6300947B1 (en) * 1998-07-06 2001-10-09 International Business Machines Corporation Display screen and window size related web page adaptation system
US6345279B1 (en) * 1999-04-23 2002-02-05 International Business Machines Corporation Methods and apparatus for adapting multimedia content for client devices
US20050052427A1 (en) * 2003-09-10 2005-03-10 Wu Michael Chi Hung Hand gesture interaction with touch surface
US20050210399A1 (en) * 2004-03-18 2005-09-22 Microsoft Corporation Method and system for improved viewing and navigation of content
US20060274067A1 (en) * 2001-09-14 2006-12-07 Hideo Hidai Image processing apparatus, display apparatus with touch panel, image processing method and computer program
US7203901B2 (en) * 2002-11-27 2007-04-10 Microsoft Corporation Small form factor web browsing

Family Cites Families (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5680479A (en) * 1992-04-24 1997-10-21 Canon Kabushiki Kaisha Method and apparatus for character recognition
US5523775A (en) * 1992-05-26 1996-06-04 Apple Computer, Inc. Method for selecting objects on a computer display
US5583946A (en) * 1993-09-30 1996-12-10 Apple Computer, Inc. Method and apparatus for recognizing gestures on a computer system
US5546474A (en) * 1993-12-21 1996-08-13 Hewlett-Packard Company Detection of photo regions in digital images
IL114838A0 (en) * 1995-08-04 1996-11-14 Spiegel Ehud Apparatus and method for object tracking
JP2000163044A (en) * 1998-11-30 2000-06-16 Sharp Corp Picture display device
US6473522B1 (en) * 2000-03-14 2002-10-29 Intel Corporation Estimating text color and segmentation of images
US6788809B1 (en) * 2000-06-30 2004-09-07 Intel Corporation System and method for gesture recognition in three dimensions using stereo imaging and color vision
JP2002192800A (en) * 2000-12-25 2002-07-10 Canon Inc Image printer and image printing method
US20050195221A1 (en) * 2004-03-04 2005-09-08 Adam Berger System and method for facilitating the presentation of content via device displays
US7308112B2 (en) * 2004-05-14 2007-12-11 Honda Motor Co., Ltd. Sign based human-machine interaction
US20060078162A1 (en) * 2004-10-08 2006-04-13 Dynapel, Systems, Inc. System and method for stabilized single moving camera object tracking
WO2006128302A1 (en) * 2005-06-02 2006-12-07 The Medipattern Corporation System and method of computer-aided detection
WO2007000743A2 (en) * 2005-06-28 2007-01-04 Koninklijke Philips Electronics, N.V. In-zoom gesture control for display mirror
US7980948B2 (en) * 2006-12-19 2011-07-19 Igt Dynamic side wagering system for use with electronic gaming devices

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6300947B1 (en) * 1998-07-06 2001-10-09 International Business Machines Corporation Display screen and window size related web page adaptation system
US6345279B1 (en) * 1999-04-23 2002-02-05 International Business Machines Corporation Methods and apparatus for adapting multimedia content for client devices
US20060274067A1 (en) * 2001-09-14 2006-12-07 Hideo Hidai Image processing apparatus, display apparatus with touch panel, image processing method and computer program
US7203901B2 (en) * 2002-11-27 2007-04-10 Microsoft Corporation Small form factor web browsing
US20050052427A1 (en) * 2003-09-10 2005-03-10 Wu Michael Chi Hung Hand gesture interaction with touch surface
US20050210399A1 (en) * 2004-03-18 2005-09-22 Microsoft Corporation Method and system for improved viewing and navigation of content

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP2168095A4 *

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10203852B2 (en) 2016-03-29 2019-02-12 Microsoft Technology Licensing, Llc Content selection in web document

Also Published As

Publication number Publication date
AU2008278242A1 (en) 2009-01-22
EP2168095A1 (en) 2010-03-31
US8238662B2 (en) 2012-08-07
NZ582553A (en) 2013-01-25
KR20100051648A (en) 2010-05-17
CA2693775A1 (en) 2009-01-22
CA2693775C (en) 2016-09-13
EP2168095A4 (en) 2011-07-27
CN101765860A (en) 2010-06-30
US20090022394A1 (en) 2009-01-22

Similar Documents

Publication Publication Date Title
CA2693775C (en) Method for manipulating regions of a digital image
US9330292B2 (en) Two-dimensional code scanning method and device
US20130215148A1 (en) Interactive input system having a 3d input space
US9792268B2 (en) Zoomable web-based wall with natural user interface
US20140189482A1 (en) Method for manipulating tables on an interactive input system and interactive input system executing the method
CN111475059A (en) Gesture detection based on proximity sensor and image sensor
US20140333585A1 (en) Electronic apparatus, information processing method, and storage medium
KR20130110158A (en) Smartphone-based user interfaces, such as for browsing print media
US20210192751A1 (en) Device and method for generating image
US20180046351A1 (en) Controlling display object on display screen
CN112954193B (en) Shooting method, shooting device, electronic equipment and medium
CN113934297B (en) Interaction method and device based on augmented reality, electronic equipment and medium
CN110830704B (en) Method and device for generating rotating image
CN113873151A (en) Video recording method and device and electronic equipment
CN106507201A (en) A kind of video playing control method and device
US20020101364A1 (en) System and method for extracting a point of interest of an object in front of a computer controllable display captured by an imaging device
CN110286827B (en) Element scaling control method, device, equipment and storage medium
CN114025100A (en) Shooting method, shooting device, electronic equipment and readable storage medium
WO2011096571A1 (en) Input device
CN112822394A (en) Display control method and device, electronic equipment and readable storage medium
Denoue et al. Real-time direct manipulation of screen-based videos
CN113873168A (en) Shooting method, shooting device, electronic equipment and medium
CN114339073B (en) Video generation method and video generation device
JP2011039594A (en) Input device
CN114339050A (en) Display method and device and electronic equipment

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 200880025134.1

Country of ref document: CN

121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 08772887

Country of ref document: EP

Kind code of ref document: A1

WWE Wipo information: entry into national phase

Ref document number: 2693775

Country of ref document: CA

WWE Wipo information: entry into national phase

Ref document number: 582553

Country of ref document: NZ

WWE Wipo information: entry into national phase

Ref document number: 2008278242

Country of ref document: AU

WWE Wipo information: entry into national phase

Ref document number: 2008772887

Country of ref document: EP

NENP Non-entry into the national phase

Ref country code: DE

ENP Entry into the national phase

Ref document number: 20107002585

Country of ref document: KR

Kind code of ref document: A

ENP Entry into the national phase

Ref document number: 2008278242

Country of ref document: AU

Date of ref document: 20080716

Kind code of ref document: A