OpenHantek6022 is a free software for Hantek DSO6022 USB digital signal oscilloscopes that is actively developed on github.com/OpenHantek/OpenHantek6022 - but only for Hantek 6022BE/BL and compatible scopes (Voltcraft, Darkwire, Protek, Acetech, etc.).
- About OpenHantek6022
- AC coupling
- Continuous Integration
- Building OpenHantek6022 from source
- Install prebuilt binary packages
- Run OpenHantek6022
- Specifications, features, limitations and developer documentation
- Other DSO open source software
- Other related software
Demo mode is provided by the
--demoModecommand line option.
Fully supported operating system: Linux; developed under debian stable (currently bullseye) for amd64 architecture.
Compiles under FreeBSD (packaging / installation: work in progress, thx tspspi).
Other operating systems builds: Windows (mostly untested) & macOS (completely untested). No support for non-Linux related issues unless a volunteer steps in!
Uses free open source firmware, no longer dependent on nonfree Hantek firmware.
Extensive User Manual with technical specs and schematics.
- Voltage and Spectrum view for all device supported channels.
- CH1 and CH2 name becomes red when input is clipped (bottom left).
- Settable probe attenuation factor 1..1000 to accommodate a variety of different probes.
- Measure and display Vpp, DC (average), AC, RMS and dB (of RMS) values as well as frequency of active channels.
- Display the power dissipation for a load resistance of 1..1000 Ω (optional, can be set in Oscilloscope/Settings/Analysis).
- Display the THD of the signal (optional, can be set in Oscilloscope/Settings/Analysis).
- Math channel modes: CH1+CH2, CH1-CH2, CH2-CH1, CH1*CH2 and AC part of CH1 or CH2.
- Time base 10 ns/div .. 10 s/div.
- Sample rates 100, 200, 500 S/s, 1, 2, 5, 10, 20, 50, 100, 200, 500 kS/s, 1, 2, 5, 10, 12, 15, 24, 30 MS/s (24 & 30 MS/s in CH1-only mode).
- 48 MS/s not supported due to unstable USB data streaming.
- Downsampling (up to 200x) increases resolution and SNR.
- Calibration output square wave signal frequency can be selected between 32 Hz .. 100 kHz in small steps (poor man's signal generator).
- Trigger modes: Normal, Auto and Single with green/red status display (top left).
- Untriggered Roll mode can be selected for slow time bases of 200 ms/div .. 10 s/div.
- Trigger filter HF (trigger also on glitches), Normal and LF (for noisy signals).
- Display interpolation modes Off, Linear, Step and Sinc.
- Calibration values loaded from eeprom or a model configuration file.
- Calibration program to create these values automatically.
- Digital phosphor effect to notice even short spikes; simple eye-diagram display with alternating trigger slope.
- Histogram function for voltage channels on right screen margin.
- A zoom view with a freely selectable range.
- Cursor measurement function for voltage, time, amplitude and frequency.
- Export of the graphs to JPG, PNG or PDF file or to the printer; data export as CSV or JSON.
- Freely configurable colors.
- Automatic adaption of iconset for light and dark themes.
- The dock views on the main window can be customized by dragging them around and stacking them. This allows a minimum window size of 800*300 for old laptops or workstation computers.
- All settings can be saved to a configuration file and loaded again.
- Chinese, French, German, Polish, Russian and Spanish localisation complete, Italian and Portuguese translation ongoing - volunteers welcome!
A little HW modification adds AC coupling. OpenHantek6022 supports this feature since v2.17-rc5 / FW0204.
Every commit triggers a workflow on GitHub Actions that builds and packages OpenHantek6022 for:
- Linux (
- macOS (
- Windows (
Building OpenHantek6022 from source
The preferred way to run OpenHantek6022 is to build it from source on your system, especially under Linux.
The easiest way to get an up-to-date working code base is to clone the code from here via
git clone https://github.com/OpenHantek/OpenHantek6022.git
and then build it locally, for this you will need the following software:
- CMake 3.5+
- Qt 5.4+
- FFTW 3+ (prebuild files will be downloaded on windows)
- libusb-1.0, version >= 1.0.16 (prebuild files will be used on windows)
- A compiler that supports C++11 - tested with gcc, clang and msvc
To make building for Linux even easier, I provide two shell scripts:
LinuxSetup_AsRoot, which installs all build requirements. You only need to call this script once (as root) if you have cloned the project.
LinuxBuildconfigures the build, builds the binary and finally creates the packages (deb, rpm and tgz) that can be installed as described in the next paragraph. If you make small changes to the local source code, it is sufficient to call
fakeroot make -j4 packagein the
Install prebuilt binary packages
- Download Linux (built on Ubuntu 1804 LTS), Raspberry Pi (Debian stable), FreeBSD (12.1), macOS (Catalina 10.15) and Windows (Visual Studio 2019) packages for your convenience from the Releases page.
- If you want to follow ongoing development, packages built from a fairly recent commit are available in the unstable release.
- For RPi4 see also issue #28.
- These binary packages are built on stable operating system versions and require an up-to-date system.
- As I develop on a Debian stable system my preferred (native) package format is
*.deb. The program itself and the
*.debpackage built on my local system is tested for completeness and correctness. The precompiled packages are only randomly tested - if at all - and the installation of the
*.rpmpackages is untested.
- To install the downloaded
*.debpackage, open a terminal window, go to the package directory and enter the command (as root)
apt install ./openhantek_..._amd64.deb. This command will automatically install all dependencies of the program as well.
- For installation of
*.rpmpackages follow similar rules, e.g.
dnf install ./openhantek-...-1.x86_64.rpm.
*.tar.gzachives contain the same files as the
*.rpmpackages for quick testing - do not use for a permanent installation. Do not report any issues about the
- Get macOS packages from macports - thx ra1nb0w.
- Get Fedora rpm packages - thx Vascom.
- Download (untested) builds from last commit(s). Select the preferred
workflow runand go to
On a Linux system start the program via the menu entry OpenHantek (Digital Storage Oscilloscope) or from a terminal window as
You can explore the look and feel of OpenHantek6022 without the need for real scope hardware by running it from the command line as:
OpenHantek6022 uses the OpenGL graphics library to display the data. It requires a graphics card that supports
3D rendering and runs on legacy HW/SW that supports at least OpenGL 2.1+ or OpenGL ES 1.2+.
OpenGL is selected by default, but if this does not work (i.e. the black scope window shows an error message
or closes immediately after startup), you can choose the less resource-hungry OpenGL ES variant as a fallback
by starting OpenHantek from the command line as follows:
OpenHantek -e or
Especially on Windows, this option may be necessary to use the program.
The Raspberry Pi build uses OpenGL ES automatically, check also the graphics driver setup.
USB access for the device is required (unless using demo mode):
- On Linux, you need to copy the file
/usr/lib/udev/rules.d/and replug your device. If OpenHantek is installed from a
*.rpmpackage this file is installed automatically into
Windows USB access
- The original Hantek driver for Windows doesn't work! You have to assign the correct WinUSB driver with one of these two solutions:
- Use the tool Zadig and follow the good step-by-step tutorial provided by DaPa.
- Install the signed WinUSB driver provided by VictorEEV.
The scope doesn't store the firmware permanently in flash or eeprom, it must be uploaded after each power-up and is kept in ram 'til power-down. If the scope was used with a different software (old openhantek, sigrok or the windows software) the scope must be unplugged and replugged one-time before using it with OpenHantek6022 to enable the automatic loading of the correct firmware. The top line of the program must display the correct firmware version (FW0209).
Specifications, features, limitations and developer documentation
I use this project mainly to explore how DSP software can improve and extend the limitations of this kind of low level hardware. It would have been easy to spend a few bucks more to buy a powerful scope - but it would be much less fun :) Please refer also to the developer info.
We welcome any reported GitHub issue if you have a problem with this software. Send us a pull request for enhancements and fixes. Some random notes:
- Read how to properly contribute to open source projects on GitHub.
- Create a separate branch other than main for your changes. It is not possible to directly commit to main on this repository.
- Write good commit messages.
- Use the same coding style and spacing -> install clang-format and use make target:
make formator execute directly:
clang-format -style=file -i *.cpp *.h.
- It is mandatory that your commits are Signed-off-by:, e.g. use git's command line option
-sto append it automatically to your commit message:
git commit -s -m 'This is my good commit message'
- Open a pull request with a clear title and description.
- Read Add a new device if you want to know how to add a device.
- We recommend QtCreator as IDE on all platforms. It comes with CMake support, a decent compiler, and Qt out of the box.
Other DSO open source software
- Firmware used by OpenHantek and python bindings for 6022BE/BL
- Software for the Hantek 6022BE/BL (win only)
Other related software
- HScope for Android A one-channel basic version is available free of charge (with in-app purchases).