forked from hoverlabs/hover_raspberrypi
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathHover_example.py
102 lines (92 loc) · 3.69 KB
/
Hover_example.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
# ===========================================================================
# This is an example for Hover.
#
# Hover is a development kit that lets you control your hardware projects in a whole new way.
# Wave goodbye to physical buttons. Hover detects hand movements in the air for touch-less interaction.
# It also features five touch-sensitive regions for even more options.
# Hover uses I2C and 2 digital pins. It is compatible with Arduino, Raspberry Pi and more.
#
# Hover can be purchased here: http://www.justhover.com
#
# Written by Emran Mahbub and Jonathan Li for Gearseven Studios.
# BSD license, all text above must be included in any redistribution
# ===========================================================================
#
# HOOKUP GUIDE (For Raspberry Pi)
#
# =============================
# | 1 2 3 4 5 6 7 |
# | HOVER |
# | |
# | +++++++++++++++++++++++++++ |
# | + + |
# | + + |
# | * + |
# | * + |
# | * + |
# |_+++++++++++++++++++++++++++_|
#
# PIN 1 - HOST_V+ ---- 3V3 pin
# PIN 2 - RESET ---- Any Digital Pin. This example uses GPIO 24 (BCM Mode).
# PIN 3 - SCL ---- SCL pin
# PIN 4 - SDA ---- SDA pin
# PIN 5 - GND ---- Ground Pin
# PIN 6 - 3V3 ---- 3V3 pin
# PIN 7 - TS ---- Any Digital Pin. This example uses GPIO 23 (BCM Mode).
#
# =============================================================================
#
# OUTPUT DEFINITION
# The message variable outputs an 8-bit binary value to indicate the event type, gesture direction, and tap location.
# Upper 3 bits indicates the event type: gesture or tap.
# Lower 5 bits indicates the gesture direction or tap location.
#
# EVENT TYPE DIRECTION
# 000 00000
# ---------------------------------------------------------
# GESTURES DIRECTION FOR GESTURE
# 001 00010 - Right Swipe
# 00100 - Left Swipe
# 01000 - Up Swipe
# 10000 - Down Swipe
#
# TAP DIRECTION FOR TAP
# 010 00001 - South Tap
# 00010 - West Tap
# 00100 - North Tap
# 01000 - East Tap
# 10000 - Center Tap
# ----------------------------------------------------------
#
# HISTORY
# v1.0 - Initial Release
#
# INSTALLATION
# Place the Hover_library.py file in the same folder as the Hover_example.py file.
# Then run Hover_example.py by typing: sudo python Hover_example.py
#
# SUPPORT
# For questions and comments, email us at [email protected]
#
# ============================================================================================================
import time
from Hover_library import Hover
hover = Hover(address=0x42, ts=23, reset=24)
try:
while True:
# Check if hover is ready to send gesture or touch events
if (hover.getStatus() == 0):
# Read i2c data and print the type of gesture or touch event
event = hover.getEvent()
if event is not None:
print event,
print "= " + hover.getEventString(event) #This line can be commented out if you don't want to see the event in text format
# Release the ts pin until Hover is ready to send the next event
hover.setRelease()
time.sleep(0.001) #sleep for 1ms
except KeyboardInterrupt:
print "Exiting..."
hover.end()
except:
print "Something has gone wrong...:("
hover.end()