The present invention relates to interpretation of certain inputs on a touch sensing device, and in particular to interpretation of gestures comprising pressure or force.
Touch sensing systems (“touch systems”) are in widespread use in a variety of applications. Typically, the touch systems are actuated by a touch object such as a finger or stylus, either in direct contact, or through proximity (i.e. without contact), with a touch surface. Touch systems are for example used as touch pads of laptop computers, in control panels, and as overlays to displays on e.g. hand held devices, such as mobile telephones. A touch panel that is overlaid on or integrated in a display is also denoted a “touch screen”. Many other applications are known in the art.
To an increasing extent, touch systems are designed to be able to detect two or more touches simultaneously, this capability often being referred to as “multi-touch” in the art.
There are numerous known techniques for providing multi-touch sensitivity, e.g. by using cameras to capture light scattered off the point(s) of touch on a touch panel, or by incorporating resistive wire grids, capacitive sensors, strain gauges, etc into a touch panel.
WO2011/028169 and WO2011/049512 disclose multi-touch systems that are based on frustrated total internal reflection (FTIR). Light sheets are coupled into a panel to propagate inside the panel by total internal reflection (TIR). When an object comes into contact with a touch surface of the panel, the propagating light is attenuated at the point of touch. The transmitted light is measured at a plurality of outcoupling points by one or more light sensors. The signals from the light sensors are processed for input into an image reconstruction algorithm that generates a 2D representation of interaction across the touch surface. This enables repeated determination of current position/size/shape of touches in the 2D representation while one or more users interact with the touch surface. Examples of such touch systems are found in U.S. Pat. No. 3,673,327, U.S. Pat. No. 4,254,333, U.S. Pat. No. 6,972,753, US2004/0252091, US2006/0114237, US2007/0075648, WO2009/048365, US2009/0153519, WO2010/006882, WO2010/064983, and WO2010/134865.
In touch systems in general, there is a desire to not only determine the location of the touching objects, but also to estimate the amount of force by which the touching object is applied to the touch surface. This estimated quantity is often referred to as “pressure”, although it typically is a force. Examples of touch force estimation in connection to a FTIR based touch-sensing apparatus is disclosed in the Swedish application SE-1251014-5. An increased pressure is here detected by an increased contact, on a microscopic scale, between a touching object and a touch surface with increasing application force. This increased contact may lead to a better optical coupling between the transmissive panel and the touching object, causing an enhanced attenuation (frustration) of the propagating radiation at the location of the touching object.
The touch technology gives the possibility to use new gestures for controlling different functions or graphical objects on a touch screen. The use of gestures may simplify work for users in different professions or in their hobbies. For example may the user make use of the touch technology when editing photos or other graphical objects. If an input device such as a mouse shall be used for editing, a lot of the user experience is lost and it is only possible to point at one location at the same time. If the user instead directly can interact with the graphical objects with his or her fingers the editing becomes more intuitive and may also become faster. From e.g. U.S. Pat. No. 8,238,784B2 it is known to zoom in and out of a graphical object using two fingers. For the editing purpose it might be a desire to also choose a certain area of the graphical object.
The object of the invention is thus to provide a gesture to enable editing work using touch technology, wherein the gesture includes pressure.
According to a first aspect, the object is at least partly achieved with a method according to the first independent claim. The method comprises receiving touch input data indicating touch inputs on a touch surface of a touch sensing device, and determining from said touch input data:
With the method, the user is provided with a tool, i.e. a gesture, to make layout work, image editing, etc more efficient and easy when working on a touch sensing device capable of sensing multiple simultaneous touches. With the method, the user can enlarge (zoom in) a certain detail in an image, i.e. a graphical element, and crop it such that a new image is defined with the enlarged detail. The enlarged detail, i.e. the cropped element, may then be transferred to another place, e.g. to a place in an album or newspaper.
By increasing the size of the first area is meant zooming into the first area. By decreasing the size of the first area is meant zooming out of the first area. Thus, the scale of the first area is changed. In other words, the perspective of the first area is changed. The zooming is according to one embodiment geometric zooming, i.e. where objects in the first area changes according to their size. According to another embodiment, the zooming is semantic zooming, where objects in the first area are changed according to their size and in addition modifies the selection and/or structure of data being displayed. Semantic zooming is typically used for maps.
According to one embodiment, the method comprises cropping the first area of the graphical element in relation to the attained decreased distance upon determining from the touch input data that an increased pressure compared to a threshold of at least one of the first and second touch inputs has occurred. Thus, the user can choose when the cropped element shall be defined by pressing on the touch surface.
According to another embodiment, the method comprises cropping the first area of the graphical element in relation to the attained decreased distance upon determining from said touch input data that at least one of the first and second objects is not present anymore on the touch surface. Thus, the user can choose when the cropped element shall be defined by lifting the first and/or the second object from the touch surface.
According to a further embodiment, the method comprises continuously cropping the first area of the graphical element in accordance with the decreased distance. Thus, the user will continuously see how the graphical element is cropped.
According to a further embodiment, the increasing or decreasing of the size comprises increasing or decreasing the size of the first area to a size based on the distance between the first and second objects. Thus, the first area may be increased or decreased in relation to the distance between the first and second objects. The increase or decrease of the size may directly correspond to the distance, or may be an increase or decrease scaled with a factor.
According to one embodiment, the method comprises visually indicating the first area. Thus, the first area may be highlighted to the user such that it is easily recognized. For example, visually indicating the first area comprises visually presenting the first area of the graphical element in relation to the cropped element of the graphical element. Thus, the cropped element can be easily recognized in relation to the rest of the graphical element, if any.
According to a second aspect, the object is at least partly achieved with a gesture interpretation unit comprising a processor configured to receive a touch signal sx comprising touch input data indicating touch inputs on a touch surface of a touch sensing device, the gesture interpretation unit further comprising a computer readable storage medium storing instructions operable to cause the processor to perform operations comprising determining from said touch input data:
The gesture interpretation unit thus receives touch data with information of touches on the touch surface, and if the touch data has certain characteristics, the gesture interpretation engine generates signals to make the selected graphical element react in certain ways to the touch data. The user is now provided with a gesture for simplify editing etc.
The gesture interpretation unit preferably comprises instructions for generating the first signal for increasing the size of the first area to a size defined by the positions of the first and second objects, and instructions for generating the second signal for decreasing the size of the first area to a size defined by the positions of the first and second objects. As understood, the gesture interpretation unit may comprise instructions for generating a plurality of other signals for manipulating the graphical element, for cropping, for visually presenting the cropped element on the touch surface etc.
Also, several users may interact with different graphical elements at the same time on the same GUI and touch surface.
When in the description it is referred to a pressure, it can equally mean a force.
According to a third aspect, the object is at least partly achieved with a touch sensing device comprising:
According to one embodiment, the touch sensing device is an FTIR-based (Frustrated Total Internal Reflection) touch sensing device.
The positioning data may for example be a geometrical centre of a touch input. The pressure data may be the total pressure, or force, of the touch input. According to another embodiment, the pressure data is a relative pressure, or force.
According to a fourth aspect, the object is at least partly achieved with a computer readable storage medium comprising computer programming instructions which, when executed on a processor, are configured to carry out the method as described herein.
Any of the above-identified embodiments of the method may be adapted and implemented as an embodiment of the second, third and/or fourth aspects. Thus, the gesture interpretation unit may include instructions to carry out any of the methods as described herein.
Preferred embodiments are set forth in the dependent claims and in the detailed description.
Below the invention will be described in detail with reference to the appended figures, of which:
1. Device
The touch surface 14 may be part of a touch sensitive display, a touch sensitive screen or a light transmissive panel 25 (
The touch surface 14 is configured to receive touch inputs from one or several users. A touch input is an interaction between a touch object and the touch arrangement 2. An “interaction” occurs when the touch object affects a parameter measured by a sensor as will later be exemplified. The touch arrangement 2, the touch surface 14 and the touch control unit 15 together with any necessary hardware and software, depending on the touch technology used, detect the touch inputs. The touch arrangement 2, the touch surface 14 and touch control unit 15 may also detect touch input including movement of the touch inputs using any of a plurality of known touch sensing technologies capable of detecting simultaneous contacts with the touch surface 14. Such technologies include capacitive, resistive, infrared, and surface acoustic wave technologies. An example of a touch technology which uses light propagating inside a panel will be explained in connection with
The touch arrangement 2 is configured to generate and send the touch inputs as one or several signals sy to the touch control unit 15. The touch control unit 15 is configured to receive the one or several signals sy and comprises software and hardware to analyse the received signals sy, and to determine touch input data including sets of positions xnt, ynt with associated pressure pt on the touch surface 14 by processing the signals sy. Each set of touch input data xnt, ynt, pnt, may also include identification, an ID, identifying to which touch input the data pertain. Here “n” denotes the identity of the touch input. If the touch input is still or moved over the touch surface 14, without losing contact with it, a plurality of touch input data xnt, ynt, pnt with the same ID will be determined. If the touch input is taken away from the touch surface 14, there will be no more touch input data with this ID. Touch input data from a touch input may also comprise an area ant of the touch. A position xnt, ynt referred to herein is then preferably a centre of the area ant. A position may also be referred to as a location. The touch control unit 15 is further configured to generate one or several touch signals sx comprising the touch input data, and to send the touch signals sx to a processor 12 in the gesture interpretation unit 13. The processor 12 may e.g. be a computer programmable unit (CPU). The gesture interpretation unit 13 also comprises a computer readable storage medium 11, which may include a volatile memory such as high speed random access memory (RAM-memory) and/or a non-volatile memory such as a flash memory.
The computer readable storage medium 11 comprises a touch module 16 (or set of instructions), and a graphics module 17 (or set of instructions). The computer readable storage medium 11 comprises computer programming instructions which, when executed on the processor 12, are configured to carry out the method according to any of the steps described herein. These instructions can be seen as divided between the modules 16, 17. The computer readable storage medium 11 may also store received touch input data comprising positions xnt, ynt on the touch surface 14 and pressures pt of the touch inputs. The touch module 16 includes instructions to determine from the touch input data if the touch inputs have certain characteristics, such as being in a predetermined relation to each other and/or a graphical element 1, and/or if they are at a certain distance from each other, and/or if one or several of the touch inputs are moving, and/or if continuous contact with the touch surface 14 is maintained or is stopped, and/or the pressure of the one or several touch inputs. The touch module 16 thus keeps track of the touch inputs. Determining movement of a touch input may include determining a speed (magnitude), velocity (magnitude and direction) and/or acceleration (magnitude and/or direction) of the touch input or inputs.
The graphics module 17 includes instructions for rendering and displaying graphics via the GUI. The graphics module 17 controls the position, movements, and actions etc. of the graphics. More specifically, the graphics module 17 includes instructions for displaying at least one graphical element 1 (
The gesture interpretation unit 13 may thus be incorporated in any known touch sensing device 3 with a touch surface 14, wherein the device 3 is capable of presenting the graphical element 1 via a GUI seen from the touch surface 14, detect touch inputs on the touch surface 14 and to generate and deliver touch input data to the processor 12. The gesture interpretation unit 13 is then incorporated into the device 3 such that it can process the graphical element 1 in predetermined ways when certain touch data has been determined.
2. Gesture
As a first step A1, the user makes a first touch input 4 to the touch surface 14 (
The user further makes a second touch input 7 to the touch surface 14 with a second object 8 (A3). The second touch input 7 from the second object 8 is then determined from the touch input data to be at a second position 9 on the touch surface 14 (A4). The first and second touch inputs 4, 7 do not have to come in a specific order as indicated in the flow chart of
The first area 10 may be an area limited by the first and second positions 6, 9 or a predetermined distance from the first and second positions 6, 9. For example, if the first area 10 has a rectangular shape, the sides of the rectangle may initially be positioned a distance away from the first and second positions 6, 9, e.g. a distance between 1-10 centimetres. If the first area 10 has a circular shape, the border of the circle may initially be positioned a distance between 1-10 centimetres from the first and second positions, respectively.
Depending on user preference, any of the described alternatives may be set beforehand. If the first and second objects 5, 8 are moved against each other, the distance between the objects 5, 8 decreases. Correspondingly, if the user moves the first and second objects 5, 8 apart from each other, the distance between the objects 5, 8 increases. The gesture interpretation unit 13 is thus configured to compare the distance between the first and second objects 5, 8, i.e. the distance between the first and second positions 6, 9 of the objects 5, 8, with the determined distance in a previous time step, and to generate signals to increase or decrease the size of the first area 10 in response to the result of the comparison. These signals are illustrated as sz in
As illustrated in the flowchart of
The cropped element 23 now defines a selected view and in some embodiments a zoomed in view of a certain detail of the graphical element 1. The cropped element 23 can e.g. now be moved to a certain location by pointing with an object on the cropped element 23 and moving the element 23 in accordance with the movement of the object. The cropped element 23 may instead be dragged and dropped to a certain location.
In step A12 the first area 10 of the graphical element 1 may be cropped in relation to the attained decreased distance upon determining from the touch input data that an increased pressure compared to a threshold of at least one of the first and second touch inputs 4, 7 has occurred. Thus, first when the user in this step presses on the touch surface 14 with the first and/or the second objects 5, 8, the cropped element 23 is defined. According to another embodiment, the first area 10 of the graphical element 1 is cropped in relation to the attained decreased distance upon determining from the touch input data that at least one of the first and second objects 5, 8 is not present anymore on the touch surface 14. Thus, if any or both of the first and second objects 5, 8 makes a “touch up”, thus leaves the touch surface 14, the cropped element 23 is defined. According to a further embodiment, the method comprises continuously cropping the first area 10 of the graphical element 1 in accordance with the decreased distance. The user may then continuously see how large the cropped element 23 will be.
As a response to the increased pressure, or if a “touch up” is made as described, the cropped element 23 may automatically be transferred to a certain location.
To make it easier for the user to see the various areas during zooming (zoom in and zoom out) and cropping, the areas and/or their surroundings may be visually indicated. For example, the method may comprise to visually indicate the first area 10, and/or the cropped element 23. The visual indication may for example include presenting a frame around any of the areas. According to one embodiment, the method comprises visually presenting the first area 10 of the graphical element 1 in relation to the cropped element 23 of the graphical element 1. The cropped element 23 will thus be a subset of the first area 10 of the graphical element 1, and the area between the cropped element and the first area 10 may thus be visually indicated to emphasise the cropped element 23. For example may the area be coloured, e.g. in grey, white or any other colour.
As illustrated in
The user is now satisfied with the enlargement of the first area 10, and presses with both fingers 5, 8, against the touch surface 14 with the pressures P1 and P2 as illustrated in FIG. 3D. This action halts, i.e. stops, the possibility of zooming the first area 10 more, and a distance d2 between the fingers 5, 8 is determined. The distance d2 is thus determined to be between the positions of the fingers 5, 8 at the same time instance as the pressures P1 and P2 are determined. The user now moves the fingers 5, 8 against each other as illustrated in
3. Touch Technology Based on FTIR
As explained before, the invention can be used together with several kinds of touch technologies. One kind of touch technology based on FTIR will now be explained. The touch technology can advantageously be used together with the invention to deliver touch input data xnt, ynt, pnt to the processor 12 of the gesture interpretation unit 13 (
In
As shown in the
The location of the touching objects 21, 22 may be determined by measuring the energy of light transmitted through the panel 25 on a plurality of detection lines. This may be done by e.g. operating a number of spaced apart light emitters 19 to generate a corresponding number of light sheets into the panel 25, and by operating the light detectors 20 to detect the energy of the transmitted energy of each light sheet. The operating of the light emitters 19 and light detectors 20 may be controlled by a touch processor 26. The touch processor 26 is configured to process the signals from the light detectors 20 to extract data related to the touching object or objects 21, 22. The touch processor 26 is part of the touch control unit 15 as indicated in the figures. A memory unit (not shown) is connected to the touch processor 26 for storing processing instructions which, when executed by the touch processor 26, performs any of the operations of the described method.
The light detection arrangement may according to one embodiment comprise one or several beam scanners, where the beam scanner is arranged and controlled to direct a propagating beam towards the light detector(s).
As indicated in
The detectors 20 collectively provide an output signal, which is received and sampled by the touch processor 26. The output signal contains a number of sub-signals, also denoted “projection signals”, each representing the energy of light emitted by a certain light emitter 19 and received by a certain light sensor 20. Depending on implementation, the processor 26 may need to process the output signal for separation of the individual projection signals. As will be explained below, the processor 26 may be configured to process the projection signals so as to determine a distribution of attenuation values (for simplicity, referred to as an “attenuation pattern”) across the touch surface 14, where each attenuation value represents a local attenuation of light.
4. Data Extraction Process in an FTIR System
Each frame starts by a data collection step B1, in which measurement values are obtained from the light detectors 20 in the FTIR system, typically by sampling a value from each of the aforementioned projection signals. The data collection step B1 results in one projection value for each detection line. It may be noted that the data may, but need not, be collected for all available detection lines in the FTIR system. The data collection step B1 may also include pre-processing of the measurement values, e.g. filtering for noise reduction.
In a reconstruction step B2, the projection values are processed for generation of an attenuation pattern. Step B2 may involve converting the projection values into input values in a predefined format, operating a dedicated reconstruction function on the input values for generating an attenuation pattern, and possibly processing the attenuation pattern to suppress the influence of contamination on the touch surface (fingerprints, etc.).
In a peak detection step B3, the attenuation pattern is then processed for detection of peaks, e.g. using any known technique. In one embodiment, a global or local threshold is first applied to the attenuation pattern, to suppress noise. Any areas with attenuation values that fall above the threshold may be further processed to find local maxima. The identified maxima may be further processed for determination of a touch shape and a center position, e.g. by fitting a two-dimensional second-order polynomial or a Gaussian bell shape to the attenuation values, or by finding the ellipse of inertia of the attenuation values. There are also numerous other techniques as is well known in the art, such as clustering algorithms, edge detection algorithms, standard blob detection, water shedding techniques, flood fill techniques, etc. Step B3 results in a collection of peak data, which may include values of position, attenuation, size, and shape for each detected peak. The attenuation may be given by a maximum attenuation value or a weighted sum of attenuation values within the peak shape.
In a matching step B4, the detected peaks are matched to existing traces, i.e. traces that were deemed to exist in the immediately preceding frame. A trace represents the trajectory for an individual touching object on the touch surface as a function of time. As used herein, a “trace” is information about the temporal history of an interaction. An “interaction” occurs when the touch object affects a parameter measured by a sensor. Touches from an interaction detected in a sequence of frames, i.e. at different points in time, are collected into a trace. Each trace may be associated with plural trace parameters, such as a global age, an attenuation, a location, a size, a location history, a speed, etc. The “global age” of a trace indicates how long the trace has existed, and may be given as a number of frames, the frame number of the earliest touch in the trace, a time period, etc. The attenuation, the location, and the size of the trace are given by the attenuation, location and size, respectively, of the most recent touch in the trace. The “location history” denotes at least part of the spatial extension of the trace across the touch surface, e.g. given as the locations of the latest few touches in the trace, or the locations of all touches in the trace, a curve approximating the shape of the trace, or a Kalman filter. The “speed” may be given as a velocity value or as a distance (which is implicitly related to a given time period). Any known technique for estimating the tangential speed of the trace may be used, taking any selection of recent locations into account. In yet another alternative, the “speed” may be given by the reciprocal of the time spent by the trace within a given region which is defined in relation to the trace in the attenuation pattern. The region may have a pre-defined extent or be measured in the attenuation pattern, e.g. given by the extent of the peak in the attenuation pattern.
The matching step B4 may be based on well-known principles and will not be described in detail. For example, step B4 may operate to predict the most likely values of certain trace parameters (location, and possibly size and shape) for all existing traces and then match the predicted values of the trace parameters against corresponding parameter values in the peak data produced in the peak detection step B3. The prediction may be omitted. Step B4 results in “trace data”, which is an updated record of existing traces, in which the trace parameter values of existing traces are updated based on the peak data. It is realized that the updating also includes deleting traces deemed not to exist (caused by an object being lifted from the touch surface 14, “touch up”), and adding new traces (caused by an object being put down on the touch surface 14, “touch down”).
Following step B4, the process returns to step B1. It is to be understood that one or more of steps B1-B4 may be effected concurrently. For example, the data collection step B1 of a subsequent frame may be initiated concurrently with any one of the steps B2-B4.
The result of the method steps B1-B4 is trace data, which includes data such as positions (xnt, ynt) for each trace. This data has previously been referred to as touch input data.
5. Detect Pressure The current attenuation of the respective trace can be used for estimating the current application force for the trace, i.e. the force by which the user presses the corresponding touching object against the touch surface. The estimated quantity is often referred to as a “pressure”, although it typically is a force. The process is described in more detail in the above-mentioned application No. 1251014-5. It should be recalled that the current attenuation of a trace is given by the attenuation value that is determined by step B2 (
According to one embodiment, a time series of estimated force values is generated that represent relative changes in application force over time for the respective trace. Thereby, the estimated force values may be processed to detect that a user intentionally increases or decreases the application force during a trace, or that a user intentionally increases or decreases the application force of one trace in relation to another trace.
Thus, each trace now also has force values, thus, the trace data includes positions (xnt, ynt) and forces (also referred to as pressure) (pnt) for each trace. These data can be used as touch input data to the gesture interpretation unit 13 (
The present invention is not limited to the above-described preferred embodiments. Various alternatives, modifications and equivalents may be used. Therefore, the above embodiments should not be taken as limiting the scope of the invention, which is defined by the appending claims.
This application claims priority under 35 U.S.C. §119 to U.S application No. 61/765,158 filed on Feb. 15, 2013, the entire contents of which are hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
61765158 | Feb 2013 | US |