I'm spending a lot of time in virtual meetings due to COVID. Apps like Teams and Zoom offer a way to connect with my co-workers.
For one-on-one meetings an open mic is fine but during group meetings I keep my mic muted unless I’m talking. This keeps my background noise from interrupting the speaker and is generally good form in group meetings.
I picked up an app called Talk Toggle which provides system wide Push-To-Talk functionality> I then configured it to recognize F13 as its hotkey and remapped the menu key to send F13 with AutoHotKey. On the Mac the app MuteKey has similar functionality.
While I had a passing "push-to-talk" setup I kept forgetting to press the PTT hotkey when I started talking. I needed something I could hold in my hands as a reminder. A quick google and I saw that there were options but they all cost more then I wanted to pay or didn't work like I wanted. I decided to build my own PTT solution.
- Handheld push button - I use the Philmore 30-825, but any momentary switch will work.
- I recently added a Linemaster T-91-S foot pedel that works well.
- Any micro-controller that can emulate an HID will work. Two options are:
- USB Cable - A-Male to Mini-B Cord
- Heat shrink tube
- Miscellaneous wires. I used an broken USB-C cable and some wires I had laying around.
Connect wires between the handheld push button poles and pins B1
and GND
. This is a simple switch so it doesn't matter which wire is connected to which pin. I used a breadboard and some jumper wires to avoid soldering to the teensy board. Heat shrink up any soldered wires too keep things safe and looking clean.
Start up Teensy and load the below code onto the teensy. It will detect when B1 is closed and will press ALT+SPACE
. With the above Talk Toggle or MuteKey, pressing the ALT+SPACE
will unmute the mics. Release the PTT button and the teensy will release ALT+SPACE
, reactivating mic mute.
#include <Bounce.h>
Bounce buttonPTT = Bounce(PIN_B1, 10);
void setup() {
pinMode(PIN_B1, INPUT_PULLUP); // PTT button
pinMode(PIN_D6, OUTPUT); // LED
}
void loop() {
buttonPTT.update();
// When the button is pushed, send ALT+SPACE down
if (buttonPTT.fallingEdge()) {
Keyboard.press(MODIFIERKEY_ALT);
Keyboard.press(KEY_SPACE);
digitalWrite(PIN_D6, HIGH); // LED ON
}
// When the button is release, send ALT+SPACE release
if(buttonPTT.risingEdge()) {
Keyboard.release(MODIFIERKEY_ALT);
Keyboard.release(KEY_SPACE);
digitalWrite(PIN_D6, LOW); // LED OFF
}
}
At $4 US, these are cheap MPC drive the cost of the project to less then $20 (slightly more than the cost of the Teensy alone). My main reluctance in using the pico is that HID emulation is currently not supported in the MicroPython. Instead I use CircuitPython to emulate a keyboard with the Adafruit HID library. CircuitPython (as of 2021-03-06) shows up as a USB drive when plugged in which makes for easy code editing but some companies have strict no-USB drive policy on company laptops. As a result the pico option is not as widely usable as the Teensy which just shows up as a keyboard.
Connect wires between the handheld push button poles and pins GP15
and 3v3
. This is a simple switch so it doesn't matter which wire is connected to which pin. I used a breadboard and some jumper wires to avoid soldering to the pico board. Heat shrink up any soldered wires too keep things safe and looking clean.
- Download CircuitPython. Select the UF2 and then install it on the pico. The pico will reboot after copying the UF2 file over. When it comes up, the pico will be accessable via the file browser.
- Download Adafruit_CircuitPython_HID for HID functionality. Expand and then copy the lib folder contents to the pico lib folder
- Create a file called
code.py
on the pi pico. This will be the main code for your keyboard emulator. - Add the below code to
code.py
. It will send a F13 key press when the button is pushed and release F13 when the button is released.
import time
import digitalio
import board
import usb_hid
from adafruit_hid.keyboard import Keyboard
from adafruit_hid.keycode import Keycode
# Emulate the HID Keyboard
keyboard = Keyboard(usb_hid.devices)
# Grab the LED for status indication
led = digitalio.DigitalInOut(board.LED)
led.direction = digitalio.Direction.OUTPUT
# Assign GP15 to the button
button_1 = digitalio.DigitalInOut(board.GP15)
button_1.direction = digitalio.Direction.INPUT
button_1.pull = digitalio.Pull.DOWN
is_active = False
while True:
if button_1.value:
led.value = True # Light up the LED to indicate the activity
keyboard.press(Keycode.F13) # Send F13
is_active = True # Track if the button is in a pushed state
elif(is_active): # only send the release if the button is active
led.value = False # Turn off the LED as activity is stopping
keyboard.release(Keycode.F13) # Release F13
is_active = False # Indicate the button is no longer pushed.
time.sleep(0.1)
Using the teensy or pico for this project is a bit of overkill. I am planning on making a macro-keyboard, similar to the DIY Stream Deck. With it I will be able to switch between OBS streams and potentially enable notification lights.
- Original Inspiration
- Helped me code the Teensy
- Using Pico as an HID - Provided a good basis for using the pico as an HID.
- DIY Macro Keyboard video - Helped my craft my code for the pico.
- Pico StreamDeck - Well this just looks cool.