2011-10-03 09:57:26 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
from kivy.app import App
|
|
|
|
|
|
|
|
from kivy.uix.floatlayout import FloatLayout
|
|
|
|
from kivy.uix.widget import Widget
|
|
|
|
from kivy.uix.button import Button
|
|
|
|
from kivy.graphics import Color, Ellipse, Line
|
|
|
|
from kivy.gesture import Gesture, GestureDatabase
|
|
|
|
|
|
|
|
from my_gestures import cross, circle, check, square
|
|
|
|
|
|
|
|
def simplegesture(name, point_list):
|
2011-10-03 10:09:48 +00:00
|
|
|
"""
|
|
|
|
A simple helper function
|
|
|
|
"""
|
2011-10-03 09:57:26 +00:00
|
|
|
g = Gesture()
|
|
|
|
g.add_stroke(point_list)
|
|
|
|
g.normalize()
|
|
|
|
g.name = name
|
|
|
|
return g
|
|
|
|
|
|
|
|
class GestureBoard(FloatLayout):
|
2011-10-03 10:09:48 +00:00
|
|
|
"""
|
|
|
|
Our application main widget, derived from touchtracer example, use data
|
|
|
|
constructed from touches to match symboles loaded from my_gestures.
|
|
|
|
|
|
|
|
"""
|
2011-10-03 09:57:26 +00:00
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super(GestureBoard, self).__init__()
|
2011-10-03 10:09:48 +00:00
|
|
|
self.gdb = GestureDatabase()
|
|
|
|
|
|
|
|
# add pre-recorded gestures to database
|
2011-10-03 09:57:26 +00:00
|
|
|
self.gdb.add_gesture(cross)
|
|
|
|
self.gdb.add_gesture(check)
|
|
|
|
self.gdb.add_gesture(circle)
|
|
|
|
self.gdb.add_gesture(square)
|
|
|
|
|
|
|
|
def on_touch_down(self, touch):
|
2011-10-03 10:09:48 +00:00
|
|
|
# start collecting points in touch.ud
|
|
|
|
# create a line to display the points
|
2011-10-03 09:57:26 +00:00
|
|
|
userdata = touch.ud
|
|
|
|
with self.canvas:
|
|
|
|
Color(1, 1, 0)
|
|
|
|
d = 30.
|
|
|
|
Ellipse(pos=(touch.x - d/2, touch.y - d/2), size=(d, d))
|
|
|
|
userdata['line'] = Line(points=(touch.x, touch.y))
|
|
|
|
return True
|
|
|
|
|
|
|
|
def on_touch_move(self, touch):
|
2011-10-03 10:09:48 +00:00
|
|
|
# store points of the touch movement
|
2011-10-03 09:57:26 +00:00
|
|
|
try:
|
|
|
|
touch.ud['line'].points += [touch.x, touch.y]
|
|
|
|
return True
|
2012-12-28 15:11:20 +00:00
|
|
|
except (KeyError) as e:
|
2011-10-03 09:57:26 +00:00
|
|
|
pass
|
|
|
|
|
|
|
|
def on_touch_up(self, touch):
|
2011-10-03 10:09:48 +00:00
|
|
|
# touch is over, display informations, and check if it matches some
|
|
|
|
# known gesture.
|
|
|
|
g = simplegesture(
|
|
|
|
'',
|
2012-12-28 15:11:20 +00:00
|
|
|
list(zip(touch.ud['line'].points[::2], touch.ud['line'].points[1::2]))
|
2011-10-03 10:09:48 +00:00
|
|
|
)
|
|
|
|
# gestures to my_gestures.py
|
2012-12-28 15:11:20 +00:00
|
|
|
print("gesture representation:", self.gdb.gesture_to_str(g))
|
2011-10-03 10:09:48 +00:00
|
|
|
|
|
|
|
# print match scores between all known gestures
|
2012-12-28 15:11:20 +00:00
|
|
|
print("cross:", g.get_score(cross))
|
|
|
|
print("check:", g.get_score(check))
|
|
|
|
print("circle:", g.get_score(circle))
|
|
|
|
print("square:", g.get_score(square))
|
2011-10-03 10:09:48 +00:00
|
|
|
|
|
|
|
# use database to find the more alike gesture, if any
|
|
|
|
g2 = self.gdb.find(g, minscore=0.70)
|
|
|
|
|
2012-12-28 15:11:20 +00:00
|
|
|
print(g2)
|
2011-10-03 10:09:48 +00:00
|
|
|
if g2:
|
2012-12-28 15:11:20 +00:00
|
|
|
if g2[1] == circle: print("circle")
|
|
|
|
if g2[1] == square: print("square")
|
|
|
|
if g2[1] == check: print("check")
|
|
|
|
if g2[1] == cross: print("cross")
|
2011-10-03 09:57:26 +00:00
|
|
|
|
2011-10-03 10:09:48 +00:00
|
|
|
# erase the lines on the screen, this is a bit quick&dirty, since we
|
|
|
|
# can have another touch event on the way...
|
2011-10-03 09:57:26 +00:00
|
|
|
self.canvas.clear()
|
|
|
|
|
|
|
|
class DemoGesture(App):
|
|
|
|
def build(self):
|
|
|
|
return GestureBoard()
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
DemoGesture().run()
|
|
|
|
|