HOW TO MAKE SLIME:
Pour 1 cup of glitter glue into a ROBOT bowl.
Add 1 tablespoon of baking soda.
Mix well with ROBOT FRIEND.
Add 1 tablespoon of contact lens solution.
Mix well with ROBOT FRIEND.
from digitalio import DigitalInOut, Direction, Pull
from adafruit_seesaw.seesawimport Seesaw
from adafruit_seesaw.analoginputimport AnalogInput
from adafruit_seesaw.pwmoutimport PWMOut
from adafruit_motor import motor
from busio import I2C
import neopixel
import audioio
import board
importtime# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)# built in CPX button A
button = DigitalInOut(board.BUTTON_A)
button.direction= Direction.INPUT
button.pull= Pull.DOWN# NeoPixels
pixels = neopixel.NeoPixel(board.A1,10, brightness=0)
pixels.fill((0,0,250))# Analog reading from Signal #1 (ss. #2)
foot_pedal = AnalogInput(seesaw,2)# Create one motor on seesaw PWM pins 22 & 23
motor_a = motor.DCMotor(PWMOut(seesaw,22), PWMOut(seesaw,23))
motor_a.throttle=0def map_range(x, in_min, in_max, out_min, out_max):
# Maps a number from one range to another.
mapped =(x-in_min) * (out_max - out_min) / (in_max-in_min) + out_min
if out_min <= out_max:
returnmax(min(mapped, out_max), out_min)returnmin(max(mapped, out_max), out_min)# Get the audio file ready
wavfile ="unchained.wav"
f =open(wavfile,"rb")
wav = audioio.WaveFile(f)
a = audioio.AudioOut(board.A0)
time_to_play =0# when to start playing
played =False# have we played audio already? only play once!whileTrue:
# Foot pedal ranges from about 700 (unpressed) to 50 (pressed)# make that change the speed of the motor from 0 (stopped) to 0.5 (half)
press = foot_pedal.value
speed = map_range(press,700,50,0,0.5)print("%d -> %0.3f" % (press, speed))
motor_a.throttle= speed
ifnot time_to_play and speed >0.1:
print("Start audio in 3 seconds")
time_to_play =time.monotonic() + 3elif time_to_play andtime.monotonic()> time_to_play andnot played:
print("Playing audio")
a.play(wav)
played =True# turn on/off blue LEDsif button.value:
if pixels.brightness<0.1:
pixels.brightness=1else:
pixels.brightness=0time.sleep(0.5)# loop delaytime.sleep(0.1)
from digitalio import DigitalInOut, Direction, Pull
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.analoginput import AnalogInput
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import motor
from busio import I2C
import neopixel
import audioio
import board
import time
# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)
# built in CPX button A
button = DigitalInOut(board.BUTTON_A)
button.direction = Direction.INPUT
button.pull = Pull.DOWN
# NeoPixels
pixels = neopixel.NeoPixel(board.A1, 10, brightness=0)
pixels.fill((0,0,250))
# Analog reading from Signal #1 (ss. #2)
foot_pedal = AnalogInput(seesaw, 2)
# Create one motor on seesaw PWM pins 22 & 23
motor_a = motor.DCMotor(PWMOut(seesaw, 22), PWMOut(seesaw, 23))
motor_a.throttle = 0
def map_range(x, in_min, in_max, out_min, out_max):
# Maps a number from one range to another.
mapped = (x-in_min) * (out_max - out_min) / (in_max-in_min) + out_min
if out_min <= out_max:
return max(min(mapped, out_max), out_min)
return min(max(mapped, out_max), out_min)
# Get the audio file ready
wavfile = "unchained.wav"
f = open(wavfile, "rb")
wav = audioio.WaveFile(f)
a = audioio.AudioOut(board.A0)
time_to_play = 0 # when to start playing
played = False # have we played audio already? only play once!
while True:
# Foot pedal ranges from about 700 (unpressed) to 50 (pressed)
# make that change the speed of the motor from 0 (stopped) to 0.5 (half)
press = foot_pedal.value
speed = map_range(press, 700, 50, 0, 0.5)
print("%d -> %0.3f" % (press, speed))
motor_a.throttle = speed
if not time_to_play and speed > 0.1:
print("Start audio in 3 seconds")
time_to_play = time.monotonic() + 3
elif time_to_play and time.monotonic() > time_to_play and not played:
print("Playing audio")
a.play(wav)
played = True
# turn on/off blue LEDs
if button.value:
if pixels.brightness < 0.1:
pixels.brightness = 1
else:
pixels.brightness = 0
time.sleep(0.5)
# loop delay
time.sleep(0.1)
Adafruit publishes a wide range of writing and video content, including interviews and reporting on the maker market and the wider technology world. Our standards page is intended as a guide to best practices that Adafruit uses, as well as an outline of the ethical standards Adafruit aspires to. While Adafruit is not an independent journalistic institution, Adafruit strives to be a fair, informative, and positive voice within the community – check it out here: adafruit.com/editorialstandards
Stop breadboarding and soldering – start making immediately! Adafruit’s Circuit Playground is jam-packed with LEDs, sensors, buttons, alligator clip pads and more. Build projects with Circuit Playground in a few minutes with the drag-and-drop MakeCode programming site, learn computer science using the CS Discoveries class on code.org, jump into CircuitPython to learn Python and hardware together, TinyGO, or even use the Arduino IDE. Circuit Playground Express is the newest and best Circuit Playground board, with support for CircuitPython, MakeCode, and Arduino. It has a powerful processor, 10 NeoPixels, mini speaker, InfraRed receive and transmit, two buttons, a switch, 14 alligator clip pads, and lots of sensors: capacitive touch, IR proximity, temperature, light, motion and sound. A whole wide world of electronics and coding is waiting for you, and it fits in the palm of your hand.
Have an amazing project to share? The Electronics Show and Tell is every Wednesday at 7:30pm ET! To join, head over to YouTube and check out the show’s live chat and our Discord!
Python for Microcontrollers – Adafruit Daily — Python on Microcontrollers Newsletter: Open Hardware is In, New CircuitPython and Pi 5 16GB, and much more! #CircuitPython #Python #micropython @ThePSF @Raspberry_Pi
EYE on NPI – Adafruit Daily — EYE on NPI Maxim’s Himalaya uSLIC Step-Down Power Module #EyeOnNPI @maximintegrated @digikey