Provided by: ginn_0.2.6-0ubuntu5_amd64 bug

NAME

       ginn - Gesture to Keypress / Mouse Button injector

SYNOPSIS

       ginn [<specific configuration file>]

DESCRIPTION

       ginn is a program to test support gestures in legacy applications without the need to
       rewrite them.  This support is made by injecting keypresses or mouse buttons after
       matching rules from wishes.xml file.

       You can define the matching rules by expressing wishes. Each wish contains the name of the
       gesture, number of fingers, the matching rules.  The keypress to inject is defined by key
       tag, and the mouse button by button, you can add also up to 4 modifiers keys like
       Control_L.

   EXAMPLES
       Sample wishes file:

           <ginn>
           <global>
             <wish gesture="Drag" fingers="2">
               <action name="action5" when="update">
                 <trigger prop="delta y" min="20" max="80"/>
                 <key>Down</key>
               </action>
             </wish>
           </global>
           <applications>
             <application name="inkscape">
               <wish gesture="Pinch" fingers="2">
                 <action name="action1" when="update">
                   <trigger prop="radius delta" min="-200" max="-40"/>
                   <key>KP_Subtract</key>
                 </action>
               </wish>
             </application>
           </applications>
           </ginn>

       Gesture type can be: Drag, Pinch, Rotate or Tap The time of injection can be selected by
       using update to inject when the gesture is received or finish to inject when the gesture
       is finished.  The choice should be written inside the when in the action line.
               <action name="action1" when="update">

       The Open Input Framework gesture stack provide gesture updates which can be very small to
       reach the desired interval specified in the trigger.  To provide more flexibility a
       gesture accumulation is performed by default to the successive property values' updates
       for a desired gesture until it reaches the min-max intervall or the gesture finish, then,
       the accumlation buffer is reinitialized.  If you want to disable this feature you can
       specify it explicitly:
               <trigger prop="delta x" min="-80" max="-40" accumulate="false"/>

       The attributes used in trigger can be obtained by running geistest, you can also refer to
       the list below.  You can use more than one trigger, but you need to use them in the same
       order as they appear in the list below.

           Sub-list of general attributes
            "device id"       = 13
            "timestamp"       = 180598198
            "root window id"  = 254
            "event window id" = 159825921
            "child window id" = 159825921
            "focus x"         = 0.000000
            "focus y"         = 0.000000
            "gesture name"    = "Drag"
            "touches"         = 1

           Sub-list of attributes used with Drag gesture
            "delta x"    = -8.933333
            "delta y"    = 22.000000
            "velocity x" = -0.638095
            "velocity y" = 1.571429
            "position x" = 634.533386
            "position y" = 482.777771

           Sub-list of attributes used with Rotate gesture
            "angle delta"      = -0.358113
            "angular velocity" = -0.029843
            "angle"            = -1.159999

           Sub-list of attributes used with Pinch gesture
            "radius delta"    = -44.935688
            "radial velocity" = -3.209692
            "radius"          = 180.466690

           Sub-list of attributes used with Tap gesture
            "tap time"   = 74.000000
            "position x" = 740.933350
            "position y" = 469.333344

           Last attribues in the general list
            "boundingbox x1" = 634.533386
            "boundingbox y1" = 482.777771
            "boundingbox x2" = 634.533386
            "boundingbox y2" = 482.777771
            "touch 0 id"     = 1079.000000
            "touch 0 x"      = 634.533386
            "touch 0 y"      = 482.777771

       The names of keys list can be obtained after removing the XK_ prefix from
       /usr/include/X11/keysymdef.h file

        The mouse buttons are written with their corresponding number:
           1   Left Button
           2   Middle Button
           3   Right Button
           4   Wheel Up
           5   Wheel Down
           6   Horizontal Wheel Left
           7   Horizontal Wheel Right
           8   "Back" in browsers

FILES

       /etc/ginn/wishes.xml User customized wishes file.

       /usr/share/ginn/wishes.xml Basic ginn wishes file installed for reference.

SEE ALSO

       geistest

AUTHOR

       Mohamed Ikbel Boulabiar <boulabiar@gmail.com>

COPYRIGHT

       Copyright 2010-2011 by Canonical, Ltd.

                                            2012-07-30                                    GINN(1)