Maker.io main logo

Introducing Adafruit Crickit #MakeRobotFriend

81

2018-07-03 | By Adafruit Industries

License: See Original Project Programmers Circuit Playground

Courtesy of Adafruit

Guide by Lady Ada

Overview

CRICKIT and Circuit Playground

Sometimes we wonder if robotics engineers ever watch movies. If they did, they'd know that making robots into slaves always ends up in a robot rebellion. Why even go down that path? Here at Adafruit, we believe in making robots our friends!

Crickit

So, if you find yourself wanting a companion, consider the robot. They're fun to program, and you can get creative with decorations.

With that in mind, we designed Crickit - That's our Creative Robotics and Interactive Construction Kit. It's an add-on to our popular Circuit Playground Express that lets you #MakeRobotFriend using CircuitPython, MakeCode (coming soon), or Arduino.

Bolt on your Circuit Playground using the included stand-off bolts and start controlling motors, servos, solenoids. You also get signal pins, capacitive touch sensors, a NeoPixel driver and amplified speaker output. It complements and extends the Circuit Playground so you can still use all the goodies on the CPX, but now you have a robotics playground as well.

Crickit is powered by seesaw

The Crickit is powered by seesaw, our I2C-to-whatever bridge firmware. So you only need to use two data pins to control the huge number of inputs and outputs on the Crickit. All those timers, PWMs, sensors are offloaded to the co-processor.

You get:

  • 4 x Analog or Digital Servo control, with precision 16-bit timers
  • 2 x Bi-directional brushed DC motor control, 1 Amp current limited each, with 8-bit PWM speed control (or one stepper)
  • 4 x High current "Darlington" 500 mA drive outputs with kick-back diode protection. For solenoids, relays, large LEDs, or one unipolar stepper
  • 4 x Capacitive touch sensors with alligator-pads
  • 8 x Signal pins, digital in/out or analog inputs
  • 1 x NeoPixel driver with a 5V level shifter
  • 1 x Class D, 4 Ohm to 8 Ohm speaker, 3W-max audio amplifier

All are powered via 5VDC, so you can use any 5V-powered servos, DC motors, steppers, solenoids, relays, etc. To keep things simple and safe, we don't support mixing voltages, so only 5V, not for use with 9V or 12V robotic components.

power supply has an

Since you'll be working with high-current devices, we wanted to have a good solid power supply system that minimizes the risk of damage. The power supply has an 'eFuse' management chip that will automatically turn off if the voltage goes above 5.5V or below 3V and has over-current protection at 4 A. Every motor driver has kick-back protection. We think this is a nice and durable board for robotics!

Crickit Tour

Crickit Tour

Power Input

Power Input

Your project starts here, where power comes into the Crickit and is then used to control various motors and parts. We cover the various ways you can power your Crickit in the next section, since there's a lot of flexibility depending on the budget, portability, and complexity of your project.

For now, assume you will plug in a 5V wall adapter to the 2.1mm DC jack. This DC jack is the only way to provide power to Crickit. There's a USB jack (covered at the bottom of this section) but you cannot power the Crickit that way (the USB jack is only for debugging seesaw!).

Use 5VDC (4VDC to 5.5VDC range works) with positive-center voltage. If you try to plug in a negative-center power supply, the polarity-protection will kick in and you will not see any lights on the Crickit.

The Crickit uses a power management chip to keep you from accidentally powering it from 9V or 12V, damaging your electronics. Look for the OK and /!\ warning LEDs. If you see the green OK LED, the power is fine! If you see the red warning LED, the voltage is too low, too high, or too much current is being used.

You can turn off the Crickit at any time with the On/Off switch. This will turn off the 5V power, completely disabling all motors, as well as turning off the seesaw control chip.

There's also a Reset button. This button will reset the seesaw chip, and can be used to load new seesaw firmware (you won't likely have to do that). On the Feather Crickit, this button also connects to the Feather reset pin. On the Circuit Playground Crickit, it does not connect to the Playground Reset button.

Power options to consider:

4 x Hobby Servos

4 x Hobby Servos

Hobby servos are really popular in robotics because they're fairly low cost, very easy to use, and reliable.

Crickit gives you 4 slots

The Crickit gives you 4 slots for 4 independent servos. You can use micro, mini, standard, large size servos. Analog and digital work great. Continuous or 180-degree is OK. As long as you've got a servo with a 3-pin connector, you're golden.

Servo notes:

  • The white/yellow 'signal' wire goes next to the # marking on each port.
  • Each servo is controlled by a 16-bit hardware timer at 50 Hz so you will not see any jitter. The signal line is 3.3V logic.
  • The power to each servo comes from the DC power supply, 5VDC nominal.
  • The Crickit can set the pulse width to any value, but in general, you'll want to stick to 500 ms to 2500 ms wide pulses. This is customized in the Arduino, CircuitPython, or MakeCode software.
  • There is variation from servo to servo, so getting the exact same speed or angle may require some calibration and tweaking. Again, this can be customized in the driver code, the Crickit just generates whatever pulses you like!

The seesaw chip on the Crickit does all the management of these pins so your Feather or CPX does not directly control them, it must send a message to Crickit. They are on seesaw pins 17, 16, 15, 14 in that order.

Typical Adafruit Hobby Servos to consider:

2 x DC Motors

2 x DC Motors

Round and round, DC motors are great whenever you need something to spin. They tend to be faster, stronger and less expensive than continuous-rotation servos, but you need a proper DC motor driver to use them. Luckily, the Crickit can drive two DC motors.

 2 independently-controllable brushed DC motor drives

You get 2 independently-controllable brushed DC motor drives. Each motor can go forwards or backwards, with 8-bit speed control. There's a 5-pin terminal block to connect motors, 2 pins for each motor and a middle ground pin. (The ground pin is for some advanced techniques).

The power to the motors comes from the DC jack, about 5VDC so you can control 3VDC to 6VDC motors, which are very common. The motors can be bare motors or with a gear-box attached.

You won't be able to control 1.5VDC motors, they'll burn out. You might be able to control 6VDC to 9VDC motors, but they'll be a little slow. Same with 12VDC motors. Likewise, you cannot use the Crickit with brush-less (ESC) motors. Those require a more advanced motor driver!

  • Each motor has two wires, you can connect the wires either way. If the spin of the motor is opposite what you want, swap the wires.
  • Each motor drive has a 1 Amp peak output. After that, the over-current protection will kick in.
  • We don't recommend paralleling the output to get twice the current because the seesaw chip cannot guarantee that both will turn on/off at the same time.
  • Instead of 2 DC motors, you could also control a single bipolar stepper motor (5VDC power) or single unipolar stepper motor. You'll use the ground pin for the 5th (and 6th, if it exists) wire of the unipolar stepper.
  • Uses the DRV8833 dual H-Bridge motor driver chip.

The seesaw chip on the Crickit does all the management of these pins so your Feather or CPX does not directly control them, it must send a message to Crickit. They are on seesaw pins 22 23 (motor 1) and 19 18 (motor 2).

Typical Adafruit Motors to consider:

4 x High Power Drivers

4 x High Power Drivers

In addition to servos and DC motors, you may find you want to drive other high-power electronics like relays, solenoids, powerful LEDs, vibration motors, etc. Some of these devices are motor-like and need a kick-back protection diode, so having a proper driver is important to avoid damage!

This is where you will want to use the high power Drive terminal block. You get four high current drivers. Each driver is a 'Darlington' transistor that, when turned on, connects the output pin to ground.

Crickit only connect/disconnects drive pins to Ground

That's a little different than most other outputs on the Crickit: The Crickit can only connect/disconnect the drive pins to Ground! You cannot 'set' the Drive output to be a high voltage. So, if you're driving a solenoid, relay, vibration motor, etc. connect one side to the 5V pin, and the other side to one of the driver pins. You can connect multiple wires to the 5V pin if necessary.

Drive details:

  • 500 mA current limit per output, you can double/triple/quadruple pins up to get more current, if you like. Just make sure to tell the Crickit to turn on/off all four pins in a row.
  • Kick-back protection diodes for each output to 5V power.
  • Uses a ULN2003 Darlington driver.
  • Instead of 4 solenoids/relays, you can connect and control a single unipolar stepper motor, connect the 5th (and 6th if it exists) wire to 5V. Won't work with bipolar steppers, use the DC motor ports for that.
  • The drive outputs are also PWM-able, so you can control LED brightness or motor power. If using with solenoids or relays, set the duty cycle to 0% or 100% only.
  • Advanced usage: If you want to drive higher-voltage non-inductive/motor devices, like 12V LEDs, you can power the positive line of the LEDs from 12V, then connect the negative line of the LEDs to drive pins. Make sure your 12V power supply ground is connected to the Crickit ground. Not recommended unless you feel confident you won't accidentally put 12VDC into the Crickit! Kick-back diode won’t work in this case so not for use with motors/coils/solenoids...

The seesaw chip on the Crickit does all the management of these pins so your Feather or CPX does not directly control them, it must send a message to Crickit. They are on seesaw pins 13, 12, 43, 42 in that order.

8 x Signal I/O

8 x Signal I/O

Sure you can drive servos and motors but sometimes you just want to blink an LED or read a button. The Crickit has an eight-signal port. You can use these as "general purpose" input/output pins. We solder a 3x8 female socket header in so you can plug wires in very easily. Each signal has matching 3V and Ground power pins.

  • All pins are 3.3V logic level
  • All pins can read analog inputs (potentiometers, bend sensors, etc) at 12-bit resolution
  • All pins can be set to outputs with high (3.3V) or low (0V) voltage
  • All pins can drive about 7mA when set to outputs
  • All pins can have an internal ~50K Ohm pull-up resistor set when used as an input
  • Bonus: If you absolutely need more capacitive touch pins, Signal #1, #2, #3, #4 are four more capacitive touch inputs

Signal pin #1 is special and can be set to be a true analog 'output' with 10-bit precision.

The seesaw chip on the Crickit does all the management of these pins so your Feather or CPX does not directly control them, it must send a message to Crickit. They are on seesaw pins 2, 3, 40, 41, 11, 10, 9, 8 in that order.

4 x Capacitive Touch

4 x Capacitive Touch

Capacitive touch sensing allows you to add human-triggered control to your robot. When you touch the pad (either directly or through an alligator clip, copper tape or conductive ink) the Crickit can detect that signal. We give you four capacitive touch inputs with alligator/croc clip compatible PCB pads.

  • Capacitive touch works best with highly-conductive materials like metal
  • But you can have the metal also connect to salty-wet items such as fruit or water. However, do not try to dunk the Crickit into water or squish a grape into the pads - use an alligator clip!
  • Bonus: if you absolutely need more signal I/O pins, all four capacitive touch pads can also act as analog/digital signal I/O pins!

The seesaw chip on the Crickit does all the management of these pins so your Feather or CPX does not directly control them, it must send a message to Crickit. They are on seesaw pins 4, 5, 6, 7 in order.

NeoPixel Drive

NeoPixel Drive

Blinky lights will make your robot fun and fashionable. And we've made it really easy to add NeoPixels (WS2812/WS2811/SK6812 chipsets) to your project. The Crickit has a 3-terminal block connector with Ground, Signal, and 5V power. The signal line has a level shifter on it so it will be 5V logic level, for nice clean signals.

This output is slightly different depending on what kind of Crickit you have.

  • If you have a Feather Crickit then the NeoPixels are driven by the seesaw chip on the Crickit, and you must send seesaw commands to set colors. But that means no extra pins are needed from your Feather.
  • If you have a Circuit Playground Crickit then the NeoPixels are driven by the Circuit Playground A1 pad by default. This way you can use the MakeCode emulator and built-in Circuit Playground CircuitPython library. However, if you want, you can cut the jumper underneath the Crickit and solder closed the ss pad so that the seesaw chip controls the NeoPixels (for advanced hackers only).

If you choose to have the NeoPixel driven from the seesaw, note it is on seesaw pin #20.

Adafruit sells a very wide variety of NeoPixel products - shop here!

Speaker Drive

Speaker Drive

Audio animatronics? Yes! Your Crickit can make fairly loud sounds thanks to the built-in Class-D speaker driver. This will let you amplify audio. However, please note that the Crickit does not in-itself make audio. The audio must come from the controlling board, such as the Feather or Circuit Playground.

At this time, we recommend using the speaker with CircuitPython only since MakeCode and Arduino don't have easy to use audio support.

  • Class D audio amplifier.
  • Can drive 4Ω to 8Ω speaker. Up to 3W with 4Ω and up to 1W with 8Ω.
  • There's a small potentiometer you can use to adjust the audio volume. By default, we set it to the halfway point. Please be gentle if adjusting, don't try to crank it past the two stop-points.
  • Output is 5VDC BTL (bridge-tied-load) so do not connect to a stereo system or other line-input!
  • On the Circuit Playground Crickit, the speaker is connected directly to the A0 pad (the analog output).
  • On the Feather Crickit, the speaker input is marked Audio on the PCB and you can solder a jumper to the Feather A0 pin if desired.

Speakers to consider:

Circuit Playground Bolts

Circuit Playground Bolts

If you have a Circuit Playground Crickit, you can attach the Playground in the middle using 6 standoff bolts that come with the kit. Make sure you tighten these as loose bolts can cause connection issues.

There are six connections to make.

  • Ground - signal and power ground between Crickit and Playground
  • SDA and SCL - the I2C data connection used to send/receive data from the Crickit
  • A1 - Used for the NeoPixel output default
  • A0 - Used for the speaker output
  • VOUT - This bolt lets you safely power the Circuit Playground from the Crickit so you don't need to separately power the Playground with batteries

you can plug a Feather into the center of the Crickit

If you have a Feather, you can plug it right into the center of the Crickit.

Despite all the sockets, you only will be using 4 connections total:

  • Ground - signal and power ground between Crickit and Feather
  • SDA and SCL - the I2C data connection used to send/receive data from the Crickit
  • 3.3V - This connection lets you power the Feather from the Crickit so you don't need to separately power the Feather with batteries or USB. Note it will only power the 3.3 V line, not VUSB or VBAT

There's an optional AUDIO jumper if you want to connect the A0 Feather line to the Speaker.

seesaw USB Debug and Indicators

seesaw USB Debug and Indicators

The seesaw chipset is the programmed ATSAMD21 processor in the south section of the board. It comes with its own parts too.

Across from the power input is the seesaw debug USB connection. This USB power cannot power the Crickit and it also does not connect to the Feather or Circuit Playground USB.

It's only for debugging/reloading the seesaw firmware. Basically, if we add more Crickit capabilities, you could load new firmware over this USB connection. In general, you won't be using this port, you may want to cover it with some masking tape!

To the right is a yellow Activity LED, which will flash when seesaw sends/receives commands from your Circuit Playground or Feather. To the left is a seesaw NeoPixel. You can control this NeoPixel if you like, to give you status information, as an advanced usage.

The internal NeoPixel is on seesaw pin #27.

Powering Crickit

Powering Crickit

The first thing you'll learn when making robots is that they use a lot of power. So, making sure you have your power supply all worked out is super important. We've tried to make the power supply as easy and safe as possible, so you don't have to worry about damaging your electronics or robot. To do that we made some important design decisions.

How to Power your Crickit

It's really important to read and understand how to power your Crickit!

  • You MUST provide about 4-5 Volts DC power to the Crickit to power the servos, motors, solenoids, NeoPixels, etc.
  • You CANNOT provide this power by plugging the Crickit or Circuit Playground into USB. Computer USB ports cannot provide the 2 Amp required to drive robotics, LEDs, speakers...
  • Power to the Crickit is provided via the 2.1mm DC Jack only!
  • The Cricket has two LEDs to let you know how the power supply is doing. If you see the green LED next to the smiley face, you're good to go. If you see the red LED next to the warning triangle, the voltage is too high, too low or too much current is being drawn.
  • The Crickit power will also power the Circuit Playground Express or Feather so you don't need separate power for your microcontroller board (however, if you want to plug it into USB for programming, that's totally OK too!).

Here are our recommended ways to power the Crickit:

Plug-In DC Power Supplies

These get wall power and give you a nice clean 5VDC power option. 5V, 2A works for most projects with a motor or two...

And a 5V, 4A supply will give you lots of power so you can drive 4 or more servos, motors, etc. Use this if you notice you're running out of power with a 5V, 2A adapter.

  • 5V, 4A (4000mA) switching power supply - UL Listed

AA Battery Packs

On the go? Portable power is possible! Use AA battery packs.

The number of batteries you need depends on whether you are using Alkaline or NiMH rechargeables.

We recommend NiMH rechargeables. For one, they have less waste, but they also perform better than alkalines in high-current draw robotics. So, if you can, please use NiMH!

4 x AA Battery Packs for NiMH ONLY

NiMH batteries have a 1.3V max voltage, so 4 of them is 4 x 1.3 = 5.2 Volts. Perfect!

3 x AA Battery Packs for Alkaline ONLY

Alkaline batteries have a 1.5V max voltage, so 4 of them is 4 x 1.5 = 6 Volts. That's too high! Instead we recommend 3 in series for 3 x 1.5V = 4.5VDC.

If you're making a custom battery pack you may want to pick up a 2.1mm DC jack adapter, so you can connect battery pack wires.

Not-Recommended Power supplies

  • LiPoly Batteries - 1 battery is 3.7V, too low. 2 batteries are 7.2V, too high! You could possibly use a 7.2V pack and then a UBEC to step down to 5V but it’s not recommended
  • Lead Acid Batteries - These are heavy and you'll need a custom charging solution. You can probably get away with a 2 x 2V cell pack, or a 3 x 2V cell pack and then add some 1N4001 diodes to drop the voltage, but it's for advanced hacking!
  • USB Power Packs - In theory, you can use a USB to 2.1mm DC power adapter, but power packs sometimes dislike the kinds of current draw that motors have (high current peaks for short amounts of time) So experimentation is key!

Assembly

Crickit comes with a package of six threaded, hexagonal brass standoffs. These will hold the Circuit Playground Express above and onto the Crickit.

attach the standoffs to the six large holes

Using a Philips screwdriver and the provided screws, attach the standoffs to the six large holes on the inside ring of Crickit. There are three holes near the Adafruit logo and three more near the NeoPixel and speaker outputs. You do not want to put the standoffs on the holes on the outside edge of Crickit - there are 8 mounting holes there but these standoffs are needed for the Circuit Playground Express.

Tighten the screws firm, but do not try to tighten excessively. A good mechanical and electrical connection is needed but excessive torque could crack a circuit board or at least make things hard to take apart later.

Once you have the six standoffs screwed into Crickit, place a Circuit Playground Express board (ID 3333, not the Circuit Playground Classic board ID 3000) onto the standoffs with the silver USB-B port of the Express pointing in the same direction as the Crickit black power jack. This will align the standoffs to the following pads:

4 o'clock: A1, "4:30": A0, 5 o'clock: VOUT

10 o'clock: SDA, "10:30": SCL, 11 o'clock: GND

attach the boards together

Once you have the Circuit Playground Express lined up correctly, use the remaining screws to attach the boards together. Start with one screw into one standoff, say GND, leave it loose a bit, then put in the VOUT screw, loose, then the others loosely. Ensure things are lined up, then carefully tighten each screw. Again, a firm connection but not overly tight.

two boards should be attached

Now the two boards should be attached to one another.

Circular markings on bottom for four mounting pads

There are circular markings on the bottom of Crickit for four mounting pads if you would like to use the board on a surface and protect the surface and bottom of your Crickit.

If you happen to lose a standoff or screw(s), a new package is available from Adafruit as part ID 3816.

Recommended Motors

DC Gearbox Motors

These DC motors have a gearbox already built in, and wires attached, so they're super easy to use:

We also have a wide range of matching wheels:

Other accessories are available, search "TT Motor" items for the wide range of add-ons available.

Servo-style DC motor

If you need a motor that is very compact (but not very powerful) these DC-in-servo-body motors can do the job:

Which can be used with this wheel:

Non-Geared DC Motor

Non-geared DC motors are very weak but very fast: great for fans:

Recommended Chassis

This chassis is cute, red and has two DC motors so its super easy to drive from the Crickit's dual DC motor port. You may need to use some wires to extend the DC motor connections (they're a tad short).

This chassis is nearly identical but has 3 layers, so you can FIT MORE STUFF!

This chassis is not as nice as the above, but if you fancy it, it comes with two servo-style DC motors and can use the DC motor control on the Crickit as well.

Recommended Servos

You're in luck, you can use just about any kind of servo!

Note that many of the photos below don't show the additional motor horns, but every servo comes with plastic clip-on parts!

You can use just about any kind of servo

Servo Extensions

People often ask us what they can do if the wire to their Servo is too short for their project. Not a problem! These cables act as extension cords - now you've got plenty of room.

Popular plastic-gear servos

The most popular/common servos have plastic gears, they're plenty strong and not too expensive!

These can go back and forth, rotating about 180 degrees.

They come in 'standard' size:

And 'micro' size, not as strong but much more compact.

Continuous Rotation Servos

These servos look a lot like the above but they rotate all the way around. Unlike standard servos you can't control the location of the horn, just the speed and direction in which it turns. Good as an alternative to DC motors for wheeled bots. For that reason, they tend to get purchased with matching wheels!

High Torque Servos

If you need more power, metal-gear servos can give you better torque, but at additional cost (since the gears have to be machined).

These are not continuous rotation.

Recommended Speakers

The Class-D amplifier on the Crickit is pretty powerful, so you can make quite a bit of noise!

4Ω Speakers

You'll get a lot louder audio from 4Ω speakers.

We recommend this speaker, you'll have to either poke wires into the connector, or cut it off and strip the wires to connect to the terminal block, but it’s nice and durable.

This speaker is less expensive but you'll need to solder wires to the back.

8Ω Speakers

8 Ohm speakers won't be as loud, but that's OK!

This speaker is inexpensive, but you'll need to solder wires to the back.

  • Speaker - 3" Diameter - 8 Ohm 1 Watt

We don't recommend the speakers below just because the audio amp is pretty strong so you have to make sure not to damage the speakers by having the audio too loud. But, if you don't mind adjusting the little potentiometer on the Crickit, they will work fine!

Wall or Bone Transducers

You can also use surface transducers if you like; attach/bolt/clamp the transducer to a surface:

Recommended Drives

Solenoids

Since the Crickit can only drive 5V power, you'll need to stick to this small 5V solenoid.

Vibration Motors

You'll need to extend these wires but they'll work great at 5V and buzz very strongly.

Recommended Capacitive Touch

The capacitive touch pads on the Crickit have large holes so it’s easy to connect alligator/croc clips. That's how we recommend you attach to them. The "small" size clips work best:

You can also use copper foil tape. Note that if you get foil with conductive adhesive, you can tape the foil right onto the Crickit pads. Otherwise, you'll need to use alligator clips to grab onto the copper.

You can use other conductive materials like paints! Either drip the paint into the pad itself and let it harden, or use alligator clips to connect from one pad to a paper with conductive paint on it.

MakeCode

With MakeCode, you can create robots simply and easily, using a drag-and-drop block interface. It's perfect for first-time robot-makers, people who don't have a lot of coding experience, or even programmers who just want to get something going fast.

MakeCode uses a web browser only, so no IDE is required to install. When you download a binary from MakeCode it is compiled for the Circuit Playground Express and you will overwrite any Arduino code or the CircuitPython runtime. You can always go back to Arduino (just use the Arduino IDE) or CircuitPython (by re-installing CircuitPython as shown here).

Get Comfy With MakeCode

We recommend starting out by trying out the simple blinking NeoPixel example in our MakeCode guide, so you get a hang of how to install MakeCode apps on your Circuit Playground Express.

Once you feel comfortable with MakeCode, come back here and we'll add Crickit support!

Adding Crickit Extension

Now you're a MakeCode'r and you are ready to add Crickit support.

At this time, MakeCode support is being worked on and we're improving it every day, but it is Beta.

Start by visiting https://makecode.adafruit.com/beta

Start by visiting https://makecode.adafruit.com/beta.

Note the /beta at the end there! We need that so don't leave it off.

Click on New Project.

select ADVANCED and then EXTENSIONS

In the list of blocks, select ADVANCED and then EXTENSIONS.

type Crickit in Search Bar/click magnifying glass

In the Search Bar type in Crickit and click the magnifying glass.

Note that the package won't appear by default in the list of available extensions so you must search for it manually!

new CRICKIT bin of blocks you can use

You will now have a new CRICKIT bin of blocks you can use! Continue on to learn how to use these blocks.

MakeCode Servos

you can control four independent servos

Servos are so easy to use, you can control four independent servos - micro, mini, standard, metal gear, or continuous rotation. Basically, if it has a 3-pin plug on the end and has 'servo' in the name, it'll work just fine.

Let's start with a simple demo that moves two servos back and forth:

simple demo that moves two servos back and forth

Are your servos not moving a full 180 degrees? Don't fret! This is normal, see below about putting in custom pulse lengths to get the 'max range' your servo!

Controlling servos is basically the same through a Crickit as through MakeCode directly.

There are two blocks you can use, one for setting the angle and one for setting the pulse width directly.

Two blocks you can use

We recommend using the angle block, it’s easier! Select which servo you want to use, from 1 through 4.

We recommend using the angle block

Then adjust the angle. Remember it does take a little time for the servo motor to move, so you can't just set it back and forth instantly, try adding a delay of a second after moving to make sure it got to the angle you want!.

Then adjust the angle

Although the angles range from 0 to 180, servos may have different ranges depending on the make and model. Also, each servo is a little different, so you may not get precisely the same angle even if it's the same servo! Tweaking/adjusting the angle may be necessary.

Precise Pulses

For advanced use, you can hand-tune the pulse width. The 'standard' for servos is that 0 degrees is 1000 microseconds (us), 90 degrees is 1500 and 180 degrees is 2000 us. But...like we said, it can vary. You may want to try values as low as 750us and as high as 2500us! Just go slow, changing the values only 100us at a time, so you don’t thwack the servo gears too far, they could be damaged if they push too far! For that reason, we recommend using angles only until you're comfy with servo usage.

For advanced use, you can hand-tune the pulse width

MakeCode Drives

MakeCode Drives

The Drive output of your Crickit is perfect for 5V-powered solenoids, relays, vibration motors or high-powered LEDs. You can drive up to 500mA per output, and 4 outputs available.

Note that the 'positive' side of the electronic part you're driving has to connect to 5V not Ground. You can just double/triple/quadruple wires into the same 5V terminal block.

Each Drive output is a PWM output, that means you can change the amount of current or speed of whatever is connected.

Each Drive output is a PWM output

Select which Drive pin you want to control with the pull-down, Drive 1 through 4 are labeled on the Crickit.

Select which Drive pin you want to control

Then you can set the value from 0 (drive off) to 1023 (drive all the way on). If you want to dim an LED or run a vibration motor at half power, use 512. For quarter power, use 256!

you can set value from 0 to 1023

Remember you get 4 drive pins, so you can control them independently.

Changing the Drive Analog/PWM Frequency

You can set the analog frequency in an On Start block. We recommend 1000Hz (1kHz) it’s a good standard number. Advanced makers can tweak this!

Changing the Drive Analog/PWM Frequency

MakeCode DC Motors

MakeCode DC Motors

You can drive two separate DC motors, so let’s go ahead and get right to it!

DC motors are controlled by 4 PWM (adjustable speed) output pins, the 4 pins let you control speed and direction. And we'll use our CRICKIT Motors block set to help us manage the speed and direction for us, making it very easy to control motors.

Note that each DC motor is a little different, so just because you have two at the same speed does not mean they'll rotate at the exact same speed! Some tweaking may be required.

Note that each DC motor is a little different

Here's an example program that will move a single motor in different speeds and directions.

Setting Motor Speed

You can set the speed of the motor from 0% to 100% with this block. You can select which motor to use, 1 or 2. Once you set the speed of the motor it will continue at that speed until you change it or ask it to stop.

set the speed of the motor from 0% to 100%

You can change direction by having a negative percentage speed!

change direction by having a negative percentage speed

You may want to have two motors move at the same time so they act like wheels on a car. In that case, you can use this handy block that will control two motors at once!

Use this block to control two motors at once

You can set the two speeds at once. If both move at the same positive speed, the tank/car will move forward. Same negative speed it will move backward. If one side moves faster than the other, the car will turn.

If you want to 'invert' the motor, it will flip which direction positive/negative numbers go. That is, if positive was forward, now positive will mean backward.

This is sometimes handy if you want to use only positive numbers or to keep your code looking tidy.

Invert motor to flip direction pos/neg numbers go

CircuitPython Code

To use Crickit, we recommend CircuitPython. Python is an easy programming language to use, programming is fast, and it’s easy to read.

Install CPX Special Build

If you're using Circuit Playground Express (CPX), Please install this special 'seesaw' version of the CPX firmware. Plug the USB cable into the CPX, double-click the reset button until you see CPLAYBOOT drive, then drag the UF2 file onto the disk drive:

Download the special version of CircuitPython for CPX mounted on Crickit

What's nice about this special version is that the adafruit_seesaw and adafruit_motor library is built in, which saves you tons of space!

Download and save it to your Desktop

Click the link above to download the latest UF2 file.

Download and save it to your Desktop (or wherever is handy).

Double-click the small Reset button

Plug your Circuit Playground Express into your computer using a known-good USB cable.

A lot of people end up using charge-only USB cables and it is very frustrating! So, make sure you have a USB cable you know is good for data sync.

Double-click the small Reset button in the middle of the CPX, you will see all of the LEDs turn green. If they turn all red, check the USB cable, try another USB port, etc.

(If double-clicking doesn't do it, try a single-click!)

Drag the cpx-seesaw-3.0-2018-05-20.uf2 file onto it

You will see a new disk drive appear called CPLAYBOOT.

Drag the cpx-seesaw-3.0-2018-05-20.uf2 file onto it.

CPLAYBOOT disappears/new CIRCUITPY drive appears

The CPLAYBOOT drive will disappear and a new disk drive will appear called CIRCUITPY.

That's it! You're done :)

CircuitPython Servos

CircuitPython Servos

servos fritzing file

Test Servos

Let’s start by controlling some servos. You'll want at least one servo to plug in and test out the servo code. Visit our recommended servo page to check that you have a servo that works. Once you do, plug in a servo into SERVO #1 spot, making sure the yellow or white wire is next to the 1 text label.

This example will show rotating one servo from 0 to 180 degrees with a stop at 90 degrees.

Copy Code
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import servo
import board
import time

print("1 Servo demo!")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create servo object
pwm = PWMOut(seesaw, 17) # Servo 1 is on s.s. pin 17
pwm.frequency = 50 # Servos like 50 Hz signals
my_servo = servo.Servo(pwm) # Create my_servo with pwm signal

while True:
my_servo.angle = 0 # right
time.sleep(1)
my_servo.angle = 90 # middle
time.sleep(1)
my_servo.angle = 180 # left
time.sleep(1)
my_servo.angle = 90 # middle
time.sleep(1)
# and repeat!

 

Are your servos not moving a full 180 degrees? Don't fret! This is normal, see below about min/max pulse lengths to 'tune' your servo!

Import Libraries

We start by importing the libraries that we need to...

1. talk over I2C from busio import I2C

2. communicate with the seesaw from adafruit_seesaw.seesaw import Seesaw

3. create PWM objects from seesaw from adafruit_seesaw.pwmout import PWMOut

4. and turn a PWM object into a servo motor from adafruit_motor import servo

Then we import time and board, our standard timekeeping and hardware libraries.

Create seesaw device

Seesaw communicates over I2C, so we make an I2C hardware interface with i2c = I2C(board.SCL, board.SDA), then initialize the Seesaw chip over I2C and assign it to a variable so we can get hardware objects from it later seesaw = Seesaw(i2c).

Create Servo

OK, finally we're getting to the motor part! Now that seesaw is initialized, we can request a PWM control object on seesaw pin #17 pwm = PWMOut(seesaw, 17). Servos like to be controlled with a 50 Hz frequency refresh, so set the frequency to 50 Hz with pwm.frequency = 50. Finally, we can ask adafruit_motor to create a servo-control object which handles the details of pulse width and angle conversion with my_servo = servo.Servo(pwm).

Control Servo

Now that we have a servo object, we can simply assign the angle! my_servo.angle = 0 is all the way to the right, my_servo.angle = 90 is in the middle, and my_servo.angle = 180 is all the way to the left.

More Servos!

OK, that was fun but you want MORE servos, right? You can control up to four! The servos are on the seesaw pins 17, 16, 15, 14 in that order.

Copy Code
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import servo
import board
import time

print("4 Servo demo!")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create servos list
servos = []
for ss_pin in (17, 16, 15, 14):
pwm = PWMOut(seesaw, ss_pin)
pwm.frequency = 50
_servo = servo.Servo(pwm)
_servo.angle = 90 # starting angle, middle
servos.append(_servo)

while True:
# Repeat for all 4 servos
for my_servo in servos:
# Do the wave!
my_servo.angle = 0 # right
time.sleep(0.2)
my_servo.angle = 90 # middle
time.sleep(0.2)
my_servo.angle = 180 # left
time.sleep(0.2)
my_servo.angle = 90 # middle
time.sleep(0.2)
my_servo.angle = 0 # right

 

This example is similar to the 1 servo example, but instead of creating one my_servo object, we'll make a list called servos that contains 4 servo objects. Then we can assign them using servo[0].angle = 90 or iterate through them as we do in the loop. You don't have to do it this way, but it’s very compact and doesn't take a lot of code lines to create all 4 servos at once!

Min/Max Pulse control

In theory, servos should all use 1 ms to 2 ms long pulses, at 50 Hz to set the 0 and 180-degree locations. However, not all servos have their full range at those pulse widths. You can easily tweak your code to change the min and max pulse widths, which will let your servo turn more left and right. But don't set the widths too small/large or you can hit the hard stops of the servo which could damage it, so try tweaking the numbers slowly until you get a sense of what the limits are for your motor.

All you need to do is change the

my_servo = servo.Servo(pwm)

to, say,

my_servo = servo.Servo(pwm, min_pulse=750, max_pulse=2250)

Here we've changed the minimum pulse from the default 1000 microseconds to 750, and the default maximum pulse from 2000 microseconds to 2250. Again, each servo differs. Some experimentation may be required!

Continuous Rotation Servos

If you're using continuous servos, you can use the angle assignments and just remember that 0 is rotating one way, 90 is 'stopped' and 180 and rotating the other way. Or you can use the ContinuousServo object instead of the plain Servo.

Copy Code
...
my_servo = servo.ContinuousServo(pwm, min_pulse=1000, max_pulse=2000)

print("Forwards full speed")
my_servo.throttle = 1
time.sleep(1)

print("Backwards half speed")
my_servo.throttle = -0.5
time.sleep(1)

print("Stop")
my_servo.throttle = 0

 

If your continuous servo doesn't stop once the script is finished you may need to tune the min_pulse and max_pulse timings so that the center makes the servo stop. Or check if the servo has a center-adjustment screw you can tweak.

Disconnecting Servos or Custom Pulses

If you want to 'disconnect' the Servo by sending it 0-length pulses, you can do that by 'reaching in' and adjusting the underlying PWM duty cycle with:

my_servo._pwm_out.duty_cycle = 0

Likewise, you can set the duty cycle to a custom value with

my_servo._pwm_out.duty_cycle = number

where number is between 0 (off) and 65535 (fully on). For example, setting it to 32767 will be 50% duty cycle, at the 50 Hz update rate.

CircuitPython Drives

CircuitPython Drives

drives fritzing file

Test Drive

Let’s start by controlling a drive output. You'll need to plug something into the 5V and DRIVE1 terminal blocks. I'm just using a simple LED with a resistor but anything that can be powered by 5V will work.

  • Note that the drive outputs cannot have a 5V output so you must connect the positive pin of whatever you're driving to 5V. Don't try connecting the positive pin to the drive, and the negative pin to GND, it won’t work!
  • Drive outputs are PWM-able!

This example will show turning the drive output fully on and off once a second:

Copy Code
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
import board
import time

print("1 Drive demo!")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create drive (PWM) object
my_drive = PWMOut(seesaw, 13) # Drive 1 is on s.s. pin 13
my_drive.frequency = 1000 # Our default frequency is 1KHz

while True:
my_drive.duty_cycle = 0 # off
time.sleep(0.5)
my_drive.duty_cycle = 65535 # on
time.sleep(0.5)
# and repeat!

 

Import Libraries

We start by importing the libraries that we need to

1. talk over I2C from busio import I2C

2. communicate with the seesaw from adafruit_seesaw.seesaw import Seesaw

3. create PWM objects from seesaw from adafruit_seesaw.pwmout import PWMOut

Then we import time and board, our standard timekeeping and hardware libraries.

Create seesaw device

Seesaw communicates over I2C, so we make an I2C hardware interface with i2c = I2C(board.SCL, board.SDA), then initialize the Seesaw chip over I2C and assign it to a variable so we can get hardware objects from it later seesaw = Seesaw(i2c).

Create Drive

OK, finally we're getting to the good part! Now that seesaw is initialized, we can request a PWM control object on seesaw pin #13 my_drive = PWMOut(seesaw, 13). Drive outputs are all PWM outputs too, so this is the easiest way to make an object we can control. In general, the default frequency for PWM outputs on seesaw is 1000 Hz, so set the frequency to 1 kHz with my_drive.frequency = 1000. Even if you aren't planning to use the PWM output, please set the frequency!

Control Drive Output

Now that we have a drive pwm object, we can simply assign the PWM duty cycle! my_drive.duty_cycle = 0 turns the output completely off (no drive to ground, no current draw). my_drive.duty_cycle = 65535 turns the output completely on (fully drive to ground).

If you are driving an LED, motor, or other PWM-friendly device, you can try changing how much power to provide by setting duty_cycle to a value between 0 (off) and 65535 (on). For example, my_drive.duty_cycle = 32767 will set the power to half.

More Drivers!

OK, that was fun but you want MORE drives, right? You can control up to four! The four drive outputs are on the seesaw pins 13, 12, 43, 42 in that order.

Copy Code
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
import board
import time

print("4 Drive demo!")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

drives = []
for ss_pin in (13, 12, 43, 42):
_pwm = PWMOut(seesaw, ss_pin)
_pwm.frequency = 1000
drives.append(_pwm)

while True:
for drive in drives:
drive.duty_cycle = 0xFFFF
time.sleep(0.1)
drive.duty_cycle = 0
time.sleep(0.1)

 

This example is similar to the 1 drive example, but instead of creating one my_drive object, we'll make a list called drives that contains 4 pwm driving objects. Then we can assign them using drive[0].duty_cycle = 65535 or iterate through them as we do in the loop. You don't have to do it this way, but it's very compact and doesn't take a lot of code lines to create all 4 drivers at once!

CircuitPython DC Motors

CircuitPython DC Motors

dcmotors fritzing file

You can drive two separate DC motors, so let’s go ahead and get right to it!

DC motors are controlled by 4 PWM output pins, the 4 PWM pins let you control speed and direction. And we'll use our adafruit_motor library to help us manage the throttle (speed) and direction for us, making it very easy to control motors.

Note that each DC motor is a little different, so just because you have two at the same throttle does not mean they'll rotate at the exact same speed! Some tweaking may be required.

The two wires of the DC motor can be plugged in either way into each Crickit Motor port. If the motor spins the opposite way from what you want to call 'forward', just flip the wires!

Copy Code
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import motor
import board
import time

print("Dual motor demo!")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create one motor on seesaw PWM pins 22 & 23
motor_a = motor.DCMotor(PWMOut(seesaw, 22), PWMOut(seesaw, 23))
# Create another motor on seesaw PWM pins 19 & 18
motor_b = motor.DCMotor(PWMOut(seesaw, 19), PWMOut(seesaw, 18))

while True:
motor_a.throttle = 1 # full speed forward
motor_b.throttle = -1 # full speed backward
time.sleep(1)

motor_a.throttle = 0.5 # half speed forward
motor_b.throttle = -0.5 # half speed backward
time.sleep(1)

motor_a.throttle = 0 # stopped
motor_b.throttle = 0 # also stopped
time.sleep(1)

motor_a.throttle = -0.5 # half speed backward
motor_b.throttle = 0.5 # half speed forward
time.sleep(1)

motor_a.throttle = -1 # full speed backward
motor_b.throttle = 1 # full speed forward
time.sleep(1)

motor_a.throttle = 0 # stopped
motor_b.throttle = 0 # also stopped
time.sleep(0.5)

# and repeat!

 

Import Libraries

We start by importing the libraries that we need to

1. talk over I2C from busio import I2C

2. communicate with the seesaw from adafruit_seesaw.seesaw import Seesaw

3. create PWM objects from seesaw from adafruit_seesaw.pwmout import PWMOut

4. and turn a PWM object into a DC motor from adafruit_motor import motor

Then we import time and board, our standard timekeeping and hardware libraries.

Create seesaw device

Seesaw communicates over I2C, so we make an I2C hardware interface with i2c = I2C(board.SCL, board.SDA), then initialize the Seesaw chip over I2C and assign it to a variable so we can get hardware objects from it later seesaw = Seesaw(i2c)

Create Motor

OK, finally we're getting to the motor part! Now that seesaw is initialized, we can request two PWM control objects on the pairs #22 and 23 PWMOut(seesaw, 22), PWMOut(seesaw, 23). Then we immediately assign those to the two control pins of a motor object with motor_a = motor.DCMotor(PWMOut(seesaw, 22), PWMOut(seesaw, 23)). This is a compact way of creating & assigning the PWM's without having a lot of extra code.

We then do the same for the second motor with motor_b = motor.DCMotor(PWMOut(seesaw, 19), PWMOut(seesaw, 18)).

Control Motor

Now that we have our motor objects, we can simply assign the throttle, this will set the direction and speed. For example, to set the speed to full forward, use motor_a.throttle = 1 and to set to full speed backward use motor_a.throttle = -1. For speeds in between, use a fraction, such as 0.5 (half speed) or 0.25 (quarter speed). Setting the throttle = 0 will stop the motor.

CircuitPython Steppers 

CircuitPython Steppers

Even though we show the Circuit Playground Crickit, the wiring and code works with the Feather and CPX Crickit.

Dual Stepper fritzing

Even though we don't make it really obvious, you can drive stepper motors from the Crickit.

Stepper motors rotate all the way around but only one 'step' at a time. Usually, there are a few hundred steps per turn, making them great for precision motion. The tradeoff is they're very slow compared to servos or steppers. Also, unlike servos they don't know 'where' they are in the rotation, they can only step forward and backward.

There are two kinds of stepper motors: bipolar (4-wire) and unipolar (5 or 6-wire). We can control both kinds but with some restrictions!

  • The voltage we use to power the motor is 5V only, so 5V power steppers are best, but sometimes you can drive 12V steppers at a slower/weaker rate.
  • You can drive one bipolar stepper motor via the Motor port.
  • You can drive two unipolar stepper motors, one via the Motor port and one via the Drive port.
  • That means you have two unipolar steppers or one uni- and one bipolar. But you cannot drive two bipolar steppers.
  • seesaw isn't optimized for steppers so you won't be able to step faster than 20 milliseconds per step. for a 200 step/rev stepper, that means 4 seconds per revolution. If we update seesaw for faster stepping we'll update this guide!

Bipolar or Unipolar Motor Port

The Crickit Motor port can run a unipolar (5-wire and 6-wire) or bipolar (4-wire) stepper. It cannot run steppers with any other # of wires!

The code is the same for unipolar or bipolar motors, the wiring is just slightly different.

Unlike DC motors, the wire order does matter. Connect one coil to the Motor pair #1. Connect the other coil to the Motor pair #2.

  • If you have a bipolar motor, connect one motor coil to #1 and the other coil to #2 and do not connect to the center GND block.
  • If you are using a unipolar motor with 5 wires, connect the common wire to the center GND port.
  • If you are using a unipolar motor with 6 wires, you can connect the two 'center coil wires' together to the center GND port.

If you are using our "12V" bi-polar stepper

If you are using our "12V" bipolar stepper, wire in this order: red, yellow, (skip GND center), green, gray.

If you are using our 5V uni-polar stepper

If you are using our 5V unipolar stepper, wire in this order: orange, pink, red (ground), yellow, blue.

Here is the CircuitPython code for stepping various ways. You can try tweaking the INTERSTEP_DELAY from 20 milliseconds (0.02) to 10 ms but depending on the motor you probably won’t be able to go faster without the Crickit/stepper dropping steps.

CircuitPython supports 4 different waveform stepping techniques. More on each is detailed at Wikipedia.

  • SINGLE stepping (one coil on at a time) - fast, lowest power usage, weak strength
  • DOUBLE stepping (two coils on at a time) - fast, highest power, high strength
  • INTERLEAVE stepping (alternates between one and two coils on) - slow (half the speed of single or double!), medium power, medium strength
  • MICROSTEPPING - while this is supported it’s so slow with Crickit we're going to just 'skip' this one!

Unless you have power limiting requirements, DOUBLE is great for most projects. INTERLEAVE gives you smoother motion but is slower. SINGLE is simplest but weakest turning strength.

Copy Code
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import stepper
import board
import time

print("Bi-Polar or Uni-Polar Stepper motor demo!")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create one stepper motor using the 4 'motor' PWM pins 22, 23, 19 and 18
stepper_motor = stepper.StepperMotor(PWMOut(seesaw, 22), PWMOut(seesaw, 23), PWMOut(seesaw, 19), PWMOut(seesaw, 18))

INTERSTEP_DELAY = 0.02

while True:
print("Single step")
for i in range(200):
stepper_motor.onestep(direction=stepper.FORWARD)
time.sleep(INTERSTEP_DELAY)
for i in range(200):
stepper_motor.onestep(direction=stepper.BACKWARD)
time.sleep(INTERSTEP_DELAY)

print("Double step")
for i in range(200):
stepper_motor.onestep(direction=stepper.FORWARD, style=stepper.DOUBLE)
time.sleep(INTERSTEP_DELAY)
for i in range(200):
stepper_motor.onestep(direction=stepper.BACKWARD, style=stepper.DOUBLE)
time.sleep(INTERSTEP_DELAY)

print("Interleave step")
for i in range(200):
stepper_motor.onestep(direction=stepper.FORWARD, style=stepper.INTERLEAVE)
time.sleep(INTERSTEP_DELAY)
for i in range(200):
stepper_motor.onestep(direction=stepper.BACKWARD, style=stepper.INTERLEAVE)
time.sleep(INTERSTEP_DELAY)

 

CircuitPython motor control is pretty simple - once you've created the stepper (and we recommend using the exact code above to do so since the order of the PWM pins matters!) you can call onestep() to step once, with the direction and stepping style included. The default direction is FORWARD and the default style is SINGLE.

Unipolar Only Drive Port

The Drive port can also control steppers although it can only do unipolar! Don't try connecting a 4-wire bipolar stepper, it won't work at all.

If you are using our 5V uni-polar stepper

If you are using our 5V unipolar stepper, wire in this order: red (5V), orange, yellow, pink, blue. That should line up with the wires on the plug.

And here's the CircuitPython code. Note that the only difference is the creation of the PWMOut pins use different seesaw connections, to match the Drive pins. If you use this exact order for creating the stepper motor, the wiring is a lot more elegant because the unipolar stepper can be wired in the same order as the plug.

Copy Code
    from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import stepper
import board
import time

print("Uni-Polar Stepper drive demo!")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create one stepper motor using the 4 'drive' PWM pins 13, 43, 12 and 42
stepper_motor = stepper.StepperMotor(PWMOut(seesaw, 13), PWMOut(seesaw, 43), PWMOut(seesaw, 12), PWMOut(seesaw, 42))

while True:
print("Single step")
for i in range(200):
stepper_motor.onestep(direction=stepper.FORWARD)
time.sleep(0.01)
for i in range(200):
stepper_motor.onestep(direction=stepper.BACKWARD)
time.sleep(0.01)

print("Double step")
for i in range(200):
stepper_motor.onestep(direction=stepper.FORWARD, style=stepper.DOUBLE)
time.sleep(0.01)
for i in range(200):
stepper_motor.onestep(direction=stepper.BACKWARD, style=stepper.DOUBLE)
time.sleep(0.01)

print("Interleave step")
for i in range(200):
stepper_motor.onestep(direction=stepper.FORWARD, style=stepper.INTERLEAVE)
time.sleep(0.01)
for i in range(200):
stepper_motor.onestep(direction=stepper.BACKWARD, style=stepper.INTERLEAVE)
time.sleep(0.01)

 

CircuitPython Signals

Signals are on seesaw pins 2, 3, 40, 41, 11, 10, 9, 8 in that order. So that means Signal I/O #1 is seesaw #2, and Signal I/O #7 is seesaw #8.

You can use these as digital I/O pins, setting the mode, value and reading with the seesaw library directly:

Copy Code
from adafruit_seesaw.seesaw import Seesaw
from busio import I2C
import board
import time

i2c = I2C(board.SCL, board.SDA)
ss = Seesaw(i2c)

# Two buttons are pullups, connect to ground to activate
ss.pin_mode(BUTTON_1, ss.INPUT_PULLUP)
ss.pin_mode(BUTTON_2, ss.INPUT_PULLUP)
# Two LEDs are outputs, on by default
ss.pin_mode(LED_1, ss.OUTPUT)
ss.pin_mode(LED_2, ss.OUTPUT)
ss.digital_write(LED_1, True)
ss.digital_write(LED_2, True)

while True:
if not ss.digital_read(BUTTON_1):
ss.digital_write(LED_1, True)
else:
ss.digital_write(LED_1, False)
if not ss.digital_read(BUTTON_2):
ss.digital_write(LED_2, True)
else:
ss.digital_write(LED_2, False)

 

CircuitPython Audio

CircuitPython Audio

speaker fritzing file

Audio animatronics! By adding a voice or sound effects to your robot you can make a cool interactive project. We take advantage of CircuitPython's ability to play WAV files over the true-analog output pin A0.

This is one of the few outputs that does not go through the seesaw chip. Instead, the audio is played directly from the CircuitPython board and the Crickit only amplifies it!

Audio File Formats

CircuitPython supports Mono (not stereo) 22 kHz sample rate (or less) and 16-bit WAV format. The reason for mono is that there's only one output, 22 kHz or less because the Circuit Playground can't handle more data than that (and also it won’t sound much better) and the DAC output is 10-bit so anything over 16-bit will just take up room without better quality.

CircuitPython does not support OGG or MP3. Just WAV!

Since the WAV file must fit on the CircuitPython file system, it must be under 2 MB.

We have a detailed guide on how to generate WAV files here.

Amplifier Details

The onboard amplifier is a mono "Class D" audio amp with BTL (Bridge Tied Load) output.

That means you cannot plug the speaker output into another amplifier, it must connect directly to a speaker!

You can use just about any 4Ω to 8Ω speaker (6Ω is OK too, just not as common). The amplifier can drive up to 3 Watts into 4Ω and 1 Watt into 8Ω. That means its ok to drive a 5-Watt speaker, it just won’t be as loud as it could be with a bigger amp (but you won’t damage the amp). You can also drive speakers that are smaller, like an 8Ω 0.5W but make sure you don't turn the audio volume potentiometer up, as it could damage the speaker by overpowering it.

Basic Audio Playback

Copy Code
import audioio
import board

wavfile = "howto.wav"
f = open(wavfile, "rb")
wav = audioio.WaveFile(f)
a = audioio.AudioOut(board.A0)
a.play(wav)

# You can now do all sorts of stuff here while the audio plays
# such as move servos, motors, read sensors...

# Or wait for the audio to finish playing:
while a.playing:
pass

f.close()

 

Here is the audio file we're using for this example.

howto.wav

You must drag/copy this onto your CIRCUITPY disk drive, it's a big file so it will take a minute to copy over.

Import Libraries

We start by importing the libraries that we need to make audio output import audioio Then we import board, our standard hardware library.

Create wave file and audio output

Next, we set the name of the file we want to open, which is a wave file wavfile = "howto.wav" and then open the file as a readable binary and store the file object in f which is what we use to actually read audio from: f = open(wavfile, "rb").

Now we will ask the audio playback system to load the wave data from the file wav = audioio.WaveFile(f) and finally request that the audio is played through the A0 analog output pin a = audioio.AudioOut(board.A0).

The audio file is now locked-and-loaded, and can be played at any time with a.play(wav).

Audio playback occurs in the background, using "DMA" (direct memory access) so you can control servos, motors, read sensors, whatever you like, while the DMA is happening. Since it happens asynchronously, you may want to figure out when it’s done playing. You can do that by checking the value of a.playing if it's True then it’s still processing audio, it will return False when complete.

Interactive Audio

OK just playing an audio file is one thing, but maybe you want to have some interactivity, such as waiting for the person to touch something or press a button? Here's an example of using a time-delay and then pausing until something occurs:

Copy Code
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
import audioio
import board
import time

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# what counts as a 'touch'
CAPTOUCH_THRESH = 500

wavfile = "howto.wav"
f = open(wavfile, "rb")
wav = audioio.WaveFile(f)
a = audioio.AudioOut(board.A0)
a.play(wav)

t = time.monotonic() # this is the time when we started

# wait until we're at timecode 5.5 seconds into the audio
while time.monotonic() - t < 5.5:
pass

a.pause() # pause the audio

print("Waiting for Capacitive touch!")
while seesaw.touch_read(0) < CAPTOUCH_THRESH:
pass

a.resume() # resume the audio

# You can now do all sorts of stuff here while the audio plays
# such as move servos, motors, read sensors...

# Or wait for the audio to finish playing:
while a.playing:
pass
print("Done!")

 

You may want to have the audio track match to motion or events in your robot. To do that you can do some tricks with time.monotonic(). That's our way of knowing true time passage, it returns a floating point (fractional) value in seconds. Note it’s hard to get the exact precise second so use > and < rather than checking for = equality because minute variations will make it hard to get the time delta exactly when it occurs.

CircuitPython Examples

Need some...err...inspiration? Here are some example projects with CircuitPython code and wiring diagrams. They're not full-featured guides but they provide a good basis for seeing how to use Crickit!

Bubble Bot

 

 

Its summer time and that means tank tops, ice cream, and bubbles! This robot friend makes a bountiful burst of bubbles all on its own.

Parts List

Wiring Diagram

Wiring Diagram

Code

This simple robot doesn't do a lot but it does it very well!

We have one DC motor with a fan attachment, and one servo motor where we connect the bubble wand. Every few seconds, the wand goes down into the bubble mix, then back up, the fan turns on for 3 seconds, then turns off and the process repeats!

Copy Code
# CircuitPython 3.0 CRICKIT demo
import time

import board
from adafruit_motor import servo, motor
from adafruit_seesaw.pwmout import PWMOut
from adafruit_seesaw.seesaw import Seesaw
from busio import I2C

i2c = I2C(board.SCL, board.SDA)
ss = Seesaw(i2c)

print("Bubble machine!")

SERVOS = True
DCMOTORS = True

# Create 4 Servos
servos = []
if SERVOS:
for ss_pin in (17, 16, 15, 14):
pwm = PWMOut(ss, ss_pin)
pwm.frequency = 50
_servo = servo.Servo(pwm)
_servo.angle = 90 # starting angle, middle
servos.append(_servo)

# Create 2 DC motors
motors = []
if DCMOTORS:
for ss_pin in ((18, 19), (22, 23)):
pwm0 = PWMOut(ss, ss_pin[0])
pwm1 = PWMOut(ss, ss_pin[1])
_motor = motor.DCMotor(pwm0, pwm1)
motors.append(_motor)

while True:
print("servo down")
servos[0].angle = 180
time.sleep(1)
print("fan on")
motors[0].throttle = 1
time.sleep(3)
print("fan off")
time.sleep(1)
motors[0].throttle = 0
print("servo up")
servos[0].angle = 0
time.sleep(1)

 

Feynman Simulator

 

 

If you are a fan of physics wunderkind Richard Feynman and you like bongo drums, this Feynman simulator will satisfy your every desire. Between wise quips, this Feyn-bot will dazzle you with its drumming expertise.

Parts List

Wiring Diagram

Solenoids don't have 'direction' - any current will make them push. So even though we wired the black wire to 5V and the red wires to the #1 and #2 drive ports, they'll work just fine.

The micro servo is taped to a wooden stick that moves the paper cut-out mouth up and down, for a Monty-Python-style puppet.

Wiring Diagram

Code

Our code plays through a few wave file quips and quotes we found online, with some interstitial bongo drumming. Once all the audio has been played, it bongos for a long time, then repeats!

Copy Code
# CircuitPython 3.0 CRICKIT demo

import gc
import time

import audioio
import board
from adafruit_motor import servo
from adafruit_seesaw.pwmout import PWMOut
from adafruit_seesaw.seesaw import Seesaw
from busio import I2C

i2c = I2C(board.SCL, board.SDA)
ss = Seesaw(i2c)

print("Feynbot demo!")

# 1 Servo
pwm = PWMOut(ss, 17)
pwm.frequency = 50
myservo = servo.Servo(pwm)
myservo.angle = 180 # starting angle, highest

# 2 Drivers
drives = []
for ss_pin in (13, 12):
_pwm = PWMOut(ss, ss_pin)
_pwm.frequency = 1000
drives.append(_pwm)

# Audio files
wavfiles = ["01.wav", "02.wav", "03.wav", "04.wav", "05.wav"]
a = audioio.AudioOut(board.A0)


# Start playing the file (in the background)
def play_file(wavfile):
f = open(wavfile, "rb")
wav = audioio.WaveFile(f)
a.play(wav)


# Tap the solenoids back and forth
def bongo(t):
for _ in range(t):
drives[0].duty_cycle = 0xFFFF
time.sleep(0.1)
drives[0].duty_cycle = 0
time.sleep(0.1)
drives[1].duty_cycle = 0xFFFF
time.sleep(0.1)
drives[1].duty_cycle = 0
time.sleep(0.1)


# Move mouth back and forth
def talk(t):
for _ in range(t):
myservo.angle = 150
time.sleep(0.1)
myservo.angle = 180
time.sleep(0.1)


filenum = 0 # counter to play all files

while True:
gc.collect()
print(gc.mem_free())

# time to play the bongos!
bongo(5)
time.sleep(1)

# OK say something insightful
play_file(wavfiles[filenum])
# and move the mouth while it does
while a.playing:
talk(1)

# Done being insightful, take a break
time.sleep(1)

# If we went thru all the files, JAM OUT!
filenum = 1
if filenum >= len(wavfiles):
bongo(20)
filenum = 0

 

Slime Night

 

 

Ladyada was unable to get to sleep. Feeling restless she decided to visit her workshop and make some slime to help soothe her soul. Then her companion showed up to lend a hand and have fun together!

How to Make Slime

  • 1 Bottle Elmer’s Glue - we like the glitter glue but you can use plain white glue and add food coloring!
  • 1/2 Tablespoon Baking Soda - not baking powder! You probably have some in your freezer, fridge, or baking cabinet
  • 1 Tablespoon Contact Lens Solution - make sure to get the stuff with Boric Acid!

Put glue in a glass container, add soda and solution, mix and enjoy!

The quantities are flexible and you don't have to be exact. Add a little more or less to change gooeyness.

Parts Used

Wiring Diagram

Wiring Diagram

CircuitPython Code

This project has a foot pedal potentiometer that controls the speed of the TT motor that spins the platter around. Since foot pedals are rheostats (variable resistors) you need another resistor to finish the divider. We use a plain 10K, any value from about 4.7K to 47K will do fine.

When not pressed, the analog reading value is about 700. When pressed, the reading goes down to about 50. You may need to calibrate these numbers for your foot pedal!

We map the analog press values to motor speed, the max speed we want is 0.5 throttle (1.0 was waaay to fast) using our simple mapper helper. If it’s our first time pressing the pedal, we play the audio file 3 seconds later, to give some ambience.

You can also press the A button to turn on/off some pretty NeoPixels.

Copy Code
import time
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

# 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)

 

Flying Trapeze

 

 

Feel the excitement, the thrill, the rushing air beneath your wings - without having to leave home or run any risk of injury or sweating!

This Flying Trapeze bot uses a servo claw to grip onto a willing gymnast, and release it into the air when the detected acceleration has reached a sufficient peak!

Parts List

The servo claw we used had a built-in metal gear servo that could draw significant current when actuated! We found a 4xAA battery pack with good NiMH batteries would last a while but 3xNiMH couldn't power it sufficiently.

Wiring

Wiring Diagram

Boot.py

Since we want to have the ability to data log the accelerometer, we need to put the CPX into 'filesystem write mode' - this boot.py will let you use the switch on the CPX to select whether you want to log data or go into trapeze-release mode.

Copy Code
# Save as boot.py to turn on/off datalogging capability

import digitalio
import board
import storage

switch = digitalio.DigitalInOut(board.D7) # For Circuit Playground Express
switch.direction = digitalio.Direction.INPUT
switch.pull = digitalio.Pull.UP

# If the switch pin is connected to ground CircuitPython can write to the drive
storage.remount("/", switch.value)

 

CircuitPython Code

Our Python code is dual use. You can use the slide switch to select whether you want to log the accelerometer data to the onboard storage. If you do, it’s easy to plot it and see the magnitude of the forces on your trapeze artist!

We mostly used data log mode to calibrate how 'hard' we required the person to push the trapeze to make the servo release the gymnast-stand-in.

We also have two buttons on the CPX we use for different tasks. In logging mode, you use button A to turn on/off logging. The red LED blinks to let you know logging is occurring. In trapeze mode, A and B let you manually open/close the servo gripper so you can have it grab the gymnasts head. Hey, life's tough all around!

Finally, if we're in trapeze mode, we look for when we're at the beginning of a swing, that's when the Z-axis acceleration drops below 3 m/s2 and the Y axis has positive acceleration (we used the data log info to figure this out!) If so, the next time we reach max-acceleration, at the lowest point of the swing, we start opening the gripper, which takes a little time so that when we are at the end of the swing, it's opened enough for the gymnast to be released!

We change the NeoPixel colors to help debug, by flashing when we reach the different sensor states, since we don't have wireless data transfer on the CPX.

Copy Code
import time
from digitalio import DigitalInOut, Direction, Pull
import adafruit_lis3dh
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import servo
import neopixel
import board

# create accelerometer
i2c1 = I2C(board.ACCELEROMETER_SCL, board.ACCELEROMETER_SDA)
lis3dh = adafruit_lis3dh.LIS3DH_I2C(i2c1, address=0x19)
lis3dh.range = adafruit_lis3dh.RANGE_8_G

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create servo object
pwm = PWMOut(seesaw, 17) # Servo 1 is on s.s. pin 17
pwm.frequency = 50 # Servos like 50 Hz signals
my_servo = servo.Servo(pwm) # Create my_servo with pwm signal

# LED for debugging
led = DigitalInOut(board.D13)
led.direction = Direction.OUTPUT

# two buttons!
button_a = DigitalInOut(board.BUTTON_A)
button_a.direction = Direction.INPUT
button_a.pull = Pull.DOWN
button_b = DigitalInOut(board.BUTTON_B)
button_b.direction = Direction.INPUT
button_b.pull = Pull.DOWN

# NeoPixels!
pixels = neopixel.NeoPixel(board.NEOPIXEL, 10, brightness=1)
pixels.fill((0,0,0))

#################### log file for logging mode!
logfile = "/log.csv"
# check that we could append if wanted to
try:
fp = None
fp = open(logfile, "a")
print("File system writable!")
# pylint: disable=bare-except
except:
print("Not logging, trapeeze mode!")

# If we log, have some helper variables
logging = False
logpoints = 0
outstr = ""

# When its time to release the trapeze
release = False

while True:
if button_a.value: # A pressed
while button_a.value: # wait for release
pass
if fp: # start or stop logging
logging = not logging
print("Logging: ", logging)
time.sleep(0.25)
else:
my_servo.angle = 180 # open

if button_b.value: # B pressed
while button_b.value: # wait for release
pass
my_servo.angle = 0 # close

x, y, z = lis3dh.acceleration

# To keep from corrupting the filesys, take 25 readings at once
if logging and fp:
outstr = "%0.2F, %0.2F, %0.2F\n" % (x, y, z)
logpoints = 1

if logpoints > 25:
led.value = True
#print("Writing: " outstr)
fp.write(outstr "\n")
fp.flush()
led.value = False
logpoints = 0
else:
# display some neopixel output!
if z > 20:
# MAXIMUM EFFORT!
pixels.fill((0, 255, 0))
if release:
my_servo.angle = 180

elif z < 3 and y > 0: # means at the outer edge
release = True
# flash red when we peak
pixels.fill((255, 0, 0))

else:
pixels.fill((0,0,int(abs(z)*2)))

time.sleep(0.05)

 

For the curious, our data log file is here!

R.O.B. GyroBot

 

 

We picked up a Nintendo R.O.B. robot from our local online auction site and when it appeared we decided to figure out how to get it working. There are 3 motors inside, and the R.O.B. already comes with motor drivers and end-stops, so instead of driving the robot directly, we decided to control the R.O.B. using Circuit Playground Express (CPX) and Crickit!

The code is all in CircuitPython.

We use the Crickit for the amplified audio effects (we snagged some audio from gameplay to give it that authentic chiptune sound), driving an IR LED for signaling at 500 mA burst current so we could have it a few feet away, and the capacitive touch inputs for our desk controller.

With the addition of a D battery for the gyro turner, we had a fun live-action game without the need of a CRT!

Parts List

Wiring Diagram

The IR LED can handle up to 1 Amp peak current, so don't use a resistor, just wire it up to Drive 1 directly!

We use 4 capacitive touch sensors from the Crickit and 2 from CPX for 6 total (there are more capacitive touch inputs available on Crickit Signal pins but we wanted to use plain alligator pads!)

Wiring Diagram

Code!

Save to your CPX as code.py and touch the alligator clips to control your R.O.B.

The IR LED should be 1-2 feet away and pointed at the R.O.B.'s left eye (or, the right-most eye when you are looking at R.O.B)

It will calibrate when first starting up, and play some tunes.

Flip the switch on/off on the CPX to turn on/off the capacitive touch detection/command sending (if you need to adjust your cables without having the robot turn around on you!

To help you know what's going on, the NeoPixels on the CPX will glow to match the colors of the alligator clips shown above, so use those same colors! The only exception is black shows up as purple LEDs.

You may need to tweak the capacitive touch thresholds. Try uncommenting

#touch_vals = (touch2.raw_value, touch3.raw_value, seesaw.touch_read(0), seesaw.touch_read(1), seesaw.touch_read(2), seesaw.touch_read(3))

#print(touch_vals)

And watching the REPL to see what the values read are.

Copy Code
import time
import gc
from digitalio import DigitalInOut, Direction, Pull
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
import touchio
import audioio
import neopixel
import board

pixels = neopixel.NeoPixel(board.NEOPIXEL, 10, brightness=1)
pixels.fill((0,0,0))

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# switch
switch = DigitalInOut(board.SLIDE_SWITCH)
switch.direction = Direction.INPUT
switch.pull = Pull.UP

# We need some extra captouches
touch2 = touchio.TouchIn(board.A2)
touch3 = touchio.TouchIn(board.A3)

# LED for debugging
led = DigitalInOut(board.D13)
led.direction = Direction.OUTPUT

# Create drive (PWM) object
INFRARED_LED_SS = 13
my_drive = PWMOut(seesaw, INFRARED_LED_SS) # Drive 1 is on s.s. pin 13
my_drive.frequency = 1000 # Our default frequency is 1KHz

CAPTOUCH_THRESH = 850

# Commands, each 8 bit command is preceded by the 5 bit Init sequence
Init = [0, 0, 0, 1, 0] # This must precede any command
Calibrate = [1, 0, 1, 0, 1, 0, 1, 1] # the initial calibration
Up = [1, 0, 1, 1, 1, 0, 1, 1] # Move arms/body down
Down = [1, 1, 1, 1, 1, 0, 1, 1] # Move arms/body up
Left = [1, 0, 1, 1, 1, 0, 1, 0] # Twist body left
Right = [1, 1, 1, 0, 1, 0, 1, 0] # Twist body right
Close = [1, 0, 1, 1, 1, 1, 1, 0] # Close arms
Open = [1, 1, 1, 0, 1, 1, 1, 0] # Open arms
Test = [1, 1, 1, 0, 1, 0, 1, 1] # Turns R.O.B. head LED on

print("R.O.B. Start")


def IR_Command(cmd):
print("Sending ", cmd)
gc.collect() # collect memory now, timing specific!
# Output initialization and then command cmd
for val in Init cmd: # For each value in initial command
if val: # if it's a one, flash the IR LED
seesaw.analog_write(INFRARED_LED_SS, 65535) # on
seesaw.analog_write(INFRARED_LED_SS, 0) # off 2ms later
time.sleep(0.013) # 17 ms total
# pylint: disable=useless-else-on-loop
else:
time.sleep(0.015) # 17 ms total

a = audioio.AudioOut(board.A0)
startfile = "startup.wav"
loopfile = "loop.wav"
with open(startfile, "rb") as f:
wav = audioio.WaveFile(f)
a.play(wav)
for _ in range(3):
IR_Command(Calibrate)
time.sleep(0.5)
while a.playing:
IR_Command(Open)
time.sleep(1)
IR_Command(Close)
time.sleep(1)
f = open(loopfile, "rb")
wav = audioio.WaveFile(f)
a.play(wav, loop=True)

while True: # Main Loop poll switches, do commands
led.value = switch.value # easily tell if we're running
if not switch.value:
continue

#touch_vals = (touch2.raw_value, touch3.raw_value, seesaw.touch_read(0), seesaw.touch_read(1),
# seesaw.touch_read(2), seesaw.touch_read(3))
#print(touch_vals)

if touch2.raw_value > 3000:
print("Open jaws")
pixels.fill((50,50,0))
IR_Command(Open) # Button A opens arms

elif touch3.raw_value > 3000:
print("Close jaws")
pixels.fill((0,50,0))
IR_Command(Close) # Button B closes arms

elif seesaw.touch_read(0) > CAPTOUCH_THRESH:
print("Up")
pixels.fill((50,0,50))
IR_Command(Up)

elif seesaw.touch_read(1) > CAPTOUCH_THRESH:
print("Down")
pixels.fill((50,50,50))
IR_Command(Down)

elif seesaw.touch_read(2) > CAPTOUCH_THRESH:
print("Left")
pixels.fill((50,0,0))
IR_Command(Left)

elif seesaw.touch_read(3) > CAPTOUCH_THRESH:
print("Right")
pixels.fill((0,0,50))
IR_Command(Right)

time.sleep(0.1)
pixels.fill((0,0,0))

Gear Tower

Plastic toys are great for hacking, modding, and improving using Crickit! This box o' gears is fun for about 10 minutes...but when you add motors, sensors, and robotics you can make cool interactive art.

This example shows how to use the light sensor on the Circuit Playground Express to trigger a motor to rotate. With some audio effects, it becomes a Force trainer, or a moving Theremin.

Parts List

Wiring

Wiring Diagram

CircuitPython Code For "Force Wave" demo

This project is pretty simple, it looks to see when the light sensor is shaded by your hand and changes the motor from running to off or vice versa.

 

 

Copy Code
import time
from busio import I2C
import analogio
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import motor
import board

light = analogio.AnalogIn(board.LIGHT)

print("Wave on/off to turn")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create one motor on seesaw PWM pins 22 & 23
motor_a = motor.DCMotor(PWMOut(seesaw, 22), PWMOut(seesaw, 23))
motor_a.throttle = 0 # motor is stopped

while True:
print((light.value,))
# light value drops when a hand passes over
if light.value < 4000:
if motor_a.throttle:
motor_a.throttle = 0
else:
motor_a.throttle = 1 # full speed forward

while light.value < 5000:
# wait till hand passes over completely
pass
time.sleep(0.1)

CircuitPython Code For "Theremin" demo

We can adapt the code above to speed up or slow down the motor based on how far our hand is. The darker the sensor, the faster the motor spins!

 

 

Copy Code
import time
from busio import I2C
import analogio
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import motor
import board

light = analogio.AnalogIn(board.LIGHT)


print("Theramin-like turning")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create one motor on seesaw PWM pins 22 & 23
motor_a = motor.DCMotor(PWMOut(seesaw, 22), PWMOut(seesaw, 23))
motor_a.throttle = 0 # motor is stopped

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)

while True:
print((light.value,))
motor_a.throttle = map_range(light.value, 500, 8000, 1.0, 0)
time.sleep(0.1)

CPX-1701

 

 

This is the adventure of the United Space Ship CircuitPlayground. Assigned a five-year galaxy patrol, the bold crew of the giant starship explores the excitement of strange new worlds, uncharted civilizations, and exotic code. These are its voyages and its adventures.

Explore exciting new modes of propulsion by creating a really big vibrating motor. This Crickit project attaches a bunch of CDs to an up-cycled CD-ROM motor for a cool looking warp drive. Some popsicle sticks, NeoPixels, and sound effects complete the spacecraft and it's now ready for your command, captain!

Parts List

Wiring Diagram

Wiring Diagram

CircuitPython Code

This project is pretty simple, it plays some audio clips, and then lights up the built-in NeoPixels and powers up the motor in time with the effects.

Copy Code
import time
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import motor
import neopixel
import audioio
import board

print("The voyages of the CPX-1701!")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create one motor on seesaw PWM pins 22 & 23
motor_a = motor.DCMotor(PWMOut(seesaw, 22), PWMOut(seesaw, 23))

# audio output
cpx_audio = audioio.AudioOut(board.A0)

# neopixels!
pixels = neopixel.NeoPixel(board.NEOPIXEL, 10, brightness=1)
pixels.fill((0, 0, 0))

# give me a second before starting
time.sleep(1)

motor_a.throttle = 0 # warp drive off

f = open("01space.wav", "rb")
wav = audioio.WaveFile(f)
cpx_audio.play(wav)

t = time.monotonic() # take a timestamp

# slowly power up the dilithium crystals
for i in range(50):
pixels.fill((0, 0, i))
time.sleep(0.05)

# 6 seconds after audio started...
while time.monotonic() - t < 6:
pass

motor_a.throttle = 1 # full warp drive on!

# wait for music to end
while cpx_audio.playing:
pass
f.close()

# play the warp drive and theme music!
f = open("02warp.wav", "rb")
wav = audioio.WaveFile(f)
cpx_audio.play(wav)

time.sleep(1)

# blast off!
pixels.fill((255, 0, 0))

# pulse the warp core
while True:
for i in range(255, 0, -5):
pixels.fill((i, 0, 0))
for i in range(0, 255, 5):
pixels.fill((i, 0, 0))

# wait for music to end
while cpx_audio.playing:
pass
f.close()

Mag Neat-o

 

 

We picked up a magnetic foam shape kit, to make a fridge-mounted marble run. But picking up the marble after each run is such a drag - wouldn't it be fun if you could use your Crickit to help lift the ball back up and re-start the marble run?

With an electromagnet, we can pick up the stainless-steel balls. A DC motor acts as a pulley, and a servo helps align the electromagnet so it can navigate around the foam.

You can DIY, as we did, using the two Circuit Playground Express buttons and switch to control the motors - or you could even automate the whole thing!

Parts List

Wiring Diagram

Even though an electromagnet doesn't have 'direction' and thus could be controlled by a Drive pin, we opted for a Motor port because these electromagnets can draw up to 700 mA and that's more than the Drive pin. But, you could almost certainly get away with using a Drive pin if you like!

Wiring Diagram

Code!

Save to your CPX as code.py and press the CPX buttons to move the pulley up and down. Capacitive touch pads #1 and #4 twist the servo and then the switch enables and disables the electromagnet.

The most interesting part is smooth_move which is our gentle servo movement helper, it will carefully move the servo rather than jostling it and the magnet which would possibly cause the balls to fall.

Copy Code
import time
from busio import I2C
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import motor, servo
from digitalio import DigitalInOut, Direction, Pull
import board

print("Mag Neat-o!")

# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

# Create one motor on seesaw PWM pins 22 & 23
motor_a = motor.DCMotor(PWMOut(seesaw, 22), PWMOut(seesaw, 23))
# Create another motor on seesaw PWM pins 19 & 18
motor_b = motor.DCMotor(PWMOut(seesaw, 19), PWMOut(seesaw, 18))

# Create servo object
pwm = PWMOut(seesaw, 17) # Servo 1 is on s.s. pin 17
pwm.frequency = 50 # Servos like 50 Hz signals
my_servo = servo.Servo(pwm) # Create my_servo with pwm signa
my_servo.angle = 90

def smooth_move(start, stop, num_steps):
return [(start (stop-start)*i/num_steps) for i in range(num_steps)]

buttona = DigitalInOut(board.BUTTON_A)
buttona.direction = Direction.INPUT
buttona.pull = Pull.DOWN

buttonb = DigitalInOut(board.BUTTON_B)
buttonb.direction = Direction.INPUT
buttonb.pull = Pull.DOWN

switch = DigitalInOut(board.SLIDE_SWITCH)
switch.direction = Direction.INPUT
switch.pull = Pull.UP

last_buttona = buttona.value
last_buttonb = buttonb.value
last_switch = switch.value

last_touch1 = False
last_touch4 = False


while True:
touch_vals = (seesaw.touch_read(0), seesaw.touch_read(3))
# print(touch_vals)

touch1 = False
if seesaw.touch_read(0) > 500:
touch1 = True

if touch1 != last_touch1:
if touch1:
start_angle = my_servo.angle
end_angle = start_angle - 20
end_angle = max(0, min(end_angle, 180))
print("left from", start_angle, "to", end_angle)
for a in smooth_move(start_angle, end_angle, 25):
my_servo.angle = a
time.sleep(0.03)
last_touch1 = touch1

touch4 = False
if seesaw.touch_read(3) > 500:
touch4 = True

if touch4 != last_touch4:
if touch4:
start_angle = my_servo.angle
end_angle = start_angle 20
end_angle = max(0, min(end_angle, 180))
print("right from", start_angle, "to", end_angle)
for a in smooth_move(start_angle, end_angle, 25):
my_servo.angle = a
time.sleep(0.03)
last_touch4 = touch4

if buttona.value != last_buttona:
if buttona.value:
print("down")
if motor_a.throttle:
print("haulin!")
motor_b.throttle = -0.1
else:
motor_b.throttle = -0.1
else:
motor_b.throttle = 0
last_buttona = buttona.value

if buttonb.value != last_buttonb:
if buttonb.value:
print("up")
if motor_a.throttle:
print("haulin!")
motor_b.throttle = 0.4
else:
motor_b.throttle = 0.3
else:
motor_b.throttle = 0
last_buttonb = buttonb.value

if switch.value != last_switch:
motor_a.throttle = switch.value
if motor_a.throttle:
print("GRAB")
else:
print("RELEASE")
last_switch = switch.value

time.sleep(0.01)

(Don't Fear) The Crickit

 

 

Parts List

Wiring Diagram

Wiring Diagram

For the remote, we soldered four wires

  • Black ground wire to the battery spring (negative) terminal
  • Red 5V wire to the battery flat (positive) terminal
  • White and Purple go to the 'switched' part of each switch, which, when connected to 5V activates that switch

For the remote, we soldered four wires

CircuitPython Code

Copy Code
import time
import audioio
from digitalio import DigitalInOut, Pull, Direction
from adafruit_seesaw.seesaw import Seesaw
from adafruit_seesaw.pwmout import PWMOut
from adafruit_motor import servo
from busio import I2C
import neopixel
import board


# Create seesaw object
i2c = I2C(board.SCL, board.SDA)
seesaw = Seesaw(i2c)

led = DigitalInOut(board.D13)
led.direction = Direction.OUTPUT

# Two onboard CPX buttons for FOG
buttona = DigitalInOut(board.BUTTON_A)
buttona.direction = Direction.INPUT
buttona.pull = Pull.DOWN

buttonb = DigitalInOut(board.BUTTON_B)
buttonb.direction = Direction.INPUT
buttonb.pull = Pull.DOWN


# Use the signal port for potentiometer w/switch
MORECOW = 2 # A switch on Signal #1
SWITCH = 3 # A potentiometer on Signal #2
# Add a pullup on the switch
seesaw.pin_mode(SWITCH, seesaw.INPUT_PULLUP)

# Servo angles
BELL_START = 60
BELL_END = 75
MOUTH_START = 95
MOUTH_END = 105

# Create servos list
servos = []
for ss_pin in (17, 16): #17 is labeled 1 on CRICKIT, 16 is labeled 2
pwm = PWMOut(seesaw, ss_pin)
pwm.frequency = 50 #must be 50 cannot change
_servo = servo.Servo(pwm, min_pulse=400, max_pulse=2500)
servos.append(_servo)
# Starting servo locations
servos[0].angle = BELL_START
servos[1].angle = MOUTH_START

# For the fog machine we actually use the PWM on the motor port cause it really needs 5V!
fog_off = PWMOut(seesaw, 22)
fog_off.duty_cycle = 0
fog_on = PWMOut(seesaw, 23)
fog_on.duty_cycle = 0


# Audio playback object and helper to play a full file
a = audioio.AudioOut(board.A0)
def play_file(wavfile):
with open(wavfile, "rb") as file:
wavf = audioio.WaveFile(file)
a.play(wavf)
while a.playing:
servos[1].angle = MOUTH_START
time.sleep(.2)
servos[1].angle = MOUTH_END
time.sleep(.2)

# NeoPixels for EYES
pixels = neopixel.NeoPixel(board.A1, 9, brightness=0.5)
pixels[8] = (255, 255, 0)
pixels[7] = (255, 255, 0)


# Maps a number from one range to another.
def map_range(x, in_min, in_max, out_min, out_max):
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)


# Wait before starting up
time.sleep(3)
play_file("i-gotta-have-more-cowbell.wav")
# a pause between audio clips
time.sleep(1)
play_file("only-prescription-more-cowbell.wav")

while seesaw.digital_read(SWITCH):
pass

print("Ready for playing audio")
time.sleep(1)

f = open("fear11.wav", "rb")
wav = audioio.WaveFile(f)
a.play(wav)

while True:
if seesaw.digital_read(SWITCH):
break # time to bail!
pot = seesaw.analog_read(MORECOW)
print(pot)
eyecolor = (int(map_range(pot, 0, 1023, 255, 0)), int(map_range(pot, 0, 1023, 0, 255)), 0)
pixels[8] = eyecolor
pixels[7] = eyecolor

if buttonb.value:
fog_on.duty_cycle = 65535
else:
fog_on.duty_cycle = 0

if buttona.value:
fog_off.duty_cycle = 65535
else:
fog_off.duty_cycle = 0

if pot < 200: # wait for a bit before we start
continue
delay = map_range(pot, 200, 1023, 1.0, 0.1)
servos[0].angle = BELL_END
time.sleep(0.1)
servos[0].angle = BELL_START
time.sleep(delay)

a.stop()
f.close()

# Fog machine test
fog_off.duty_cycle = 65535
fog_on.duty_cycle = 0
time.sleep(0.1)
fog_off.duty_cycle = 0

pixels[8] = (255, 255, 0)
pixels[7] = (255, 255, 0)
time.sleep(1.5)
play_file("i-coulda-used-more-cow-bell.wav")

Arduino Code

Download Adafruit_Seesaw library

To begin using your Crickit with the Arduino IDE, you will need to install the Adafruit_seesaw library.

Start up the IDE and open the Library Manager:

Start up the IDE and open the Library Manager

Type in seesaw until you see the Adafruit Library pop up. Click Install!

Type in seesaw until you see Adafruit Library pop up

We also have a great tutorial on Arduino library installation at:

http://learn.adafruit.com/adafruit-all-about-arduino-libraries-install-use

Arduino Servos

Arduino Servos

Test Servos

Let’s start by controlling some servos. You'll want at least one servo to plug in and test out the servo code. Visit our recommended servo page to check that you have a servo that works. Once you do, plug in a servo into SERVO #1 spot, making sure the yellow or white wire is next to the 1 text label.

This example will show rotating one servo from 0 to 180 degrees with a stop at 90 degrees.

Copy Code
#include "Adafruit_Crickit.h"
#include "seesaw_servo.h"

Adafruit_Crickit crickit;
seesaw_Servo myservo(&crickit); // create servo object to control a servo

void setup() {
Serial.begin(115200);

if(!crickit.begin()){
Serial.println("ERROR!");
while(1);
}
else Serial.println("Crickit started");

myservo.attach(CRICKIT_SERVO1); // attaches the servo to CRICKIT_SERVO1 pin
}

void loop() {
myservo.write(0);
delay(1000);
myservo.write(90);
delay(1000);
myservo.write(180);
delay(1000);
myservo.write(90);
delay(1000);
}

Are your servos not moving a full 180 degrees? Don't fret! This is normal, see below about min/max pulse lengths to 'tune' your servo!

More Servos!

OK, that was fun but you want MORE servos, right? You can control up to four! The servos are on the seesaw pins 17 (CIRCKIT_SERVO1), 16 (CIRCKIT_SERVO2), 15 (CIRCKIT_SERVO3), 14 (CIRCKIT_SERVO4).

This example is similar to the 1 servo example, but instead of creating one myservo object, we'll make an array called servos that contains 4 servo objects. Then we can assign them using servo[0].write(90); or iterate through them as we do in the loop. You don't have to do it this way, but it’s very compact and doesn't take a lot of code lines to create all 4 servos at once!

Copy Code
#include "Adafruit_Crickit.h"
#include "seesaw_servo.h"

Adafruit_Crickit crickit;

#define NUM_SERVOS 4

//create an array of 4 servos with our crickit object
seesaw_Servo servos[] = { seesaw_Servo(&crickit),
seesaw_Servo(&crickit),
seesaw_Servo(&crickit),
seesaw_Servo(&crickit) };

//these are the pins they will be attached to
int servoPins[] = { CRICKIT_SERVO1, CRICKIT_SERVO2, CRICKIT_SERVO3, CRICKIT_SERVO4 };

void setup() {
Serial.begin(115200);

//begin the crickit
if(!crickit.begin()){
Serial.println("ERROR!");
while(1);
}
else Serial.println("Crickit started");

//attach the servos to their pins
for(int i=0; i<NUM_SERVOS; i )
servos[i].attach(servoPins[i]); // attaches the servo to the pin
}

void loop() {
//repeat for all 4 servos
for(int i=0; i<NUM_SERVOS; i ){
servos[i].write(0);
delay(1000);
servos[i].write(90);
delay(1000);
servos[i].write(180);
delay(1000);
servos[i].write(90);
delay(1000);
}
}

Min/Max Pulse control

In theory, servos should all use 1 ms to 2 ms long pulses, at 50 Hz to set the 0 and 180-degree locations. However, not all servos have their full range at those pulse widths. You can easily tweak your code to change the min and max pulse widths, which will let your servo turn more left and right. But don't set the widths too small/large or you can hit the hard stops of the servo which could damage it, so try tweaking the numbers slowly until you get a sense of what the limits are for your motor.

All you need to do is change the

myservo.attach(CRICKIT_SERVO1);

to, say,

myservo.attach(CRICKIT_SERVO1, 750, 2250);

Here we've changed the minimum pulse from the default 1000 microseconds to 750, and the default maximum pulse from 2000 microseconds to 2250. Again, each servo differs. Some experimentation may be required!

Continuous Rotation Servos

If you're using continuous servos, you can use the angle assignments and just remember that 0 is rotating one way, 90 is 'stopped' and 180 and rotating the other way.

If your continuous servo doesn't stop once the script is finished you may need to tune the min and max pulse timings so that the center makes the servo stop. Or check if the servo has a center-adjustment screw you can tweak.

Disconnecting Servos or Custom Pulses

If you want to 'disconnect' the Servo by sending it 0-length pulses, you can do that by 'reaching in' and adjusting the underlying PWM duty cycle with:

myservo.writeMicroseconds(0);

Likewise, you can set the duty cycle to a custom value with

myservo.writeMicroseconds(number);

where number is the pulse length in microseconds between 0 (off) and 20000 (fully on). For example, setting it to 10000 will be 50% duty cycle, at the 50 Hz update rate.

Arduino Drives

Arduino Drives

Test Drive

Let’s start by controlling a drive output. You'll need to plug something into the 5V and DRIVE1 terminal blocks. I'm just using a simple LED with a resistor but anything that can be powered by 5V will work.

  • Note that the drive outputs cannot have a 5V output so you must connect the positive pin of whatever you're driving to 5V. Don't try connecting the positive pin to the drive, and the negative pin to GND, it won’t work!
  • Drive outputs are PWM-able!
  • PWM values can be anywhere between 0 (0% duty cycle or always off) and 65535 (100% duty cycle or always on). A value of 32768 would be 50% duty cycle, or on for half of the period and then off for half the period.

This example will show turning the drive output fully on and off once a second. The macros CRICKIT_DUTY_CYCLE_OFF and CRICKIT_DUTY_CYCLE_MAX correspond to 0 and 65535 respectively and are used for readability:

Copy Code
#include "Adafruit_Crickit.h"

Adafruit_Crickit crickit;

void setup() {
Serial.begin(115200);
Serial.println("1 Drive demo!");

if(!crickit.begin()){
Serial.println("ERROR!");
while(1);
}
else Serial.println("Crickit started");

//our default frequency is 1khz
crickit.setPWMFreq(CRICKIT_DRIVE1, 1000);
}

void loop() {
//turn all the way on
crickit.analogWrite(CRICKIT_DRIVE1, CRICKIT_DUTY_CYCLE_OFF);
delay(500);

//turn all the way off
crickit.analogWrite(CRICKIT_DRIVE1, CRICKIT_DUTY_CYCLE_MAX);
delay(500);
}

More Drivers!

OK, that was fun but you want MORE drives, right? You can control up to four! The four drive outputs are on the seesaw pins 13 (CRICKIT_DRIVE1), 12 (CRICKIT_DRIVE2), 43 (CRICKIT_DRIVE3), 42 (CRICKIT_DRIVE4).

Copy Code
#include "Adafruit_Crickit.h"

Adafruit_Crickit crickit;

#define NUM_DRIVES 4
int drives[] = {CRICKIT_DRIVE1, CRICKIT_DRIVE2, CRICKIT_DRIVE3, CRICKIT_DRIVE4};

void setup() {
Serial.begin(115200);
Serial.println("4 Drive demo!");

if(!crickit.begin()){
Serial.println("ERROR!");
while(1);
}
else Serial.println("Crickit started");

//our default frequency is 1khz
for(int i=0; i<NUM_DRIVES; i )
crickit.setPWMFreq(drives[i], 1000);
}

void loop() {
for(int i=0; i<NUM_DRIVES; i ){
//turn all the way on
crickit.analogWrite(drives[i], CRICKIT_DUTY_CYCLE_OFF);
delay(100);

//turn all the way off
crickit.analogWrite(drives[i], CRICKIT_DUTY_CYCLE_MAX);
delay(100);
}
}

This example is similar to the 1 drive example, but instead of using just 1 PWM driver, we'll make an array called drives that contains the pin numbers of 4 PWM drivers. Then we can assign them using crickit.analogWrite(drives[0], CRICKIT_DUTY_CYCLE_MAX); or iterate through them as we do in the loop. You don't have to do it this way, but it’s very compact and doesn't take a lot of code lines to create all 4 drivers at once!

Arduino DC Motors

Arduino DC Motors

You can drive two separate DC motors, so let’s go ahead and get right to it!

DC motors are controlled by 4 PWM output pins, the 4 PWM pins let you control speed and direction. And we'll use our seesaw_Motor library to help us manage the throttle (speed) and direction for us, making it very easy to control motors.

Note that each DC motor is a little different, so just because you have two at the same throttle does not mean they'll rotate at the exact same speed! Some tweaking may be required.

The two wires of the DC motor can be plugged in either way into each Crickit Motor port. If the motor spins the opposite way from what you want to call 'forward', just flip the wires!

Copy Code
#include "Adafruit_Crickit.h"
#include "seesaw_motor.h"

Adafruit_Crickit crickit;

seesaw_Motor motor_a(&crickit);
seesaw_Motor motor_b(&crickit);

void setup() {
Serial.begin(115200);
Serial.println("Dual motor demo!");

if(!crickit.begin()){
Serial.println("ERROR!");
while(1);
}
else Serial.println("Crickit started");

//attach motor a
motor_a.attach(CRICKIT_MOTOR_A1, CRICKIT_MOTOR_A2);

//attach motor b
motor_b.attach(CRICKIT_MOTOR_B1, CRICKIT_MOTOR_B2);
}

void loop() {
motor_a.throttle(1);
motor_b.throttle(-1);
delay(1000);

motor_a.throttle(.5);
motor_b.throttle(-.5);
delay(1000);

motor_a.throttle(0);
motor_b.throttle(0);
delay(1000);

motor_a.throttle(-.5);
motor_b.throttle(.5);
delay(1000);

motor_a.throttle(-1);
motor_b.throttle(1);
delay(1000);

motor_a.throttle(0);
motor_b.throttle(0);
delay(500);
}

Arduino Signals

Signals on the Crickit are available on the following pins:

Arduino Signals

You can use these as analog or digital I/O pins, setting the mode, value and reading with the seesaw library directly:

Copy Code
#include "Adafruit_Crickit.h"

Adafruit_Crickit crickit;

#define BUTTON_1 CRICKIT_SIGNAL1
#define BUTTON_2 CRICKIT_SIGNAL2
#define LED_1 CRICKIT_SIGNAL3
#define LED_2 CRICKIT_SIGNAL4

void setup() {
Serial.begin(9600);

if(!crickit.begin()){
Serial.println("ERROR!");
while(1);
}
else Serial.println("Crickit started");

//Two buttons are pullups, connect to ground to activate
crickit.pinMode(BUTTON_1, INPUT_PULLUP);
crickit.pinMode(BUTTON_2, INPUT_PULLUP);

// Two LEDs are outputs, on by default
crickit.pinMode(LED_1, OUTPUT);
crickit.pinMode(LED_2, OUTPUT);
crickit.digitalWrite(LED_1, HIGH);
crickit.digitalWrite(LED_2, HIGH);
}

void loop() {
if(!crickit.digitalRead(BUTTON_1))
crickit.digitalWrite(LED_1, HIGH);
else
crickit.digitalWrite(LED_1, LOW);

if(!crickit.digitalRead(BUTTON_2))
crickit.digitalWrite(LED_2, HIGH);
else
crickit.digitalWrite(LED_2, LOW);
}

Hacks and Upgrades

Brown Outs?

The power supply on the Crickit will let you draw 4 Amps at once, which is a lot. But perhaps you are turning on all the motors at once, causing the power supply to flicker? An extra-large capacitor on the 5V and GND pads may help smooth out that power draw!

Use a large electrolytic capacitor, rated for 10V or higher. Even though the power supply is 5V, you may think you can use a 6.3V capacitor, but you want at least 2x the voltage rating if possible so stick to 10V!

  • 4700 uF 10V Electrolytic Capacitor

Connect the capacitor using the NeoPixel terminal blocks. The 5V and GND lines are shared across the board so even if it’s a DC motor or servo causing the issues, this will help! It's just the most convenient place to attach a large capacitor because the two terminal blocks are nicely spaced.

Connect capacitor using the NeoPixel terminal blocks

Connect the capacitor using the NeoPixel terminal blocks. The 5V and GND lines are shared across the board so even if it’s a DC motor or servo causing the issues, this will help!

Connect the Positive (longer leg) to 5V and the Negative (shorter leg) to GND.

F.A.Q.

Why did you misspell "Cricket"?

We wanted a unique name, inspired by the original Cricket robotics platform from MIT (which then became the PicoCricket), but not with the exact same name!

Downloads

Files

Datasheets

Latest seesaw Firmware

seesaw.UF2

Schematics

Schematics

Click to Enlarge

Schematics

Click to Enlarge

Schematics

Click to Enlarge

Mfr Part # 3287
BATTERY HOLDER AA 3 CELL LEADS
Adafruit Industries LLC
Mfr Part # 2201
SERVOMOTOR RC 4.8V
Adafruit Industries LLC
Mfr Part # 169
SERVOMOTOR RC 5V TOWERPRO
Adafruit Industries LLC
Mfr Part # 2307
SERVOMOTOR RC 6V HP/TORQUE METAL
Adafruit Industries LLC
SQUARE FORCE-SENSITIVE RESISTOR
Mfr Part # 1075
SQUARE FORCE-SENSITIVE RESISTOR
Adafruit Industries LLC
Mfr Part # 1142
SERVOMOTOR RC 5V HIGH TORQUE
Adafruit Industries LLC
Mfr Part # DRV8833PWPR
IC MOTOR DRIVER PAR 16HTSSOP
Texas Instruments
Mfr Part # 711
STANDARD MOTOR 9100 RPM 6V
Adafruit Industries LLC
Mfr Part # 2941
STANDARD MOTOR 130 RPM 5V
Adafruit Industries LLC
Mfr Part # 3802
GEARMOTOR 120 RPM 3-6V ALL-METAL
Adafruit Industries LLC
Mfr Part # 3801
GEARMOTOR 120 RPM 3-6V BI-METAL
Adafruit Industries LLC
Mfr Part # ULN2003ADR
IC PWR RELAY 7NPN 1:1 16SOIC
Texas Instruments
Mfr Part # 1163
SMT ADAPTERS 3 PACK 32QFN/TQFP
Adafruit Industries LLC
Mfr Part # 771
BATT HOLDER AA 3 CELL 6" LEADS
Adafruit Industries LLC
Mfr Part # 369
ADAPT TERM BL 2POS TO 2.1MM PLG
Adafruit Industries LLC
Mfr Part # 1385
EVAL BOARD FOR MP2307
Adafruit Industries LLC
Mfr Part # 3763
THIN WHITE WHEEL FOR TT DC GEARB
Adafruit Industries LLC
Mfr Part # 2744
WHEEL FOR FS90R SERVO
Adafruit Industries LLC
Mfr Part # 3216
MINI ROUND ROBOT CHASSIS KIT
Adafruit Industries LLC
Mfr Part # 3244
MINI 3-LAYER ROUND ROBOT CHASSIS
Adafruit Industries LLC
Mfr Part # 2939
MINI ROBOT ROVER CHASSIS KIT
Adafruit Industries LLC
Mfr Part # 972
SERVO EXTENSION CBL 30CM
Adafruit Industries LLC
Mfr Part # 973
SERVO EXTENSION CBL 19.5" LONG
Adafruit Industries LLC
Mfr Part # 154
SERVOMOTOR RC 5V CONT ROTATE
Adafruit Industries LLC
Mfr Part # 2442
SERVOMOTOR RC 130 RPM 5V
Adafruit Industries LLC
Mfr Part # 1143
SERVOMOTOR RC 5V HIGH TORQUE
Adafruit Industries LLC
Mfr Part # 1314
SPEAKER 4OHM 3 DIAMETER
Adafruit Industries LLC
Mfr Part # 1674
SPEAKER 8OHM 1W 90.1DB
Adafruit Industries LLC
Mfr Part # 11015
SOLENOID PUSH INTERMITTENT 5V
SparkFun Electronics
Mfr Part # 1201
VIBRATION ERM MTR 11000 RPM 5V
Adafruit Industries LLC
PANEL MOUNT 1K POTENTIOMETER (BR
Mfr Part # 1789
PANEL MOUNT 1K POTENTIOMETER (BR
Adafruit Industries LLC
Mfr Part # 324
STEPPER MOTOR HYBRID BIPOLAR 12V
Adafruit Industries LLC
Mfr Part # 858
STEPPER MOTOR PM GEARED UNI 5V
Adafruit Industries LLC
Mfr Part # 3333
CIRCUIT PLAYGROUND EXPRESS
Adafruit Industries LLC
Mfr Part # 3093
CRICKIT CIRCUIT PLAYGROUND EXP
Adafruit Industries LLC
NT$1,041
View More Details
Mfr Part # 3777
GEARMOTOR 200 RPM 3-6V DC
Adafruit Industries LLC
Mfr Part # 3630
ADDRESS LED STRIP R/G/B/W
Adafruit Industries LLC
Mfr Part # IR333-A
EMITTER IR 940NM 100MA RADIAL
Everlight Electronics Co Ltd
Mfr Part # P160KN2-4QC20B10K
POT 10K OHM 1/5W PLASTIC LINEAR
TT Electronics/BI
Mfr Part # 2056
KNOB KNURLED 0.236" METAL
Adafruit Industries LLC
Mfr Part # 3631
ADDRESS LED STRIP R/G/B/W
Adafruit Industries LLC
Add all DigiKey Parts to Cart
Have questions or comments? Continue the conversation on TechForum, DigiKey's online community and technical resource.