Using USB Controllers (RC-28, Shuttle, Stream Deck, sunSDR, etc)

This page describes how to use USB-connected controllers with wfview to control your radio.

Hardware controllers offer an immensely-improved user experience for tuning, changing modes, PTT, and more.

shuttle pro v2 quick keys RC-28 sunsdr controller xkeys streamdeck2 streamdeck1mirabox

Supported Controllers

wfview supports the following USB controllers natively:

You can have a look at the top portion of usbcontrollers.cpp for the complete list, if you are curious about it.

Preliminary Setup

You will need to connect the USB device to your computer. It is important that there are no other programs using the device. Generally drivers are not necessary since these devices are “HID Compliant”. Therefore, do not install any drivers or other software. wfview needs access to the USB device without any other programs or software using it at the same time.

Windows and macOS users: You should not need any preliminary setup. Please continue to the section wfview Controller Setup.

Linux Setup for ShuttlePro

Linux users will need to stop their desktop from using the ShuttlePRO wheel as a scroll wheel. This can be done per the following bash shell script taken from this reddit post:

#!/bin/bash
for DEV in `xinput --list | grep -i ShuttlePro | cut -d"=" -f2 | awk {'print $1'}`
do
     xinput disable ${DEV}
done

Linux users will also need the following udev rule, placed in /etc/udev/rules.d, which gives the user permission to access the shuttle device:

Contents of /etc/udev/rules.d/99-shuttle.rules:

# for newer PRO model
ATTRS{name}=="Contour Design ShuttlePro" MODE="0644"
# for older PRO model
ATTRS{name}=="Contour Design ShuttlePRO v2" MODE="0644"
# for the Xpress model
ATTRS{name}=="Contour Design ShuttleXpress" MODE="0644"
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0b33", ATTRS{idProduct}=="0020", MODE="0666"
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0b33", ATTRS{idProduct}=="0030", MODE="0666"

To activate the new rules, just pull the USB plug out and push it back in, that simple.

wfview Controller Setup

You will need wfview version 1.57 or greater. Currently the 1.60 release is recommended.

Connect the USB controller, and then, launch wfview. Click “Settings” followed by “External Control”. Check the box “Enable USB Controllers”. Then press “Setup USB Controller”.

wfview access to USB Controller Setup

The controller setup window will appear. This window is different for each type of supported USB Controller. Here is how it looks for the Contour ShuttlePRO V2:

wfview ShuttlePRO V2 Setup

To assign a function to a button, right-click on the desired controller button. Two pop-up menus will appear. The top-most pop-up menu lets you select a function for when the selected button is pressed down. This is what most users will want for most functions. The bottom menu lets you select what will happen when the button is released. Generally, the bottom menu should be set to “None”. Sometimes you will need to right-click in an empty space in order to remove the menu and reveal other buttons (we’re working on a better way to do this).

wfview USB controller button menus

To program a traditional PTT button, like a handheld microphone, where the button is held down while you are transmitting, select “PTT On” for the press (top) function and “PTT Off” for the release (bottom).

Here’s a screenshot of a traditional PTT button setup:

traditional ptt button hold down mode

For a PTT “sticky toggle” function like the radio’s chassis transmit button on an Icom, select “PTT Toggle” for the top menu and select “None” for the release (bottom) menu. This will make it transmit when you tap it and receive when you tap it again.

Press “Ok”

Important: Do not forget to press “Save Settings”!!