This application claims priority to Australian Provisional Application No. 2009904185, filed Sep. 1, 2009 by inventors John Newton and Keith Colson, and entitled “A Method of Determining Touch Locations on a Touch Screen,” the contents of which are incorporated herein by this reference.
The present invention generally relates to position detection, such as detection of one or more touches on a display screen or other touch surface.
Touch-enabled devices allow a user to interface with a computer by touching certain areas of a display screen or other surface and are increasing in demand as more users seek intuitive, easy-to-use interfaces. Such devices may use multiple and simultaneous touches to initiate certain computer events, but existing detection systems may have difficulty detecting the more complex combinations of touches.
For example, an optical position detection system may use one or more optical sensors to register touch locations based on imaging a detection area. A touch point corresponding to a first object can become lost or hidden from the view of optical sensor(s) due to a shadow cast by a second object in the detection area and/or if the second object obscures the first object or its shadow from view. This may occur, for example, when one or both of the first and second objects move during a pinching or dragging motion.
A position detection system includes a memory, at least two optical units configured to image a space, and a processing device interfaced to the memory and the optical units. The processing device is configured to access image data from the first and second optical units and use this data to determine at least one of a current first position and a current second position representing touch points on a display. If both the current first and current second positions can be determined based on the image data, the processing device can define a polygon having at least four sides based on the current first and current second positions and can store a representation of the polygon in the memory. If the processing device can determine only one of the current first position or the current second position based on the accessed image data, the processing device can use the polygon as previously defined to estimate the other position that was not determined using the accessed image data.
The current first position and the current second position can be determined by using detected light, such as light sensed by sensors in the optical units, to locate edges of blockages occurring in a particular space on the display. The edges can be used to determine a centerline between the blockages and the optical units, and the centerlines can be used to determine one or both positions using triangulation. A processing device can determine the current first position and/or the current second position by defining and storing in memory an object model based on the width of the blockage. The processing device can match parameters of the object model to parameters of the detected blockage to determine or estimate the positions.
These illustrative embodiments are mentioned not to limit or define the limits of the present subject matter, but to provide examples to aid understanding thereof. Illustrative embodiments are discussed in the Detailed Description, and further description is provided there. Advantages offered by various embodiments may be further understood by examining this specification and/or by practicing one or more embodiments of the claimed subject matter.
Reference will now be made in detail to various and alternative exemplary embodiments and to the accompanying drawings. Each example is provided by way of explanation, and not as a limitation. It will be apparent to those skilled in the art that modifications and variations can be made. For instance, features illustrated or described as part of one embodiment may be used on another embodiment to yield a still further embodiment. Thus, it is intended that this disclosure includes modifications and variations as come within the scope of the appended claims and their equivalents.
In the following detailed description, numerous specific details are set forth to provide a thorough understanding of the claimed subject matter. However, it will be understood by those skilled in the art that claimed subject matter may be practiced without these specific details. In other instances, methods, apparatuses or systems that would be known by one of ordinary skill have not been described in detail so as not to obscure the claimed subject matter.
Embodiments of the present invention relate to a position detection system for detecting touch points on an optical display screen. Embodiments are described for determining the location of at least two simultaneous touch points at rest and while moving across a display screen. Optical units, a processing device, and a memory can be used to determine the location of touch points on an optical touch screen. Additionally, various algorithms or techniques can be used to calculate the location of the touch points.
In the example of
Fewer or more optical units can be used in other embodiments. According to one embodiment, the optical units 14 and 16 can image a space by emitting light and using a sensor within the optical unit to detect changes in light output levels across the width of the sensor. In some embodiments one or both optical units include at least one light source (e.g., an infrared LED or other source) adjacent the sensor, with the light returned by the retroreflective material in the absence of a blockage. In other embodiments, an external source near the optical units and/or elsewhere can be used, or the optical units 14 and 16 can rely on ambient light reflected by the object(s) and/or light emitted by the objects. As another example, one or more illumination sources may illuminate the space from the edges.
One or more objects (e.g., a user's fingers and/or a stylus) can touch or approach display 12 at a current first position 1 and a current second position 2. The object(s) cast shadows S1-S4 indicated by the dotted lines shown in
The edges can be used to determine a centerline of the blockages, with one such centerline shown in
In one embodiment, the processing device can also determine the current first position 1 and the current second position 2 in part by defining an object model based on the width of the blockage. One or more parameters of the object model can be matched with one or more parameters of the detected blockage to determine an object likely to be causing the blockage. An example of the parameters used to perform the match can be length, width, size, and shape. Other parameters that are common between the object model and the detected blockage can be used to perform the match. The object model can be used to verify whether a subsequently detected blockage matches the expected parameters.
Returning to
If both the current first position and current second position can be determined using the image data, the processing device can store a geometric representation, such as polygon 26, based on the determined the current first position 1 and the current second position 2. For example, polygon 26 can be defined so that the current first and second positions 1 and 2 are located in opposite corners as shown in
As noted above, data used to determine both the current first or second position may not always be available—for example, one of the objects can be lost or hidden from the view of the optical units. The processing device can store the polygon in memory to be later accessed in the event that only one of the current first position 1 or the current second position 2 can be determined from the image data. The available current touch position(s), the polygon, and/or other information can be used to estimate the other current touch position based on an assumption that, even after the movement, the polygon continues to represent a geometric relationship between the positions.
As shown at 502, the method first determines if two touch positions are indicated by the image data. For example, this may be indicated by the presence of two blockages in image data available to one or both imaging units. If two touches are indicated, flow moves to block 504 where the position detection system attempts to determine the first and second positions using the image data.
After the positions are calculated at block 504, flow moves to block 506, which represents storing the positions in memory and defining or updating a geometric representation of the positions in memory. The geometric representation can be stored in memory in various forms. For example, as noted above some embodiments use a polygon having at least four sides, and the polygon may be defined so that the first and second positions are at opposite corners. In one embodiment, the location of pixels defining the sides of the polygon can be stored. As another example, data defining vertices of the polygon and relationships thereof (e.g., distance, index values for the vertices) can be stored along with data indicating which vertices correspond to touch positions. As a further example, defining the polygon may simply comprise storing an indication that a four-sided polygon is present with the first and second positions at opposite corners thereof.
Assume, for the following example, that the position detection system can determine both the current first position 1 and current second position 2 shown in
As another example, the current first and second positions can be identified based on the width of the detected blockages. For example, the width of the blockages as detected at one optical unit can be used to determine a corresponding object model (e.g., a finger, stylus, etc.). The current first and second positions will be those positions whose corresponding blockages have a width consistent with the model as detected at both optical units.
A four-sided polygon 26 may be defined as polygon A-B-C-D by storing coordinate values for each vertex A-D and data indicating that the first and second positions correspond to vertices A and C, respectively. The geometric representation can be stored as a polygon with four sides that are tangent to the edges of the touches as noted above and shown in
Returning to block 502, if two touch positions are not indicated, flow moves to block 508, which represents checking whether two touch positions were calculated previously. If only one touch position was previously calculated, the routine can move to block 510, which represents determining a single touch position. For instance, the routine can use triangulation to determine the single touch position based on identifying an intersection between centerlines of two shadows cast by the object. It is possible that a user input transitions from providing a single-touch input to providing multiple touches, but in the very first iteration the multiple touches are not indicated. In such a scenario, a single touch will be registered until an iteration in which the system can define/update the polygon.
If at block 508 the position detection system determines that two positions were previously calculated, then flow moves to block 512. In this scenario, two touches may be present, but either the current first or second position cannot be determined from the image data. If that is the case, the polygon stored in memory along with the one of the current first or second positions that was determined can be used to estimate the position that could not be determined from the image data by superimposing the polygon.
Block 512 represents superimposing the geometric representation from memory onto the determined current position in a manner that is consistent with available position data (if any) and the available image data. In some embodiments, the object model is also considered when superimposing the geometric representation, such as to ensure that the object, as modeled and at its estimated position, actually fits in the polygon as superimposed or fits with its center at a vertex of the polygon as superimposed in a manner consistent with the image data. Block 514 represents estimating the second current position as that position which, with respect to the superimposed geometric representation, is consistent with the second position's previous relationship with the representation. “Superimposing” is not meant to imply that a visual representation is necessarily generated—suitable in-memory representations of the geometry can be used by the position detection system. Additionally, as will be apparent from the figures, the polygon as superimposed may be of different size or proportion due to movement of one or more of the touch point(s).
In the following example, the four-sided polygon is used to estimate a second position, but embodiments could estimate multiple other positions. In such cases, the geometric representation may be superimposed based on one position calculated from the image data or from multiple positions determined from the image data. For example, in a three-touch scenario two touch locations may be determined from image data, with third estimated by superimposing a polygon. Alternatively, only a first position may be determined from the image data, with the second and third positions determined based on the polygon.
As shown in
Specifically, polygon 26 could be superimposed so that vertex A corresponds to first current position 1 and vertex D corresponds to the adjacent ghost point G1. Alternatively, polygon 26 could be superimposed so that vertex A corresponds to the first current position 1 and vertex B corresponds to the adjacent ghost point G2. In either event, current position 2 could be estimated as the coordinate of vertex C.
The system can superimpose the polygon consistent with the object model defined when both positions were detected using image data. Therefore, although there are multiple scenarios of superimposing the polygon (e.g., with vertex D at current position 1 and vertex C at G2, or with vertex B at current position 1 and vertex C at point G1), the various scenarios can be checked against the object model to determine a scenario of points consistent with the detected blockage widths and the object model. For example, if vertex D were at position 1 and vertex C at G2, then the expected location of current position 2 would be at vertex B. However, the width of the shadow corresponding to G2 (which would result from a blockage at vertex B in this scenario) does not match the expected width—if the blockage were at vertex B, then the detected blockage that has resulted in G2 would be wider.
In the following example, assume that the current first and second positions as shown in
In this example, the polygon cannot be superimposed in a manner consistent with the image data and with current position 1 at vertex A. For instance, assuming one imaging device detects two blockages and one imaging device detects one blockage and current position 1 is the true touch point, the available image data will include either current position 1 and ghost point G1, or current position 1 and ghost point G2. As noted above, although the polygon could be superimposed in a number of scenarios, only one scenario will be consistent with the detected blockage widths.
Returning briefly to block 508, there is a scenario in which two touches may be followed by a single touch. In such a case, in an iteration following the transition from two touches to one touches, the single touch may be identified at block 502, but the system may at block 508 determine that two touches were calculated in the prior iteration. This scenario can be handled in any suitable way. For example, the system may limit the number of consecutive iterations which rely on the polygon to estimate one of the positions. This can avoid erroneously adding an unintended second touch while accounting for the possibility that an intended second touch may be obscured for multiple iterations.
Several of the foregoing examples were described with respect to an optical touch detection system that utilizes shadows and triangulation to determine the first and second touch positions. It will be appreciated that the present techniques could be applied in systems that use other principles to determine the first and second touch positions. For example, resistive and/or capacitive based systems can be used to determine a first and second position, with the geometric representation subsequently used in to update the first or second position if only one such position is subsequently available. As another example, the geometric representation can be used with other optical-based technologies such as those that rely on a grid, total internal reflection within a touched surface, and/or processing of images of the touch area to determine the first and second positions.
Several of the foregoing examples referred to a touch or touch event. It will be understood that the touch or touch event may occur when an object contacts the display or other surface; additionally or alternatively some systems may determine a “touch” even if no contact is made.
Embodiments described herein include computer components, such as processing devices and memory, to implement the described functionality. Persons skilled in the art will recognize that various parameters of each of these components can be used in the position detection system. For example, a processing device can be a microprocessor, DSP, or other device capable of executing computer instructions. A processing device of varying numbers and speeds can be used as the complexity of the position detection system increases. For example, a system with numerous optical units and a highly complex detection algorithm can use a greater number of processing devices. Furthermore, a processing device can communicate with an optical unit via a computer bus according to an exemplary embodiment.
In embodiments, an optical unit can comprise its own processing device, and/or could be interfaced to a CPU of a computing system such as a desktop, laptop, or other computer, a mobile device (e.g., mobile phone, tablet, etc.) via a suitable connection such as a USB bus.
A memory can store data and instructions for implementing the position detection system. Various types of memory, such as RAM, DRAM, and SDRAM, can be used to provide this functionality. The memory can be located external to an optical unit and in a computing system for which the optical unit is used to provide input and/or the optical unit can comprise its own memory, according to some embodiments. Embodiments may store instructions and/or program components in non-transitory computer-readable media including memory devices, optical media (e.g., CD-ROMS, DVDs, etc.), magnetic media (e.g., hard disks, etc.), and the like. As another example, embodiments could use hardware logic (e.g., application-specific integrated circuits (ASICS), field-programmable gate arrays (FPGAs), programmable logic devices (PLDs) etc.) to implement detection logic in addition to or instead of using a processor and software to carry out embodiments of the present subject matter.
It should be understood that the foregoing relates only to certain embodiments of the invention, which are presented by way of example rather than limitation. While the present subject matter has been described in detail with respect to specific embodiments thereof, it will be appreciated that those skilled in the art, upon attaining an understanding of the foregoing may readily produce alterations to, variations of, and equivalents to such embodiments. Accordingly, it should be understood that the present disclosure does not preclude inclusion of such modifications, variations and/or additions to the present subject matter as would be readily apparent to one of ordinary skill in the art upon review of this disclosure.
Number | Date | Country | Kind |
---|---|---|---|
2009904185 | Sep 2009 | AU | national |
Number | Name | Date | Kind |
---|---|---|---|
4144449 | Funk et al. | Mar 1979 | A |
4468694 | Edgar | Aug 1984 | A |
4553842 | Griffin | Nov 1985 | A |
4703316 | Sherbeck | Oct 1987 | A |
4893120 | Doering et al. | Jan 1990 | A |
6285359 | Ogasawara et al. | Sep 2001 | B1 |
6362468 | Murakami et al. | Mar 2002 | B1 |
6518960 | Omura et al. | Feb 2003 | B2 |
6608619 | Omura et al. | Aug 2003 | B2 |
6624833 | Kumar et al. | Sep 2003 | B1 |
6727885 | Ishino et al. | Apr 2004 | B1 |
6760009 | Omura et al. | Jul 2004 | B2 |
7113174 | Takekawa et al. | Sep 2006 | B1 |
7176904 | Satoh | Feb 2007 | B2 |
7283128 | Sato | Oct 2007 | B2 |
7432914 | Kobayashi et al. | Oct 2008 | B2 |
7460110 | Ung et al. | Dec 2008 | B2 |
7515141 | Kobayashi | Apr 2009 | B2 |
7522156 | Sano et al. | Apr 2009 | B2 |
7692625 | Morrison et al. | Apr 2010 | B2 |
7755613 | Morrison et al. | Jul 2010 | B2 |
20020145596 | Vardi | Oct 2002 | A1 |
20050030287 | Sato | Feb 2005 | A1 |
20050104860 | McCreary et al. | May 2005 | A1 |
20060012579 | Sato | Jan 2006 | A1 |
20060202974 | Thielman | Sep 2006 | A1 |
20060232830 | Kobayashi | Oct 2006 | A1 |
20080143682 | Shim et al. | Jun 2008 | A1 |
20090135162 | Van De Wijdeven et al. | May 2009 | A1 |
20090213093 | Bridger | Aug 2009 | A1 |
20090219256 | Newton | Sep 2009 | A1 |
20090278816 | Colson | Nov 2009 | A1 |
20090284495 | Geaghan et al. | Nov 2009 | A1 |
20090309844 | Woo et al. | Dec 2009 | A1 |
20090309853 | Hildebrandt et al. | Dec 2009 | A1 |
20100045629 | Newton | Feb 2010 | A1 |
20100045634 | Su et al. | Feb 2010 | A1 |
20100079412 | Chiang et al. | Apr 2010 | A1 |
20100090987 | Lin et al. | Apr 2010 | A1 |
20100182279 | Juni | Jul 2010 | A1 |
20100193259 | Wassvik | Aug 2010 | A1 |
Number | Date | Country |
---|---|---|
102007021537 | Jun 2008 | DE |
1577745 | Sep 2005 | EP |
2003303046 | Oct 2003 | JP |
WO-2008007276 | Jan 2008 | WO |
WO-2009102681 | Aug 2009 | WO |
WO-2009137355 | Nov 2009 | WO |
WO-2010039663 | Apr 2010 | WO |
WO-2010044575 | Apr 2010 | WO |
Number | Date | Country | |
---|---|---|---|
20110050649 A1 | Mar 2011 | US |