Skip to content

FAQ

Quick answers to common questions about HelixScreen.


HelixScreen is a touchscreen interface for Klipper 3D printers. It connects to your Moonraker instance and provides a modern, touch-friendly UI for controlling your printer.

Key features:

  • 30+ panels, 20+ overlays, and a customizable multi-page widget dashboard
  • 3D G-code preview, bed mesh visualization, frequency response charts
  • 6 multi-material backends (AFC, Happy Hare, ACE, AD5X IFS, CFS, tool changers) with Spoolman integration
  • First-run wizard with auto-detection of 70+ printer models
  • Theme editor with 17 presets (dark and light), 9 languages
  • Sound system, timelapse integration, label printing, exclude objects
  • Auto-detecting layout system for displays from 480x320 to 1920x480
  • ~13MB RAM — designed for embedded displays, no desktop required

HelixScreen works with any Klipper-based printer running Moonraker. Tested and supported platforms:

PlatformStatusNotes
Voron 0.1, 2.4, TridentTestedPrimary development platforms
Doron Velta / RatRig V-CoreTested
FlashForge AD5M / 5M ProTestedRequires Forge-X or Klipper Mod firmware
QIDI Q2, Max 4SupportedRequires FreeDi firmware for Moonraker access
Creality K1 / K1C / K1 Max / K1 SESupportedRequires rooting or Guilouz firmware
Creality K2 Max / K2 PlusTestedRuns natively with CFS support
Creality Sonic PadSupported32-bit ARM, dedicated build
FlashForge AD5XTestedIFS filament system integrated
SOVOL SV06 / SV08TestedCommunity reports welcome
Elegoo Centauri Carbon 1TestedRequires OpenCentauri COSMOS firmware; ships with factory white-balance calibration
Other Klipper printersShould workAny printer with Moonraker API access

Note: “Tested” means the HelixScreen team has verified the platform. “Untested” means binaries exist but haven’t been verified on real hardware. See the Installation Guide for platform-specific instructions.

Tested and confirmed working:

  • BTT 5” HDMI/DSI touchscreen
  • BTT 7” HDMI/DSI touchscreen
  • FlashForge AD5M built-in 4.3” display (800x480)

Active testing underway:

  • FlashForge AD5X built-in 4.3” display (800x480)

Should work but not yet tested:

  • Official Raspberry Pi 7” DSI touchscreen
  • Creality K2 built-in 4.3” display (480x800, portrait — may need rotation)
  • Other HDMI displays
  • SPI displays (with proper configuration)

Display sizes: HelixScreen auto-detects the best layout for your display. 800x480, 1024x600, and 1920x480 (ultrawide) are fully supported. 480x320 displays will run but may have layout overlap issues — improved small-screen support is ongoing.

Display rotation: All three binaries (main, splash, watchdog) support 0°, 90°, 180°, and 270° rotation via config or command line.

If you test on hardware not listed above, please let us know your results!

How is this different from KlipperScreen and GuppyScreen?

Section titled “How is this different from KlipperScreen and GuppyScreen?”
FeatureHelixScreenKlipperScreenGuppyScreen
UI FrameworkLVGL 9 XMLGTK 3 (Python)LVGL 8 (C)
Declarative UIFull XMLPython onlyC only
Disk Size~75-115MB~50MB~60-80MB
RAM Usage~13MB~50MB~15-20MB
Reactive BindingBuilt-inManualManual
3D G-code previewYes2D layersNo
3D bed meshYes2D heatmap2D heatmap
StatusPre-1.0 (active)Mature (maintenance)Unmaintained

HelixScreen advantages:

  • Low memory footprint (~13MB vs ~50MB for KlipperScreen)
  • Declarative XML layouts (change UI without recompiling)
  • Modern reactive architecture with 6 multi-material backends
  • 3D visualizations (G-code preview, bed mesh)
  • 70+ printer auto-detection database
  • 9 languages (English, German, Spanish, French, Italian, Japanese, Portuguese, Russian, Chinese)

Pi ModelSupportedNotes
Pi 5✅ RecommendedBest performance
Pi 4✅ RecommendedGreat performance
Pi 3B+✅ MinimumWorks well
Pi 3B⚠️ UsableMay be slow
Pi Zero 2 W✅ OKGood for space-constrained setups
Pi Zero (original)❌ NoToo slow

Memory: 1GB minimum, 2GB+ recommended.

32-bit and 64-bit: Both are supported. The installer automatically detects your architecture (uname -m) and downloads the correct binary — aarch64 gets the 64-bit build, armv7l gets the 32-bit build. No manual selection needed.

Can I run HelixScreen alongside KlipperScreen/GuppyScreen?

Section titled “Can I run HelixScreen alongside KlipperScreen/GuppyScreen?”

Not on the same display. Both compete for the framebuffer. The HelixScreen installer automatically disables any existing screen UI.

MainsailOS (systemd):

Terminal window
# Disable KlipperScreen
sudo systemctl stop KlipperScreen
sudo systemctl disable KlipperScreen
# Enable HelixScreen
sudo systemctl enable helixscreen
sudo systemctl start helixscreen

AD5M Klipper Mod (SysV init):

Terminal window
# Disable KlipperScreen
/etc/init.d/S80klipperscreen stop
chmod -x /etc/init.d/S80klipperscreen
# Enable HelixScreen
chmod +x /etc/init.d/S80helixscreen
/etc/init.d/S80helixscreen start

AD5M Forge-X (SysV init):

Terminal window
# Disable GuppyScreen
/etc/init.d/S60guppyscreen stop
chmod -x /etc/init.d/S60guppyscreen
# Enable HelixScreen
chmod +x /etc/init.d/S90helixscreen
/etc/init.d/S90helixscreen start

If you have two displays, you could theoretically run both (advanced configuration, not tested).

Do I need to install X11 or a desktop environment?

Section titled “Do I need to install X11 or a desktop environment?”

No. HelixScreen renders directly to the framebuffer (fbdev) or DRM. It doesn’t need:

  • X11 / Xorg
  • Wayland
  • Desktop environment (GNOME, KDE, etc.)
  • Display manager (LightDM, GDM, etc.)

This is why it uses less memory than alternatives.

Does this work with MainsailOS, FluiddPi, or other Klipper distros?

Section titled “Does this work with MainsailOS, FluiddPi, or other Klipper distros?”

Yes! HelixScreen works with any Klipper distribution that includes Moonraker:

  • MainsailOS ✅
  • FluiddPi ✅
  • Custom Klipper installs ✅
  • KIAUH installs ✅

The web frontend you use (Mainsail, Fluidd, etc.) doesn’t matter - HelixScreen talks to Moonraker.

Your configuration is safe. The installer preserves:

  • settings.json — all your settings
  • helixscreen.env — environment variable overrides
  • Custom printer images in config/custom_images/
  • Custom theme files in config/themes/

Your Klipper configuration is never touched. See the Upgrade Guide for instructions.

My display is upside down or rotated wrong

Section titled “My display is upside down or rotated wrong”

Set the rotation in your config file:

Terminal window
# Edit settings.json and add/change in the "display" section:
"rotation": 180

Valid values: 0, 90, 180, 270. Restart HelixScreen after changing.


Does it support multiple extruders / toolchangers?

Section titled “Does it support multiple extruders / toolchangers?”

Yes. Full multi-extruder and toolchanger support:

  • ✅ Per-extruder temperature control with extruder selector in the Temperature panel
  • ✅ Toolchanger support via klipper-toolchanger — active tool badge on Home panel (T0, T1, etc.)
  • ✅ Tool-prefixed temperatures on the print status overlay
  • ✅ Dynamic discovery of all extruders from Klipper (extruder, extruder1, extruder2, etc.)
  • ✅ Multiple filament systems can run simultaneously (e.g. toolchanger + Happy Hare)

Yes. HelixScreen shows your webcam feed on the home dashboard and during printing. It automatically detects webcams configured in Moonraker (crowsnest, camera-streamer, etc.) and displays the MJPEG stream.

For the best camera performance on Raspberry Pi, install libturbojpeg0:

Terminal window
sudo apt install libturbojpeg0

This enables SIMD-accelerated (hardware-optimized) JPEG decoding, which is 3-5x faster than the built-in software decoder. HelixScreen automatically uses it if available — no configuration needed. Without it, everything still works, just with slightly higher CPU usage during camera streaming.

Yes. Spoolman integration is supported:

  • Advanced panelSpoolman to browse your spool inventory
  • SettingsSpoolman for weight sync settings
  • Assign spools to AMS slots and track filament usage

Yes. HelixScreen supports printing physical spool labels to thermal label printers:

  • Brother QL — via Network or Bluetooth
  • Phomemo — via USB or Bluetooth
  • Niimbot — via Bluetooth (B21, D11, D110)
  • MakeID — via Bluetooth (E1, L1, M1 — 9/12/16mm continuous tape)

Labels include spool name, material, color swatch, temperatures, and a QR code. See the Label Printing Guide for setup.

Does it support Happy Hare or AFC-Klipper?

Section titled “Does it support Happy Hare or AFC-Klipper?”

Yes. Full multi-material support is available for:

  • Happy Hare — MMU2, ERCF, 3MS, Tradrack
  • AFC-Klipper — Box Turtle with full data parsing, 11 device actions, per-lane reset, and mock mode
  • ACE (Anycubic ACE Pro, via ValgACE/BunnyACE/DuckACE Klipper drivers) — supported
  • Tool changers — supported

Features include visual slot configuration with tool badges, endless spool arrows, tap-to-edit popup, Spoolman integration, and material compatibility validation.

Yes! The Home Panel displays configurable widgets — quick-access buttons for features like temperature, LED control, network status, AMS, and more.

To customize:

  1. Go to SettingsHome Widgets (in the Appearance section)
  2. Toggle widgets on or off
  3. Long-press the drag handle to reorder

Up to 10 widgets can be shown. Some widgets (like AMS, humidity sensor, or probe) only appear if the relevant hardware is detected. See the Home Panel guide for the full widget list.

Yes! HelixScreen includes a built-in theme editor with 17 preset themes:

  1. Go to SettingsDisplay Settings
  2. Tap Theme to open the theme editor
  3. Choose from presets: Ayu, Catppuccin, ChatGPT, Cupertino, Dracula, Everforest, Gruvbox, HelixScreen, Kanagawa, Material Design, Midnight, Nord (default), One Dark, Rose Pine, Solarized, Tokyo Night, or Yami
  4. Toggle dark/light mode
  5. Customize individual colors if desired - changes are saved to config/themes/

For layout customization, you can edit XML files in ui_xml/ (no recompilation needed).

Yes! You can configure multiple Klipper printers and switch between them from the navigation bar or Settings. You view one printer at a time, but switching is instant. Enable this under SettingsBeta Features, then add printers via SettingsPrinters.

Yes. The History panel shows past prints with statistics, thumbnails, and details. Access via the navbar or home screen.

Yes. The Console panel lets you send G-code commands and view responses. Access via AdvancedConsole.

Yes. If you have Moonraker power devices configured, the Power panel lets you control them. Access via SettingsSystemPower Devices, or AdvancedPower, or long-press the home panel power button.

Yes. The Bed Mesh panel shows a 3D visualization of your bed mesh and lets you run calibration. Access via ControlsBed Mesh.

Yes. The Input Shaper panel provides a full calibration workflow with frequency response charts, per-axis results, shaper comparison tables, and Save Config. Access via AdvancedInput Shaper. Requires an accelerometer configured in Klipper.

Yes. During a print, you can exclude objects that failed. Tap the print status area to access exclude object controls.

Yes. The Macro panel shows your Klipper macros. Access via AdvancedMacros. You can also configure quick macro buttons in SettingsMacro Buttons.

Can I change which macro the Load / Unload / Purge buttons run?

Section titled “Can I change which macro the Load / Unload / Purge buttons run?”

Yes. Go to Settings > Printer > Macro Buttons and scroll to the Standard Macros section. Each button has a dropdown where you can select any macro from your Klipper config, or choose (Auto) to let HelixScreen detect it automatically. This works with or without an AMS system — see the Filament guide for details.

Can I customize the printer image on the home screen?

Section titled “Can I customize the printer image on the home screen?”

Yes. Tap the printer image on the Home Panel to open the Printer Manager, then tap the image again to open the Printer Image picker. You have three options:

  • Auto-Detect (default) — HelixScreen picks an image based on your printer type from Klipper
  • Shipped Images — Choose from 25+ pre-rendered images (Voron, Creality, FlashForge, Anycubic, RatRig, etc.)
  • Custom Images — Drop a PNG or JPEG file into config/custom_images/ and it appears automatically the next time you open the picker. You can also import images directly from a USB drive. Files must be under 5MB and 2048x2048 pixels max.

Your selection is saved to the display.printer_image config key and persists across restarts. See the Printer Manager guide for step-by-step instructions.

Yes. Tap the printer image on the Home Panel to open the Printer Manager. Then tap the printer name (shown with a pencil icon) to enable inline editing. Type the new name and press Enter to save, or Escape to cancel. The name syncs automatically with Mainsail and Fluidd. See the Printer Manager guide for details.

HelixScreen ships with 9 languages: English, German, Spanish, French, Italian, Japanese, Portuguese, Russian, and Chinese. Change the language in SettingsLanguage.

Only if you opt in. Telemetry is off by default. When enabled, it collects anonymous usage data (display resolution, platform, print outcomes) to help improve the software. No filenames, G-code, IP addresses, or personal information is ever collected. You can view, disable, and delete your data at any time in SettingsTelemetry. See the Telemetry page for full details.


Yes. HelixScreen automatically detects USB mice and keyboards connected at startup. Both work alongside the touchscreen — you don’t have to choose one or the other. A small white cursor appears when a mouse is detected. Combo devices like the Logitech K400 (keyboard + trackpad) also work.

Devices must be plugged in before HelixScreen starts. If auto-detection doesn’t find your device, set HELIX_MOUSE_DEVICE or HELIX_KEYBOARD_DEVICE in helixscreen.env to the device path (run cat /proc/bus/input/devices to find it).

If taps register in the wrong location:

  1. Go to Settings (gear icon)
  2. Scroll to System section
  3. Tap Touch Calibration
  4. Tap the crosshairs that appear on screen
  5. Calibration saves automatically when complete

Note: This option only appears on touchscreen displays, not in the desktop simulator.

  1. Go to SettingsDisplay Settings
  2. Tap Theme to open the theme editor
  3. Browse available presets and see live preview
  4. Toggle dark/light mode
  5. Tap Apply to save (some changes require restart)

Tap the Tune button on the print status screen to access:

  • Print Speed (50-200%) - Adjust movement speed
  • Flow Rate (75-125%) - Adjust extrusion rate
  • Z-Offset - Baby stepping for first layer adjustment

Fan control is available from the home screen fan widget or controls panel.

Does HelixScreen support firmware retraction?

Section titled “Does HelixScreen support firmware retraction?”

Yes, if your printer has [firmware_retraction] configured in Klipper. Go to SettingsRetraction Settings (under Printer section) to adjust:

  • Retract length and speed
  • Unretract extra length and speed
  • Enable/disable firmware retraction

This option only appears if Klipper reports firmware retraction capability.

  1. Check your display connection: SPI displays are significantly slower than HDMI or DSI. If possible, use an HDMI or DSI-connected display for best performance.
  2. Disable animations: Go to Settings → toggle Animations off
  3. Check CPU/memory via SSH: Run top or htop to see if something else is using resources
  4. Reduce logging: If you added -vv or -vvv to the service, remove it
  5. Consider a faster SBC: Pi 4 or Pi 5 will be noticeably smoother than a Pi 3 or Pi Zero

The wizard runs when no valid configuration exists. Causes:

  1. Config file missing or deleted
  2. Config file has invalid JSON
  3. Permissions prevent reading config

Fix: Check /opt/helixscreen/config/settings.json exists and is valid JSON.

There’s currently no UI to change this after initial setup. Your options:

Edit the config file directly:

Terminal window
sudo nano /opt/helixscreen/config/settings.json
# Edit moonraker_host and moonraker_port in the "printer" section
sudo systemctl restart helixscreen

Or re-run the setup wizard:

Terminal window
# Either delete the config to trigger wizard on next start:
sudo rm /opt/helixscreen/config/settings.json
sudo systemctl restart helixscreen
# Or force wizard with command-line flag:
helix-screen --wizard

  1. Check input device: ls /dev/input/event*
  2. Test manually: sudo evtest /dev/input/event0
  3. Specify device: Add "touch_device": "/dev/input/event1" to input section in config
  1. Check service: sudo systemctl status helixscreen
  2. Check logs: sudo journalctl -u helixscreen -n 50
  3. Check framebuffer: ls /dev/fb* or ls /dev/dri/*
  4. Try specifying device: Add "drm_device": "/dev/dri/card1" to display section in config
  1. Check Moonraker: sudo systemctl status moonraker
  2. Test manually: curl http://localhost:7125/printer/info
  3. Check firewall: sudo ufw status
  4. Verify IP: hostname -I

See TROUBLESHOOTING.md for more solutions.


Yes! HelixScreen is licensed under GPL v3. Source code is on GitHub.

See the Contributing Guide for:

  • Code standards
  • Development setup
  • Pull request process

We welcome:

  • Bug reports
  • Feature suggestions
  • Code contributions
  • Documentation improvements

See the Development Guide for build instructions, dependencies, and development setup.

  • C++17 for application logic
  • XML for UI layouts (LVGL 9 declarative system)
  • Makefile for build system
  • Bash for scripts

Open an issue on GitHub Issues with:

  • HelixScreen version
  • Hardware info (Pi model, display)
  • Steps to reproduce
  • Relevant log output

Open a GitHub issue with the “enhancement” label, or suggest it in the Discord.

Easiest method: Go to Settings > System > Log Level and select Debug from the dropdown. The change takes effect immediately — no restart needed. Set it back to Warn when you’re done.

Alternative (via config file): Add HELIX_LOG_LEVEL=debug to your helixscreen.env file and restart:

Terminal window
# MainsailOS / Pi
echo 'HELIX_LOG_LEVEL=debug' >> ~/helixscreen/config/helixscreen.env
sudo systemctl restart helixscreen
# AD5M (Forge-X)
echo 'HELIX_LOG_LEVEL=debug' >> /opt/helixscreen/config/helixscreen.env
/etc/init.d/S90helixscreen restart

Available levels: warn (default), info, debug, trace. Set back to Warn after debugging — verbose logging impacts performance.

Terminal window
# systemd journal (MainsailOS)
sudo journalctl -u helixscreen -f
# If using file logging
cat /var/log/helix-screen.log
# or
cat ~/.local/share/helix-screen/helix.log

For more details, see: