README.md
wfview
wfview is an open-source front-end application for the
- Icom IC-705 HF portable SDR Amateur Radio
- Icom IC-7300 HF SDR Amateur Radio
- Icom IC-7610 HF SDR Amateur Radio
- Icom IC-7850 HF Hybrid SDR Amateur Radio
- Icom IC-7851 HF Hybrid SDR Amateur Radio
- Icom IC-9700 VHF/UHF SDR Amateur Radio
Other models to be tested/added (including the IC-705)..
website - WFVIEW wfview.org
wfview supports viewing the spectrum display waterfall and most normal radio controls. Using wfview, the radio can be operated using the mouse, or just the keyboard (great for those with visual impairments), or even a touch screen display. The gorgous waterfall spectrum can be displayed on a monitor of any size, and can even projected onto a wall for a presentation. Even a VNC session can make use of wfview for interesting remote rig posibilities. wfview runs on humble hardware, ranging from the $35 Raspberry Pi, to laptops, to desktops. wfview is designed to run on GNU Linux, but can probably be adapted to run on other operating systems. In fact we do have working example in windows as well.
wfview is unique in the radio control ecosystem in that it is free and open-source software and can take advantage of modern radio features (such as the waterfall). wfview also does not "eat the serial port", and can allow a second program, such as fldigi, access to the radio via a pseudo-terminal device.
For screenshots, documentation, User FAQ, Programmer FAQ, and more, please see the project's wiki.
wfview is copyright 2017-2020 Elliott H. Liggett. All rights reserved. wfview source code is licensed via the GNU GPLv3.
Features:
- Plot bandscope and bandscope waterfall. Optionally, also plot a "peak hold". A splitter lets the user adjust the space used for the waterfall and bandscope plots.
- Double-click anywhere on the bandscope or waterfall to tune the radio.
- Entry of frequency is permitted under the "Frequency" tab. Buttons are provided for touch-screen control
- Bandscope parameters (span and mode) are adjustable.
- Full keyboard and mouse control. Operate in whichever way you like. Most radio functions can be operated from a numberic keypad! This also enables those with visual impairments to use the IC-7300.
- 100 user memories stored in plain text on the computer
- Stylable GUI using CSS
- pseudo-terminal device, which allows for secondary program to control the radio while wfview is running
- works for radios that support the ethernet interface with compareable waterfall speeds as on the radio itself.
Build Requirements:
- gcc / g++ / make
- qmake
- qt5 (proably the package named "qt5-default")
- libqt5serialport5-dev
- libqcustomplot-dev
Recommended:
- Debian-based Linux system (Debian Linux, Linux Mint, Ubuntu, etc) or opensuse 15.x. Any recent Linux system will do though!
- QT Creator for building, designing, and debugging w/gdb
Build directions:
See INSTALL.md for directions.
Rig setting:
- CI-V Baud rate: Auto
- CI-V address: 94h (default)
- CI-V Transceive ON
- CI-V USB-> REMOTE Transceive Address: 00h
- CI-V Output (for ANT): OFF
- CI-V USB Port: Unlink from REMOTE
- CI-V USB Baud Rate: 15200
- CI-V USB Echo Back: OFF
- Turn on the bandscope on the rig screen
- Note: The program currently assumes the radio is on a device like this:
/dev/serial/by-id/usb-Silicon_Labs_CP2102_USB_to_UART_Bridge_Controller_IC-7300_02010092-if00-port0
This is symlinked to a device like /dev/ttyUSB0 typically. Make sure the port is writable by your username. You can accomplish this using udev rules, or if you are in a hurry:
sudo chown `whoami` /dev/ttyUSB*
TODO (for developers and contributors):
- Re-work pseudo term code into separate thread
- Consider XML RPC to make flrig/fldigi interface easier
- Add hide/show for additional controls: SWR, ALC, Power, S-Meter interface
- Fix crash on close (order of delete operations is important)
- Add support for other compatible CI-V radios (IC-706, IC-7100, IC-7610, etc)
- Better settings panel (select serial port, CI-V address, more obvious exit button)
- Add support for festival or other text-to-speech method using the computer (as apposed to the radio's speech module)
see also the wiki: