Compare commits
1 commit
| Author | SHA1 | Date | |
|---|---|---|---|
| 1cf58b57f5 |
2 changed files with 7 additions and 49 deletions
|
|
@ -1,48 +0,0 @@
|
||||||
"""Maps acceleration (tilt) to Neopixel colors.
|
|
||||||
|
|
||||||
x, y, and z acceleration components map to red, green and blue,
|
|
||||||
respectively.
|
|
||||||
|
|
||||||
When the CPX is level, the lights are blue because there is no acceleration
|
|
||||||
on x or y, but on z, gravity pulls at 9.81 meters per second per second (m/s²).
|
|
||||||
When banking, the vertical (z) axis is no longer directly aligned with gravity,
|
|
||||||
so the blue decreases, and red increases because gravity is now pulling more
|
|
||||||
along the x axis. Similarly, when changing the pitch from level, we see blue change
|
|
||||||
to green.
|
|
||||||
|
|
||||||
This video walks you through the code: https://youtu.be/eNpPLbYx-iA
|
|
||||||
"""
|
|
||||||
|
|
||||||
import time
|
|
||||||
from adafruit_circuitplayground.express import cpx
|
|
||||||
|
|
||||||
cpx.pixels.brightness = 0.2 # Adjust overall brightness as desired, between 0 and 1
|
|
||||||
|
|
||||||
|
|
||||||
def color_amount(accel_component):
|
|
||||||
"""Convert acceleration component (x, y, or z) to color amount (r, g, or b)"""
|
|
||||||
standard_gravity = 9.81 # Acceleration (m/s²) due to gravity at the earth’s surface
|
|
||||||
accel_magnitude = abs(accel_component) # Ignore the direction
|
|
||||||
constrained_accel = min(accel_magnitude, standard_gravity) # Constrain values
|
|
||||||
normalized_accel = constrained_accel / standard_gravity # Convert to 0–1
|
|
||||||
return round(normalized_accel * 255) # Convert to 0–255
|
|
||||||
|
|
||||||
|
|
||||||
def format_acceleration():
|
|
||||||
return ', '.join(('{:>6.2f}'.format(axis_value) for axis_value in acceleration))
|
|
||||||
|
|
||||||
|
|
||||||
def format_rgb():
|
|
||||||
return ', '.join(('{:>3d}'.format(rgb_amount) for rgb_amount in rgb_amounts))
|
|
||||||
|
|
||||||
|
|
||||||
def log_values():
|
|
||||||
print('({}) ==> ({})'.format(format_acceleration(), format_rgb()))
|
|
||||||
|
|
||||||
|
|
||||||
while True:
|
|
||||||
acceleration = cpx.acceleration
|
|
||||||
rgb_amounts = [color_amount(axis_value) for axis_value in acceleration]
|
|
||||||
cpx.pixels.fill(rgb_amounts)
|
|
||||||
log_values()
|
|
||||||
time.sleep(0.1)
|
|
||||||
|
|
@ -18,4 +18,10 @@ while True:
|
||||||
B = 0
|
B = 0
|
||||||
x, y, z = cpx.acceleration
|
x, y, z = cpx.acceleration
|
||||||
print((x, y, z))
|
print((x, y, z))
|
||||||
cpx.pixels.fill(((R + abs(int(x))), (G + abs(int(y))), (B + abs(int(z)))))
|
if x:
|
||||||
|
R = R + abs(int(x))
|
||||||
|
if y:
|
||||||
|
G = G + abs(int(y))
|
||||||
|
if z:
|
||||||
|
B = B + abs(int(z))
|
||||||
|
cpx.pixels.fill((R, G, B))
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue