A gesture recognition method comprises capturing images, processing the images to identify at least two clusters of touch points associated with at least two pointers, recognizing a gesture based on motion of the clusters, and updating a display in accordance with the recognized gesture.
| 
 | 1.  A gesture recognition method comprising:
 capturing images using imaging sensors having fields of view aimed generally across or at an input surface from different vantages; processing the captured images to detect a pair of hands brought into contact with said input surface and for each detected hand calculating a bounding box, the calculated bounding box surrounding either a cluster of proximate touch points resulting from multiple fingers of the hand being in contact with said input surface or a single large touch region exceeding a threshold size resulting from a palm region of the hand being in contact with said input surface; creating an observation for each bounding box in each captured image, each observation in each captured image defined by the area formed between two straight lines, one line of which extends from the focal point of the imaging sensor that captured the image and crosses the right edge of the bounding box and the other line of which extends from the focal point of the imaging sensor that captured the image and crosses the left edge of the bounding box; in response to relative movement of the hands over the input surface, recognizing a gesture based on corresponding relative movement of the created observations; executing a command associated with the recognized gesture; and updating an image displayed on said input surface in accordance with the executed command. 2.  An interactive input system comprising:
 an input surface; at least two imaging sensors having fields of view aimed generally across or at said input surface from different vantages; and processing structure communicating with said at least one imaging sensor, said processing structure being configured to:
 analyze images captured by said at least one imaging sensor to detect multiple hands brought into contact with said input surface, for each detected hand, calculate a bounding box, the bounding box surrounding either a cluster of proximate touch points resulting from multiple fingers of the hand being in contact with said input surface or a single large touch region exceeding a threshold size resulting from a palm region of the hand being in contact with said input surface, create an observation for each bounding box in each captured image, wherein each observation in each captured image defined by the area formed between two straight lines, one line of which extends from the focal point of the imaging sensor that captured the image and crosses the right edge of the bounding box and the other line of which extends from the focal point of the imaging sensor that captured the image and crosses the left edge of the bounding box; in response to relative movement of the hands over the input surface, recognize a gesture based on corresponding relative movement of the created bounding boxes, execute a command associated with said recognized gesture, and update an image displayed on said input surface in accordance with the executed command. 4.  The method of  5.  The method of  6.  The method of  7.  A non-transitory computer readable medium having computer program code stored thereon, the computer program code, when executed by a processor, causing an apparatus at least to perform the method of  8.  The interactive input system of  9.  The interactive input system of  10.  The interactive input system of  11.  The interactive input system of  12.  The interactive input system of  13.  The interactive input system of  14.  The interactive input system of  | |||||||||||||||||||||||||||
This application is a national stage of PCT/CA2010/000002, filed on Jan. 5, 2010, which claims priority to U.S. Provisional Patent Application No. 61/142,545, filed on Jan. 5, 2009. Each of these documents is incorporated herein by reference in its entirety.
The present invention relates generally to gesture recognition and in particular, to a gesture recognition method and to an interactive input system employing the same.
Interactive input systems that allow users to inject input (e.g. digital ink, mouse events etc.) into an application program using an active pointer (e.g. a pointer that emits light, sound or other signal), a passive pointer (e.g. a finger, cylinder or other object) or other suitable input device such as for example, a mouse or trackball, are well known. These interactive input systems include but are not limited to: touch systems comprising touch panels employing analog resistive or machine vision technology to register pointer input such as those disclosed in U.S. Pat. Nos. 5,448,263; 6,141,000; 6,337,681; 6,747,636; 6,803,906; 7,232,986; 7,236,162; and 7,274,356 and in U.S. Patent Application Publication No. 2004/0179001 assigned to SMART Technologies ULC of Calgary, Alberta, Canada, assignee of the subject application, the contents of which are incorporated by reference; touch systems comprising touch panels employing electromagnetic, capacitive, acoustic or other technologies to register pointer input; tablet personal computers (PCs); touch-enabled laptop PCs; personal digital assistants (PDAs); and other similar devices.
Gesture recognition methods employed by interactive input systems have been considered. For example, U.S. Pat. No. 7,411,575 to Hill et al. and assigned to SMART Technologies ULC, the contents of which are incorporated by reference, discloses a gesture recognition method employed by a machine vision interactive input system. During the method, multiple pointers in close proximity to a touch surface are detected to determine if the multiple pointers are being used to perform a known gesture. When the multiple pointers are being used to perform a known gesture, a command associated with the gesture is executed. Specifically, pointer data is examined to detect the existence of multiple pointers in captured images and then the nature of the multiple pointers is examined to determine if a known gesture has been performed, such as for example a right-click gesture, a scroll gesture, a rotate gesture etc. When a known gesture has been performed, a command event is generated that is associated with the determined gesture and the command event is conveyed to the active application program being executed by a computer.
U.S. Pat. No. 7,176,904 to Satoh discloses a touch panel with a display screen. An optical reflection film is provided on three sides of the display screen and reflects light towards two optical units aligned to look across the touch panel. A coordinate control section detects when a pointer has touched on the panel and generates a signal according to the detected point. The coordinate control section generates a coordinate signal that shows coordinates of a touched point, when one point touch on the panel has been detected. When simultaneous touches of two or more points on the panel have been detected, the coordinate control section generates a control signal that shows a control set in advance corresponding to the number of touched points.
U.S. Patent Application Publication Nos. 2008/0180404; 2008/0180405; and 2008/018406 to Han disclose methods and systems for interfacing with multi-point input devices that employ techniques for controlling displayed images including 2D and 3D image translation, scale/zoom, rotation control and globe axis tilt control. Various control techniques employ three or more simultaneous inputs, changes in characteristics of the inputs and pressure sensing.
In interactive input systems that employ rear projection devices to present images on the input surfaces of the interactive input systems (such as rear projection displays, liquid crystal display (LCD) devices, plasma televisions, etc.), multiple pointers from more than one user that are brought into contact with the input surfaces are difficult to locate and track, especially in interactive input systems employing only two imaging devices. For example, in interactive input systems employing two imaging devices, when multiple pointers are being tracked, the triangulation solutions for the pointers include actual pointer locations and imaginary pointer locations resulting in pointer ambiguity issues if the pointers do not carry markings that enable the pointers to be readily differentiated. The ambiguity issues become very complex when recognizing gestures made using multiple pointers.
Therefore, it is an object of the present invention to provide a novel gesture recognition method and a novel interactive input system employing the method.
Accordingly, in one aspect there is provided a gesture recognition method comprising capturing images looking generally across an input region, processing the images to identify at least two clusters of touch points associated with at least two pointers within the input region, recognizing a gesture based on motion of the clusters of touch points, and updating a display in accordance with the recognized gesture.
According to another aspect there is provided an interactive input system comprising an input surface, at least one imaging sensor having a field of view looking generally across the input surface, and processing structure communicating with said at least one imaging sensor, said processing structure being configured to analyze image data acquired by said at least one imaging sensor to determine the location of a cluster of touch points associated with at least two pointers in contact with the input surface, to recognize successive clusters of touch points representing a gesture based on the relative positions of the clusters of touch points and to execute a command associated with said gesture.
According to another aspect there is provided a gesture recognition method comprising capturing images looking at an input surface, processing the images to identify at least two clusters of touch points associated with at least two pointers, recognizing a gesture based on motion of the clusters of touch points, and updating a display in accordance with the gesture.
According to yet another aspect there is provided an interactive input system comprising an input surface, at least one imaging sensor having a field of view looking at the input surface, and processing structure communicating with said at least one imaging sensor, said processing structure being configured to analyze image data acquired by said at least one imaging sensor to determine the location of a cluster of touch points associated with at least two pointers in contact with the input surface, to recognize successive clusters of touch points representing a gesture based on the relative positions of the clusters of touch points and to execute a command associated with said gesture.
Embodiments will now be described more fully with reference to the accompanying drawings in which:
Turning now to 
Assembly 22 is coupled to a master controller 30. Master controller 30 is coupled to a general purpose computing device 32 and to a display controller 34. The general purpose computing device 32 executes one or more application programs and uses pointer location and gesture identification information communicated from the master controller 30 to generate and update image data that is provided to the display controller 34 for output to the display unit so that the image presented on the display surface 24 reflects pointer activity. In this manner, pointer activity proximate to the display surface 24 can be recorded as writing or drawing or used to control execution of one or more application programs running on the general purpose computing device 32.
Imaging devices 40, 42 are positioned adjacent two corners of the display surface 24 and look generally across the display surface from different vantages. Referring to 
The general purpose computing device 32 in this embodiment is a computer comprising, for example, a processing unit, system memory (volatile and/or non-volatile memory), other non-removable or removable memory (eg. a hard disk drive, RAM, ROM, EEPROM, CD-ROM, DVD, flash memory, etc.) and a system bus coupling the various computing device components to the processing unit. The computing device 32 may also comprise a network connection to access shared or remote drives, one or more networked computers, or other networked devices. The processing unit runs a host software application/operating system which, during execution, provides a graphical user interface that is presented on the display surface 24 such that freeform or handwritten ink objects and other objects can be input and manipulated via pointer interaction with the display surface 24.
During operation, the DSP 90 of each imaging device 40, 42, generates clock signals so that the image sensor 80 of each imaging device captures image frames at the desired frame rate. The dock signals provide to the image sensors 80 are synchronized such that the image sensors of the imaging devices 40 and 42 capture image frames substantially simultaneously. When no pointer is in proximity of the display surface 24, image frames captured by the image sensors 80 comprise a substantially uninterrupted bright band as a result of the infrared backlighting provided by the bezel 26. However, when one or more pointers are brought into proximity of the display surface 24, each pointer occludes the IR backlighting provided by the bezel 26 and appears in captured image frames as a dark region interrupting the white bands.
Each image frame output by the image sensor 80 of each imaging device 40, 42 is conveyed to its associated DSP 90. When each DSP 90 receives an image frame, the DSP 90 processes the image frame to detect the existence of one or more pointers. If one or more pointers exist in the image frame, the DSP 90 creates an observation for each pointer in the image frame. Each observation is defined by the area formed between two straight lines, one line of which extends from the focal point of the imaging device and crosses the right edge of the pointer and the other line of which extends from the focal point of the imaging device and crosses the left edge of the pointer. The DSP 90 then conveys the observation(s) to the master controller 30 via serial line driver 162.
The master controller 30 in response to received observations from the imaging devices 40, 42, examines the observations to determine observations from each imaging device that overlap. When each imaging device sees the same pointer resulting in observations generated by the imaging devices 40, 42 that overlap, the center of the resultant bounding box, that is delineated by the intersecting lines of the overlapping observations, and hence the position of the pointer in (x,y) coordinates relative to the display surface 24 is calculated using well known triangulation as described in above-incorporated U.S. Pat. No. 6,803,906 to Morrison at al. The master controller 30 also examines the observations to determine if pointers interacting with the display surface 24 are being used to input gestures.
The master controller 30 in turn outputs calculated pointer positions and gesture information, if a gesture is recognized, to the general purpose computing device 32. The general purpose computing device 32 in turn processes the received pointer positions and gesture information and updates image output provided to the display controller 34, if required, so that the image presented on the display unit can be updated to reflect the pointer activity. In this manner, pointer interaction with the display surface 24 can be recorded as writing or drawing or used to control execution of one or more application programs running on the general purpose computing device 32.
When a single pointer exists in image frames captured by the imaging devices 40, 42, the location of the pointer in (x, y) coordinates relative to the display surface 24 can be readily computed using triangulation. When multiple pointers exist in image frames captured by the imaging devices 40, 42, computing the positions of the pointers in (x, y) coordinates relative to the display surface 24 is more challenging as a result of pointer ambiguity and pointer occlusion issues. Pointer ambiguity arises when multiple pointers are within the fields of view of the imaging devices 40, 42 and the pointers do not have distinctive markings that allow the pointers to be readily differentiated. In such cases, during triangulation, a number of possible solutions for the pointer locations may result.
For example, 
Occlusion occurs when one pointer occludes another pointer in the field of view of an imaging device. In these instances, the image frame captured by that imaging device includes only one pointer. As a result, the correct locations of the pointers relative to the display surface 24 cannot be disambiguated from phantom pointer locations. For example, 
When multiple pointers are moved relative to the display surface 24 in order to input a gesture, depending on the type of gesture and the nature of the touch input used, the need to resolve pointer ambiguity may or may not be necessary as will now be exemplified.
Difficulties in classification arise when an entire hand or multiple fingers from a user's hand are used as a single pointer. When an entire hand is used as a single pointer, during triangulation multiple possible touch point locations for each finger of the hand contacting the display surface 24 are generated. To deal with these scenarios, when an entire hand is used to contact the display surface, all real and imaginary touch points calculated during triangulation in response to the hand contact are clustered together to form a single large touch region. In the case where two separate hands are used as two individual pointers to interact with the display surface 24, all real and imaginary touch points that are calculated during triangulation are also clustered to form a single large touch region.
As one of skill in the art will appreciate, the above discussion highlights only a few examples of gestures that can be made using multiple pointers or multiple hands and that other gestures may be recognized.
In step 1306, if one or more observation from each imaging device exists, a check is made in step 1308 to determine if only one observation from each imaging device exists. If only one observation from each imaging device exists, then in step 1310, the center of the bounding box defined by the intersecting lines of the overlapping observations and hence the pointer location or touch point in (x,y) coordinates is calculated using triangulation. Triangulation is performed in physical measurement units such as centimeters starting at a designated origin, for example, the top left corner of the assembly 22.
Once the position of the touch point is determined an approximation of the size of the touch point is calculated by determining the area of the bounding box. The units of the size measurement are the same as the units of triangulation. The touch point location and size are then stored as original pointer position information for later reference to see if any change in the position of the touch point pointer occurs.
In step 1312, the observations generated by the imaging devices 40 and 42 following processing of the next image frames are acquired. In step 1314, the size of the bounding box defined by the intersecting lines of the overlapping observations that correspond to the touch point identified during processing of the previous observations is compared with a threshold value to determine if the size of the bounding box is much larger than a typical finger. If the size of the bounding box is much larger than an average finger, for example approximately 4 cm in diameter, a hand gesture classification routine (labeled B) is executed as will be described. If the size of the bounding box has not changed or is not larger than an average finger, then in step 1316, it is determined if the touch point has been lost. If the touch point has been lost, a lift of the pointer from the display surface 24 is recognized indicating a left-click and a left-click gesture routine (labeled C) is executed as will be described. If the touch point has not been lost, then in step 1318, it is determined if the observations signify that more than one touch point exists and whether the original touch point was possibly part of a multi-touch gesture or possibly a right-click gesture. If the observations do not signify that more than one touch point exists, then in step 1320, the center of the bounding box and hence the new pointer position is calculated using triangulation. In step 1322, it is then determined if a drag gesture was performed by examining the current and previous touch point locations. If a change in touch position is detected, then a drag gesture routine (labeled D) is executed as will be described. If a change in touch position is not detected, the classification routine returns to step 1312.
If at step 1318 the observations signify that more than one touch point exists, then in step 1324, it is determined if the new touch point occurred to the right of the original touch point. If the new touch point occurred to the right of the original touch point, a potential right-click gesture is recognized and the right-click flag is set in step 1328. If the new potential touch point did not occur to the right of the original touch point or after the right-click flag has been set, the classification routine proceeds to step 1328.
If at step 1308, more than one observation from each imaging device exists, then at step 1328, the bounding boxes representing the touch points are examined to determine if any of the bounding boxes are very large—for example, larger than the average finger width of approximately 4 cm—or whether bounding boxes representing more than two touch points exist. If bounding boxes representing more than two touch points are determined or if a large bounding box is determined, the classification routine recognizes that a cluster gesture has been initiated and the hand gesture classification routine B is executed. If bounding boxes representing two touch points are determined and neither bounding box has a size greater than 4 cm in diameter, then in step 1330, the gesture is recognized as a two-finger gesture and all four possible touch points, including the real pair of touch points and the imaginary pair of touch points as shown in 
As mentioned previously with reference to 
In step 1332, observations generated by the imaging devices 40 and 42 following processing of the next image frames are acquired and the next four touch point positions are triangulated. The results for this next triangulation set are then stored as the next position. In step 1334, it is determined if the observations signify new touch points. If the observations signify new touch points, the classification routine 1300 returns to step 1328. If the observations do not signify any new touch point, then in step 1336, it is determined if any of the touch points has been lost. If a touch point has been lost, then in step 1338, it is determined whether the rightmost touch point was lost and if the right-click flag is set. If the rightmost touch point was lost and the right-click flag is set, then a right-click gesture routine (labeled E) is executed as will be described.
If the right-click flag is not set or if the rightmost touch point was not lost, it is determined that a gesture has been aborted and no gesture is recognized. The classification routine 1300 then proceeds to step 1340 and the observations generated by the imaging devices 40 and 42 following processing of the next image frames are acquired. In step 1342, it is then determined whether either imaging device 40 or 42 sees the pointer and returns an observation. If the pointer is seen by either imaging device, the classification routine 1300 returns to step 1340. If the pointer is no longer seen by the imaging devices 40 and 42, the classification routine returns to step 1302. This forces the user to lift his or her fingers between gestures as the classification routine 1300 will not proceed until there are no observations of pointers. This inhibits transients that occur as the user lifts his or her fingers from the display surface 24, from being interpreted as other gestures.
In step 1336, if no touch points are lost, then in step 1344, movement of the touch points is examined to determine whether a pan gesture has been made as shown in 
In step 1404, observations generated by the imaging devices 40 and 42 following processing of the next image frames are acquired. In step 1406, it is determined whether the observations signify any new touch points appearing at the edges of the bounding box which could not be accounted for by reasonable movement of the pointer(s) between the image frames. If the observations signify such a new touch point, it is assumed that the original touch point position was calculated with transient data and the hand gesture classification returns to step 1402 to start over. If the observations do not signify any new touch points, then in step 1408, it is determined if the touch point has been lost. If the touch point has been lost, then it is assumed that the user's hand lifted from the display surface 24 without performing a gesture and no gesture is recognized. The hand gesture classification routine 1400 is then exited and the classification routine returns to step 1340.
In step 1408, if the touch point has not been lost, then in step 1410, movement of the touch point is examined to determine if a drag gesture has been made. A drag gesture is detected when all four triangulation points of the bounding box move more than a certain threshold of approximately 4 cm in roughly the same direction, plus or minus approximately 45°. If a drag gesture is detected, then in step 1414, a check is made to determine if the touch point size is small enough to be made by a single hand. The threshold size for a single hand is approximately 4 cm. If the touch point size is small enough to be a single hand, then a hand swipe gesture routine (labeled I) is executed as will be described. If the touch point size is not small enough to be made by a single hand, then a hand pan gesture routine (labeled K) is executed as will be described.
If a drag gesture is not detected in step 1410, then in step 1412, movement of the touch points are examined to determine if a zoom gesture has been made. A zoom gesture is detected when the extreme left and extreme right triangulation points of the bounding box both move more than a certain threshold of approximately 4 cm apart from one another for enlarging an object presented on the display surface 24, or together for shrinking an object presented on the display surface 24. If a zoom gesture is detected, then a hand zoom gesture routine (labeled J) is executed as will be described. If a zoom gesture is not detected, then the hand gesture classification routine 1400 returns to step 1404.
If the touch points have not been lost, then in step 1912, a new triangulation set is calculated for the new position of the touch points and a new distance is calculated from the new triangulation set. In step 1914, the change in zoom from the current distance to the new distance is reported to the general purpose computing device 32 by the master controller 30. In step 1916, the current distance is used to replace the new distance. The zoom gesture routine 1900 then returns to step 1906. The zoom gesture routine 1900 only ends when one or both imaging devices loses sight of a pointer. When two touch points contact one another or are brought near each other during the zoom gesture, the interactive input system 20 continues to identify the two touch points instead of creating a single touch point input since the centroid location of the touch points do not change. When the two pointers are touching and in view of the imaging devices 40 and 42, they are then recognized as a single touch point. When the two pointers separate during a zoom gesture, the pointers are resolved into separate touch points as identified in step 1334 and the zoom gesture is recognized in step 1346.
If the direction of the hand swipe is not above the current touch point position, then in step 2116, it is determined if the direction of the hand swipe is below the current touch point position. If the direction of the hand swipe is below the current touch point position, then in step 2118, a swipe-down event is reported to the general purpose computing device 32 by the master controller 30. The hand swipe gesture routine 2100 is then exited and the classification routine returns to step 1340. If the direction of the hand swipe is not below the current touch point position, then in step 2120, it is determined if the direction of the hand swipe is predominantly to the left of the current touch point position. If the direction of the hand swipe is predominantly to the left of the current touch point position, then in step 2122, a swipe-left event is reported to the general purpose computing device 32 by the master controller 30. The hand swipe gesture routine 2100 is then exited and the classification routine returns to step 1340. If the direction of the hand swipe is not predominantly to the left of the current touch point position, then in step 2124, it is determined if the direction of the hand swipe is predominantly to the right of the current touch point position. If the direction of the hand swipe is predominantly to the right of the current touch point position, then in step 2126, a swipe-right event is reported to the general purpose computing device 32 by the master controller 30. The hand swipe gesture routine 2100 is then exited and the classification routine returns to step 1340. If the direction of the hand swipe is not predominantly to the right of the current touch point position, then the hand swipe gesture routine 2100 is exited and the classification routine returns to step 1340 of 
The threshold value assigned at step 2406 is the virtual size of the touch point. In most cases, to improve pointer tracking, the pointer threshold value will be less than the size of the actual pointer and will be located at the centroid of the touch point. Threshold guidelines can be set by the user based on pointer size or type. Pointers below a certain diameter, for example, may be identified as a stylus and given a certain threshold. Pointers above a certain size may be treated as hand gestures and assigned a threshold equal to or larger than the pointer itself to facilitate the grouping of adjacent pointers. Other sizes may be identified as fingers and given thresholds significantly smaller than the actual pointer to avoid accidental pointer merging. In the case of identifying pointers as fingers, the chosen threshold pointer size could be defined as the size of the actual pointer minus a certain multiple of the standard deviation in finger pointer sizes.
Once the threshold value has been assigned in step 2406, or if no new touch points are found at step 2404, step 2408 checks for lost touch points. If no touch points have been lost, the existing touch points, identification numbers and threshold values are retained and output at step 2414.
If a pointer contact is deemed lost at step 2408, step 2410 determines whether two or more pointers have merged. Pointer contacts are deemed to have merged if the threshold values overlap. In the case where a user's fingers touch momentarily, as in the case of a zoom in motion, the threshold pointer sizes, since they are smaller than the actual pointers, will not overlap, and the two pointers will continue to be recognized. In some cases, depending on the threshold values assigned to certain pointer size and types, two or more pointers will be merged into a single, larger pointer. The merged touch point may be identified at step 2412 as a new pointer or it may retain the identity of the largest, oldest, or otherwise most dominant pointer. The unchanged pointer contacts, and the pointers identified at step 2412 are output at 2414.
One of skill in the art will appreciate that interactive input system 20 operates with both passive pointers and active pointers. As mentioned above, a passive pointer is typically one that does not emit any signal when used in conjunction with the interactive input system. Passive pointers may include, for example, fingers, cylinders of material or other objects brought into contact with the display surface 24.
One of skill in the art will also appreciate that while the above gesture detection methods are described with reference to an interactive input system employing two imaging devices that look generally across the display surface 24, the gesture recognition methods may also be applied in an interactive input system using frustrated total internal reflection (FTIR). According to the general principles of FTIR, the total internal reflection (TIR) of light traveling through an optical waveguide is frustrated when an object such as a pointer touches the waveguide surface, due to a change in the index of refraction of the waveguide, causing some light to escape from the touch point. In a multi-touch interactive input system, the machine vision system captures images including the point(s) of escaped light, and processes the images to identify the position of the pointers on the waveguide surface based on the point(s) of escaped light for use as input to application programs.
For example, turning now to 
Cabinet 3016 supports the table top 3012 and touch panel 3014, and houses a processing structure 3020 (see 
Processing structure 3020 in this embodiment is a general purpose computing device in the form of a computer. The computer comprises for example, a processing unit, system memory (volatile and/or non-volatile memory), other non-removable or removable memory (a hard disk drive, RAM, ROM, EEPROM, CD-ROM, DVD, flash memory etc.) and a system bus coupling the various computer components to the processing unit.
During execution of the host software application/operating system run by the processing structure 3020, a graphical user interface comprising a background, upon which graphic widgets are displayed, is presented on the display surface of the touch panel 3014. In this embodiment, the background is a three-dimensional environment, and the graphical user interface is presented on the touch panel 3014, such that three-dimensional graphic widgets in the three-dimensional environment can be manipulated via pointer interaction with the display surface 3015 of the touch panel 3014.
The cabinet 3016 also houses a horizontally-oriented projector 3022, an infrared (IR) filter 3024, and mirrors 3026, 3028 and 3030. An imaging device 3032 in the form of an infrared-detecting camera is mounted on a bracket 3033 adjacent mirror 3028. The system of mirrors 3026, 3028 and 3030 functions to “fold” the images projected by projector 3022 within cabinet 3016 along the light path without unduly sacrificing image size. The overall touch table 3010 dimensions can thereby be made compact.
The imaging device 3032 is aimed at mirror 3030 and thus sees a reflection of the display surface 3015 in order to mitigate the appearance of hotspot noise in captured images that typically must be dealt with in systems having imaging devices that are aimed directly at the display surface 3015. Imaging device 3032 is positioned within the cabinet 3016 by the bracket 3033 so that it does not interfere with the light path of the projected image.
During operation of the touch table 3010, processing structure 3020 outputs video data to projector 3022 which, in turn, projects images through the IR filter 3024 onto the first mirror 3026. The projected images, now with IR light having been substantially filtered out, are reflected by the first mirror 3026 onto the second mirror 3028. Second mirror 3028 in turn reflects the images to the third mirror 3030. The third mirror 3030 reflects the projected video images onto the display (bottom) surface of the touch panel 3014. The video images projected on the bottom surface of the touch panel 3014 are viewable through the touch panel 3014 from above. The system of three mirrors 3026, 3028, 3030 configured as shown provides a compact path along which the projected image can be channeled to the display surface. Projector 3022 is oriented horizontally in order to preserve projector bulb life, as commonly-available projectors are typically designed for horizontal placement.
The projector 3022, and IR-detecting camera 3032 are each connected to and managed by the processing structure 3020. A power supply (not shown) supplies electrical power to the electrical components of the touch table 3010. The power supply may be an external unit or, for example, a universal power supply within the cabinet 3016 for improving portability of the touch table 3010. The cabinet 3016 fully encloses its contents in order to restrict the levels of ambient visible and infrared light entering the cabinet 3016 thereby to facilitate satisfactory signal to noise performance. Doing this can compete with various techniques for managing heat within the cabinet 3016. The touch panel 3014, the projector 3022, and the processing structure are all sources of heat, and such heat if contained within the cabinet 3016 for extended periods of time can create heat waves that can distort the optical components of the touch table 3010. As such, the cabinet 3016 houses heat managing provisions (not shown) to introduce cooler ambient air into the cabinet while exhausting hot air from the cabinet. For example, the heat management provisions may be of the type disclosed in U.S. patent application Ser. No. 12/240,953 to Sirotich et al., filed on Sep. 29, 2008, entitled “TOUCH PANEL FOR AN INTERACTIVE INPUT SYSTEM AND INTERACTIVE INPUT SYSTEM INCORPORATING THE TOUCH PANEL” and assigned to SMART Technologies ULC of Calgary, Alberta, the assignee of the subject application, the content of which is incorporated herein by reference.
As set out above, the touch panel 3014 of touch table 3010 operates based on the principles of frustrated total internal reflection (FTIR), as described further in U.S. patent application Ser. No. 12/240,953 to Sirotich et al., referred to above. 
Touch panel 3014 comprises an optical waveguide 3144 that, according to this embodiment, is a sheet of acrylic. A resilient diffusion layer 3146, in this embodiment a layer of V-CARE® V-LITE® barrier fabric manufactured by Vintex Inc. of Mount Forest, Ontario, Canada, or other suitable material lies against the optical waveguide 3144.
The diffusion layer 3146, when pressed into contact with the optical waveguide 3144, substantially reflects the IR light escaping the optical waveguide 3144 so that escaping IR light travels down into the cabinet 3016. The diffusion layer 3146 also diffuses visible light being projected onto it in order to display the projected image.
Overlying the resilient diffusion layer 3146 on the opposite side of the optical waveguide 3144 is a clear, protective layer 3148 having a smooth touch surface. In this embodiment, the protective layer 3148 is a thin sheet of polycarbonate material over which is applied a hardcoat of Marnot® material, manufactured by Tekra Corporation of New Berlin, Wis., U.S.A. While the touch panel 3014 may function without the protective layer 3148, the protective layer 3148 permits use of the touch panel 14 without undue discoloration, snagging or creasing of the underlying diffusion layer 3146, and without undue wear on users' fingers. Furthermore, the protective layer 3148 provides abrasion, scratch and chemical resistance to the overall touch panel 3014, as is useful for panel longevity.
The protective layer 3148, diffusion layer 3146, and optical waveguide 3144 are clamped together at their edges as a unit and mounted within the table top 3012. Over time, prolonged use may wear one or more of the layers. As desired, the edges of the layers may be unclamped in order to inexpensively provide replacements for the worn layers. It will be understood that the layers may be kept together in other ways, such as by use of one or more of adhesives, friction fit, screws, nails, or other fastening methods.
An IR light source comprising a bank of infrared light emitting diodes (LEDs) 3142 is positioned along at least one side surface of the optical waveguide layer 3144 (into the page in 
In operation, IR light is introduced via the flame-polished side surface of the optical waveguide 3144 in a direction generally parallel to its large upper and lower surfaces. The IR light does not escape through the upper or lower surfaces of the optical waveguide due to total internal reflection (TIR) because its angle of incidence at the upper and lower surfaces is not sufficient to allow for its escape. The IR light reaching other side surfaces is generally reflected entirely back into the optical waveguide 3144 by the reflective tape 3143 at the other side surfaces.
As shown in 
As each touch point is moved along the display surface 3015 of the touch panel 3014, the compression of the resilient diffusion layer 3146 against the optical waveguide 3144 occurs and thus escaping of IR light tracks the touch point movement. During touch point movement or upon removal of the touch point, decompression of the diffusion layer 3146 where the touch point had previously been due to the resilience of the diffusion layer 3146, causes escape of IR light from optical waveguide 3144 to once again cease. As such, IR light escapes from the optical waveguide 3144 only at touch point location(s) allowing the IR light to be captured in image frames acquired by the imaging device.
The imaging device 3032 captures two-dimensional, IR video images of the third mirror 3030. IR light having been filtered from the images projected by projector 3022, in combination with the cabinet 3016 substantially keeping out ambient light, ensures that the background of the images captured by imaging device 3032 is substantially black. When the display surface 3015 of the touch panel 3014 is contacted by one or more pointers as described above, the images captured by IR camera 3032 comprise one or more bright points corresponding to respective touch points. The processing structure 3020 receives the captured images and performs image processing to detect the coordinates and characteristics of the one or more touch points based on the one or more bright points in the captured images. The detected coordinates are then mapped to display coordinates and interpreted as ink or mouse events by the processing structure 3020 for manipulating the displayed image.
The host application tracks each touch point based on the received touch point data, and handles continuity processing between image frames. More particularly, the host application receives touch point data from frames and based on the touch point data determines whether to register a new touch point, modify an existing touch point, or cancel/delete an existing touch point. Thus, the host application registers a Contact Down event representing a new touch point when it receives touch point data that is not related to an existing touch point, and accords the new touch point a unique identifier. Touch point data may be considered unrelated to an existing touch point if it characterizes a touch point that is a threshold distance away from an existing touch point, for example. The host application registers a Contact Move event representing movement of the touch point when it receives touch point data that is related to an existing pointer, for example by being within a threshold distance of, or overlapping an existing touch point, but having a different focal point. The host application registers a Contact Up event representing removal of the touch point from the display surface 3015 of the touch panel 3014 when touch point data that can be associated with an existing touch point ceases to be received from subsequent images. The Contact Down. Contact Move and Contact Up events are passed to respective elements of the user interface such as the graphic widgets, or the background, based on the element with which the touch point is currently associated, and/or the touch points current position. Routines similar to those previously described can be run by the host application allowing the host application to detect multi-pointer gestures.
Another embodiment of the thresholding process 2400 suitable for use in the FTIR interactive input system described above is shown in 
At step 2510, the image is segmented so that only those regions where pointer contacts appear are processed by the system to reduce the processing load. In step 2512, the average brightness and standard deviation of pixels inside each segmented region are calculated, and in step 2514, the threshold of each pointer is set to the average brightness value plus a multiple of the standard deviation in brightness. This threshold is typically set at about 1 standard deviation from the mean. The pointer contact is now represented by a virtual pointer having the threshold size.
In the FTIR system described above, it is possible to estimate the contact pressure applied by a user when touching the touch area by measuring the changing pointer size or brightness. Process 2600 in 
At step 2610, the image is segmented so that only those regions where pointer contacts appear are processed by the system to reduce the processing load. In step 2512, the average brightness and standard deviation of pixels inside each segmented region are calculated. At step 2620, the pressure is estimated using the using the pointer contact brightness calculated in step 2612 and normalized using the upper and lower background levels. The upper background level 2616 is then updated with feedback from the calculated pressure.
At step 2614, a background analysis is performed by averaging the brightness and standard deviation of the background image 2604. At step 2618, the lower background level is set to the average background brightness level minus one standard deviation. At step 2616, the upper background level is set to an arbitrary reasonable default value.
The background image 2504 is continuously updated by blending some areas of the current image devoid of pointers on a frame by frame basis. When pointers dwell beyond a certain threshold time, they are ignored by the pointer recognition software as inactive pointers, such as a hand, mouse, cup, etc. resting on the input surface. When the latent pointer is removed, the background image is updated immediately to allow contact detect in that region.
As mentioned above, the gestures described herein are merely examples of gestures that may be used with the interactive input system. As one of skill in the art will appreciate, other whole hand or multiple touch point gestures that may be used in application associated with such interactive input system can employ similar routines as outlined above.
Rather than employing an illuminated bezel, the assembly may comprise a reflective or retroreflective bezel that reflects radiation emitted by radiation sources associated with the imaging devices so that the imaging devices see white bands in the absence of pointers.
Although, the assembly 22 is described as employing machine vision, the assembly may alternatively employ electromagnetic, capacitive, acoustic or other technologies to register pointer interaction with the display surface 24.
Those of skill in the art will also appreciate that other variations and modifications from those described may be made without departing from the scope and spirit of the invention, as defined by the appended claims.
McGibney, Grant, Tse, Edward, Benner, Erik, Xu, Qizhi Joanna
| Patent | Priority | Assignee | Title | 
| 10945675, | May 24 2017 | SAMSUNG ELECTRONICS CO , LTD | Determining a health status for a user | 
| 11107236, | Apr 22 2019 | Projected augmented reality interface with pose tracking for directing manual processes | |
| 11112872, | Apr 13 2011 | Nokia Technologies Oy | Method, apparatus and computer program for user control of a state of an apparatus | 
| 11740725, | Mar 04 2008 | Apple Inc. | Devices, methods, and user interfaces for processing touch events | 
| 11755196, | Mar 16 2009 | Apple Inc. | Event recognition | 
| 11954322, | Jan 07 2007 | Apple Inc. | Application programming interface for gesture operations | 
| Patent | Priority | Assignee | Title | 
| 5483261, | Feb 14 1992 | ORGPRO NEXUS INC | Graphical input controller and method with rear screen image detection | 
| 6972401, | Jan 30 2003 | SMART Technologies ULC | Illuminated bezel and touch system incorporating the same | 
| 7129927, | Mar 13 2000 | MOTUVERI AB | Gesture recognition system | 
| 7176904, | Mar 26 2001 | Ricoh Company, Limited | Information input/output apparatus, information input/output control method, and computer product | 
| 7411545, | Sep 29 2006 | Honeywell International Inc.; Honeywell International Inc | Carrier phase interger ambiguity resolution with multiple reference receivers | 
| 7411575, | Sep 16 2003 | PIXART IMAGING INC | Gesture recognition method and touch system incorporating the same | 
| 20030076293, | |||
| 20030085871, | |||
| 20060044282, | |||
| 20060244734, | |||
| 20080029691, | |||
| 20090237361, | |||
| 20090273569, | |||
| 20100201631, | |||
| 20130234957, | 
| Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc | 
| Jan 05 2010 | SMART Technologies ULC | (assignment on the face of the patent) | / | |||
| Aug 15 2011 | BENNER, ERIK | SMART Technologies ULC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027017/ | 0299 | |
| Aug 15 2011 | XU, QIZHI JOANNA | SMART Technologies ULC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027017/ | 0299 | |
| Aug 22 2011 | MCGIBNEY, GRANT | SMART Technologies ULC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027017/ | 0299 | |
| Aug 22 2011 | TSE, EDWARD | SMART Technologies ULC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027017/ | 0299 | |
| Jul 31 2013 | SMART TECHNOLOGIES INC | MORGAN STANLEY SENIOR FUNDING INC | SECURITY AGREEMENT | 030935/ | 0848 | |
| Jul 31 2013 | SMART Technologies ULC | MORGAN STANLEY SENIOR FUNDING INC | SECURITY AGREEMENT | 030935/ | 0848 | |
| Oct 03 2016 | MORGAN STANLEY SENIOR FUNDING, INC | SMART Technologies ULC | RELEASE OF TERM LOAN SECURITY INTEREST | 040713/ | 0123 | |
| Oct 03 2016 | MORGAN STANLEY SENIOR FUNDING, INC | SMART TECHNOLOGIES INC | RELEASE OF ABL SECURITY INTEREST | 040711/ | 0956 | |
| Oct 03 2016 | MORGAN STANLEY SENIOR FUNDING, INC | SMART Technologies ULC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 040798/ | 0077 | |
| Oct 03 2016 | MORGAN STANLEY SENIOR FUNDING, INC | SMART TECHNOLOGIES INC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 040798/ | 0077 | |
| Oct 03 2016 | MORGAN STANLEY SENIOR FUNDING, INC | SMART Technologies ULC | RELEASE OF ABL SECURITY INTEREST | 040711/ | 0956 | |
| Oct 03 2016 | MORGAN STANLEY SENIOR FUNDING, INC | SMART TECHNOLOGIES INC | RELEASE OF TERM LOAN SECURITY INTEREST | 040713/ | 0123 | 
| Date | Maintenance Fee Events | 
| Aug 16 2019 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. | 
| Aug 16 2023 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. | 
| Date | Maintenance Schedule | 
| Feb 16 2019 | 4 years fee payment window open | 
| Aug 16 2019 | 6 months grace period start (w surcharge) | 
| Feb 16 2020 | patent expiry (for year 4) | 
| Feb 16 2022 | 2 years to revive unintentionally abandoned end. (for year 4) | 
| Feb 16 2023 | 8 years fee payment window open | 
| Aug 16 2023 | 6 months grace period start (w surcharge) | 
| Feb 16 2024 | patent expiry (for year 8) | 
| Feb 16 2026 | 2 years to revive unintentionally abandoned end. (for year 8) | 
| Feb 16 2027 | 12 years fee payment window open | 
| Aug 16 2027 | 6 months grace period start (w surcharge) | 
| Feb 16 2028 | patent expiry (for year 12) | 
| Feb 16 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |