1. Field of the Invention
The invention relates to an electronic device user interface, also known as a human-machine interface, and, more particularly, to a method and apparatus for combining a manipulable input device and a gesture based input device.
2. Introduction
A first type of human-machine interface in the art comprises manipulable input devices such as a computer mouse, trackball, trackpad, digitizing pad, touchscreen, touchscreen with stylus, joystick, keypad, keyboard, or other devices that enable users to accurately indicate that they want a functionality to be executed by the machine, for example by clicking a mouse button, and to accurately indicate to the machine a desired position or movement, for example by moving a mouse or depressing an arrow key repeatedly.
A second type of human-machine interface in the art comprises recognizing and tracking gestures, for example but not limited to recognizing the configuration of a hand or hands, recognizing a motion of a hand or hands, or recognizing a changing configuration of a hand or hands over time. It will be understood by those skilled in the art that other body parts may be used instead of or together with hands, and that the recognition of gestures may be aided by the addition of coverings or implements to the body parts; for example, a glove may be worn on the hand or a brightly colored object may be held in a hand. U.S. Patent Applications 20030156756 (Gokturk et. al) and 20030132913 (Issinski) propose using gesture recognition as a computer user interface (UI) in which stereo cameras register finger and hand movements in the space in front of a computer screen.
The first type of user interface has the disadvantage that the user experiences fatigue. This is especially the case when the first type of user interface is a one-handed interface such as a computer mouse. In the case of a computer mouse, one hand is used a great deal, leading to fatigue of that hand, whereas the other hand is underutilized. Another disadvantage of the first type of user interface is that, except in the case of touchscreens and the like, the user is not interacting directly with displayed content, but instead with a device that physically moves on, for example, a mouse pad or desktop instead of the screen. A third disadvantage of the first type of user interface is that, while many user-interface functionalities may be enabled, in many instances, and particularly with one-handed interfaces such as a computer mouse, it is not possible to perform two actions simultaneously, for example simultaneously manipulate two displayed objects in different ways and/or at different locations in the display.
The second type of user interface has an advantage that it allows directly interacting with displayed content, for example, by pointing to a window on a display screen with a finger. The second type of user interface has a disadvantage that it often does not enable the same degree of accuracy as the first type of user interface. For example, a hand moving freely in space cannot match a conventional mouse stabilized on a desktop for precision of cursor movement. Furthermore, the second type of user interface has a disadvantage that machine operations can be triggered inadvertently, as when, for example, the user, or another person in discussion with the user, moves his hand towards the screen without intending to interact with the machine. The inadvertent triggering of machine operations can result in content being altered or files or applications being closed against the wishes of the user.
For the reasons stated above, and for other reasons stated below which will become apparent to those skilled in the art upon reading and understanding the present specification, there is a need in the art for a human-machine interface that combines the advantages and mitigates the disadvantages of the first and second types of user interface.
A method and apparatus for manipulating displayed content using the first and second types of human-machine interface in combination, for example a manipulable device such as a mouse and a gesture based input device such as one comprising a camera, are disclosed.
The disclosed invention addresses the disadvantages of the first type of user interface and the second type of user interface by dividing machine operations into two sets and enabling control of a first set and a second set via the first type of user interface and enabling control of only the second set via the second type of user interface. In a preferred embodiment, one hand controls the first set and the other hand controls the second set, using the first and second types of human-machine interfaces, respectively. In a preferred embodiment, the first set and second set of machine operations would be enabled via a mouse interface and the second set of machine operations would be enabled via a stereo camera based hand gesture recognition interface.
In a preferred embodiment, the apparatus has a manipulable input device capable of interacting with displayed content and visualization of the displayed content. Additionally, the apparatus has a gesture based input device with access to only the visualization of the displayed content. In a possible embodiment, the gesture-based inputs do not require precise positioning. In a preferred embodiment, the gesture based inputs are “non-destructive”, that is, the inputs affect only the visualization of the displayed content, and moreover the alteration of the visualization is temporary, so the user does not have to worry about unintentionally closing files or altering content when pointing at the screen without any intent of invoking user interface functions.
In order to describe the manner in which the above-recited and other advantages and features of the invention can be obtained, a more particular description of the invention briefly described above will be rendered by reference to specific embodiments thereof which are illustrated in the appended drawings. Understanding that these drawings depict only typical embodiments of the invention and are not therefore to be considered to be limiting of its scope, the invention will be described and explained with additional specificity and detail through the use of the accompanying drawings in which:
Additional features and advantages of the invention will be set forth in the description which follows, and in part will be obvious from the description, or may be learned by practice of the invention. The features and advantages of the invention may be realized and obtained by means of the instruments and combinations particularly pointed out in the appended claims. These and other features of the present invention will become more fully apparent from the following description and appended claims, or may be learned by the practice of the invention as set forth herein.
Various embodiments of the invention are discussed in detail below. While specific implementations are discussed, it should be understood that this is done for illustration purposes only. A person skilled in the relevant art will recognize that other components and configurations may be used without parting from the spirit and scope of the invention.
The invention comprises a variety of embodiments, such as a method and apparatus and other embodiments that relate to the basic concepts of the invention.
Computer 102 includes a processor 104, commercially available from Intel, Freescale, Cyrix, and others. Computer 102 also includes random-access memory (RAM 106, read-only memory (ROM) 108, and one or more mass storage devices 110, and a system bus 112 that operatively couples various system components to the processing unit 104. The memory 106, 108, and mass storage devices 110 are types of computer-accessible media. Mass storage devices 110 are more specifically types of nonvolatile computer-accessible media and can include one or more hard disk drives, flash memory, floppy disk drives, optical disk drives, and tape cartridge drives. The processor 104 executes computer programs stored on the computer-accessible media.
Computer 102 can be communicatively connected to the Internet 114 via a communication device 116. Internet 114 connectivity is well known within the art. In one embodiment, communication device 116 is an Ethernet® or similar hardware network card connected to a local-area network (LAN) that itself is connected to the Internet via what is known in the art as a “direct connection” (e.g., T1 line, etc.).
A user enters commands and information into the computer 102 through input devices such as a keyboard 118 or a manipulable device 120. The keyboard 118 permits entry of textual information into computer 102, as known within the art, and embodiments are not limited to any particular type of keyboard. Manipulable device 120 permits the control of a screen pointer provided by a graphical user interface (GUI). Embodiments are not limited to any particular manipulable device 120. Such devices include a computer mouse, trackball, trackpad, digitizing pad, touchscreen, touchscreen with stylus, joystick, or other devices that enable users to accurately indicate that they want a functionality to be executed by the machine.
In some embodiments, computer 102 is operatively coupled to a display device 122. Display device 122 permits the display of information, including computer, video and other information, for viewing by a user of the computer. Embodiments are not limited to any particular display device 122. Examples of display devices include cathode ray tube (CRT) displays, as well as flat panel displays such as liquid crystal displays LCD's). In addition to a display device, computers typically include other peripheral input/output devices such as printers (not shown). Speakers 124 and 126 provide audio output of signals. Speakers 124 and 126 are also connected to the system bus 112.
Computer 102 also includes an operating system (not shown) that is stored on the computer-accessible media RAM 106, ROM 108, and mass storage device 110, and is executed by the processor 104. Examples of operating systems include Microsoft Windows®, Apple MacOS®, Linux®, and UNIX®. Examples are not limited to any particular operating system, however, and the construction and use of such operating systems are well known within the art.
Embodiments of computer 102 are not limited to any type of computer 102. In varying embodiments, computer 102 comprises a PC-compatible computer, a MacOS®-compatible computer, a Linux®-compatible computer, or a UNIX®-compatible computer. Computer 102 may be a desktop computer, a laptop, handheld, or other portable computer, a wireless communication device such as a cellular telephone or messaging device, a television with a set-top box, or any other type of industrial or consumer device that comprises a user interface. The construction and operation of such computers are well known within the art. Computer 102 also includes power supply 138. Each power supply can be a battery.
Computer 102 can be operated using at least one operating system to provide a human-machine interface comprising a manipulable device 120 such as a computer mouse, trackball, trackpad, digitizing pad, touchscreen, touchscreen with stylus, joystick, keypad, keyboard, or other devices that enable users to accurately indicate that they want a functionality to be executed by the machine and to accurately indicate to the machine a desired position or movement. Computer 102 can have at least one web browser application program executing within at least one operating system, to permit users of computer 102 to access an intranet, an extranet, or Internet world-wide-web pages as addressed by Universal Resource Locator (URL) addresses. Examples of browser application programs include Firefox® and Microsoft Internet Explorer®.
The computer 102 can operate in a networked environment using logical connections to one or more remote computers, such as remote computer 128. These logical connections are achieved by a communication device coupled to, or a part of, the computer 102. Embodiments are not limited to a particular type of communications device. The remote computer 128 can be another computer, a server, a router, a network PC, a client, a peer device, or other common network node. The logical connections depicted in
When used in a LAN-networking environment, the computer 102 and remote computer 128 are connected to the local network 130 through network interfaces or adapters 134, which is one type of communications device 116. Remote computer 128 also includes a network device 136. When used in a conventional WAN-networking environment, the computer 102 and remote computer 128 communicate with a WAN 132 through modems (not shown). The modem, which can be internal or external, is connected to the system bus 112. In a networked environment, program modules depicted relative to the computer 102, or portions thereof, can be stored in the remote computer 128.
The hardware and operating environment 100 may include a gesture based input device. The gesture based input device may be a vision based input device comprising one or more cameras. In a possible embodiment, hardware and operating environment 100 may include cameras 150 and 160 for capturing first and second images of a scene for developing a stereoscopic view of the scene. If the fields of view of cameras 150 and 160 overlap at least a portion of the same scene, one or more objects of the scene can be seen in both images. The signals or data from the cameras are components of the gesture based input device capable of enabling the user to interact with the visualization of a displayed content, as will be described in greater detail below.
The hardware and the operating environment illustrated in
As shown, the user, using the manipulable device 240 in his right hand, has opened an architectural package that is displaying a drawing of a structure. Concurrently with modifying the drawing of the structure using the manipulable device 240 with his right hand, the user employs his free left hand 230 to move window 220 using the gesture based input device. The gesture based input device produces user interface signals such as, but not limited to, location, motion, and selection data. In one possible embodiment, pixel values from camera 150 and camera 160 are combined to provide a depth image. A depth image can provide 3D shape information about a scene. In a depth image, pixel values represent distances of different parts of a scene to a reference point, line, or plane. An object in the foreground can be separated from a background based on pixel values of a depth image, and, optionally, camera pixel values. In the present embodiment, the foreground object is a hand of a user of computer system 100. The captured images from camera 150 and camera 160 are delivered to processor 102 of
The gestures, such as various hand gestures of a user, are recognized by software running in processor 102. For example, an outstretched hand tracking in a certain direction could indicate moving a window in that direction, a finger pointing in a particular direction and moving inward could indicate zooming in, while moving out could indicate zooming out. The processor 102 may be configured to recognize various tracking patterns, such as various hand-related gestures such as a hand or finger moving from right to left, bottom to top, in and out, etcetera. Alternatively, processor 102 could be trained with an image recognition program to correlate various images or motion patterns to various control actions. In a possible implementation, images of gestures received through camera 150 and camera 160 are compared to at least one of a set of gestures stored in a suitable storage device or correlated to a pre-defined motion pattern recognized by an image recognition program in processor 102. The processor may then forward information identifying the gesture to other devices or applications to invoke an action.
Methods or means for recognizing gestures using, for example but not limited to, cameras, depth imagers, and data gloves are known to those skilled in the art. Such methods and systems typically employ a measurement method or means and a pattern matching or pattern recognition method or means known in the art. A depth imager produces a depth image which stores depths or distances to points in the scene in pixels instead of, or in addition to, color and luminance values. Examples of depth imagers include, but are not limited to, multiple-camera systems with stereoscopic depth processing, laser, sonar, and infrared range finders, structured light systems, and single camera systems in which images taken at different times are combined to yield depth information.
While the magnifying glass is invoked with the left hand via the gesture based input device, the user could operate a computer mouse 340 with the right hand to select a graphic detail or word of text under the magnifying glass for copying or deletion. Such two-handed interaction provides a powerful, natural, and intuitive user interface. Mouse 340 can alternatively be any manipulable device, such as a trackball, trackpad, digitizing pad, touchscreen, touchscreen with stylus, joystick, keypad, keyboard, or a combination thereof in any number.
For illustrative purposes, the process will be described below in relation to the block diagrams shown in
At step 510, the data or signal from a manipulable device such as a mouse is received for processing. At step 520, the received manipulable device data is processed to generate a command.
At step 530, the data or signal from a gesture based input device such as one comprising a camera or cameras is received for processing. At step 540, the received gesture based input device data is processed to generate a command.
The process goes to step 550 and ends. Here the commands from the gesture based input device or the manipulable input device or both are used to cause the computer 100 to perform a desired operation.
It will be understood by those skilled in the art that other types of gesture based input devices, such as those comprising a single camera and single camera based gesture recognition or tracking methods, may be substituted for the gesture based input device described in the exemplary embodiments.
Embodiments within the scope of the present invention may also include computer-readable media for carrying or having computer-executable instructions or data structures stored thereon. Such computer-readable media can be any available media that can be accessed by a general purpose or special purpose computer. By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to carry or store desired program code means in the form of computer-executable instructions or data structures. When information is transferred or provided over a network or another communications connection (either hardwired, wireless, or combination thereof) to a computer, the computer properly views the connection as a computer-readable medium. Thus, any such connection is properly termed a computer-readable medium. Combinations of the above should also be included within the scope of the computer-readable media.
Computer-executable instructions include, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Computer-executable instructions also include program modules that are executed by computers in stand-alone or network environments. Generally, program modules include routines, programs, objects, components, and data structures, etc. that perform particular tasks or implement particular abstract data types. Computer-executable instructions, associated data structures, and program modules represent examples of the program code means for executing steps of the methods disclosed herein. The particular sequence of such executable instructions or associated data structures represents examples of corresponding acts for implementing the functions described in such steps.
Although the above description may contain specific details, they should not be construed as limiting the claims in any way. Other configurations of the described embodiments of the invention are part of the scope of this invention. For example, the principles of the invention may be applied to each individual user where each user may individually deploy such a system. This enables each user to utilize the benefits of the invention even if any one of the large number of possible applications do not need the functionality described herein. It does not necessarily need to be one system used by all end users. Accordingly, only the appended claims and their legal equivalents should define the invention, rather than any specific examples given.
The present application claims priority from U.S. Provisional Patent Application No. 61/017,905, filed Dec. 31, 2007.
Number | Date | Country | |
---|---|---|---|
61017905 | Dec 2007 | US |