This repository was dropped in favour of this Repo. The newer repo is directly forked from marlin and should be easier to maintain. Furthermore, features like bed levling are working like a charm out of the box. The newer Repo dropped the LVGL-Gui in favour of the more raw stock marlin 2.0 color touch UI. This Menu is just a lot snappier and less bugging around. I mean: Imagine your printer stopping, while a new menu screen is beeing loaded... I think you get it.
This fork is a Marlin version, based on the original branch of MKS (board manufacturer), and was created to bring Marlin 2.0 with the easy configurability of Marlin implementation from l3tspeak to TwoTrees printers like the Sapphire Plus an Pro. This brings back the original GUI that originally came with your printer but with full configurability.
- Sapphire Pro
- Sapphire Plus (Dual-Z and belt-synced versions)
- Bluer
- Sapphire Pro/Plus with E3D Hemera
As I own a Sapphire Plus with a Hemera, this will be the only tested version by myself. So be carefull with those other versions at the until you trust them. At least the software Z-Endstop of the Pro has to be adjusted. Please feel free to bring in your own modifications and do a pull-request or verify modifications I'm not able to verify.
I am not responsible for bricked devices, dead SD cards, thermonuclear war, or having some unsupervised 3D-Printer (which probably does not match your countries electrical safety standarts anyway) burning down your house. I would recommend you to have at least your configured factory firmware ready, in case the firmware is maybe not working, as intended.
YOU are choosing to make these modifications, and if you point the finger at me for messing up your device, I will laugh at you.
Do everything at your own risk! But it's probably worth it anyway huh?
If you do not have a clou, what VS-Code or PlatformIO is: This is the way for you!
You are going to find some precompiled firmware binaries under the section "releases" on this page. You will find a file named "Robin_nano35.bin" in the .zip, that is according to your machine. Just put that one onto a SD-Card. Put the card into your (switched off) machine and switch it on after that. Your machine will update itself (progress-bar is shown) and start the firmware after that. The Screen has to be calibrated at the first startup.
The preconfigurations for the E3D Hemera are optimized for this mount (Seems to work best). I remixed the mount for the useage of an EBM Pabst RLF35, beacause we can (See Thingiverse). You have to also do some spacers between the platform and Z-endstops (See Photos of the RLF35 Mount). The cables of the Hemera are not long enougth. Just take the factory ones for that last part. Nobody wants to go back from a hemera anyway, right?
You can't find your particular firmware, just want to do some modifications or have I been to lazy to rebuilt the binaries (again)? Then go for it. It's Marlin. You probably know how to work with it. To make life easier, the Firmware includes some precompiler definitions, inspired by user l3tspeaks "TwoTrees Marlin 2.0 Firmware".
There are some defintions in the Marlin Configuration.h
and one further defintion in Configuration_adv.h
. Definitions are
//#define SAPPHIRE_PRO
//#define SAPPHIRE_PLUS
//#define SAPPHIRE_PLUS_DUAL_Z
//#define E3D_HEMERA
//#define BL_TOUCH
Uncomment your personal machine and options, if needed. Only the function of the Sapphire Plus Dual Z with E3D Hemera is verified yet. The factory will probably work fine. The Hemera will work probably fine with the Sapphire Plus models. At that point you are going to find other features, like the neo-pixel implementation anyway...
As now (January 2021) All TwoTrees Printers seem to be delivered with the Robin Nano V1. It might be, that they switch to V2 or V3 in the meantime. Just a hint for troubleshooting...
Please also keep the direct information of the MKS repository in mind.
No Problem. Take a look at this Repository. Same stuff, but with the stock Marlin UI. It's proven to be stable.
The firmware of MKS Robin Nano, based on Marlin2.0.x, added the LittlevGL, supporting colourful GUI and touch screen. It is developed on PlatformIO, we hope more and more developers will participate the development of this repository.
As the firmware is based on Marlin2.0.x which is built on the core of PlatformIO, the buid compiling steps are the same as Marlin2.0.x. You can directly using PlatformIO Shell Commands, or using IDEs contain built-in PlatformIO Core(CLI), for example, VSCode and Atom. VSCode is recommended.
The images should be added to gcode file when slicing, and MKS has developed the plugin for Cura to make it.
- Open LVGL online image converter tool.
- Open bmp images.
- Enter the saved file name.
- Choose color format:True color.
- Choose file output format:Binary RGB565.
- Start convertion.
- Save bin file.
- Copy the converted bin file to the assets folder.
- Copy the assets folder to the SD card.
- SD card is connected to the motherboard, and you can see the update interface after powering on.
- Build config:
-
platformio.ini:
default_envs = mks_robin_nano35
-
Configuation.h:
#define SERIAL_PORT 3
#define MKS_ROBIN_TFT35
#define MOTHERBOARD BOARD_MKS_ROBIN_NANO
#define TFT_LVGL_UI
#define TOUCH_SCREEN
- Update firmware:
- Enter the
.pio\build\mks_robin_nano35
directory, copy theassets
folder andRobin_nano35.bin
to the sd card - Insert SD card to the motherboard, and you can see the update interface after power on.
- Build config:
-
platformio.ini:
default_envs = mks_robin_nano35
-
Configuation.h:
#define SERIAL_PORT 3
#define MKS_TS35_V2_0
#define MOTHERBOARD BOARD_MKS_ROBIN_NANO_V2
#define TFT_LVGL_UI
#define TOUCH_SCREEN
- Update firmware:
- Enter the
.pio\build\mks_robin_nano35
directory, copy theassets
folder andRobin_nano35.bin
to the sd card - Insert SD card is to the motherboard, and you can see the update interface after power on.
- Build config:
-
platformio.ini:
default_envs = mks_robin_nano_v3_usb_flash_drive_msc
-
Configuation.h:
#define SERIAL_PORT -1
#define MKS_TS35_V2_0
#define MOTHERBOARD BOARD_MKS_ROBIN_NANO_V3
#define TFT_LVGL_UI
#define TOUCH_SCREEN -
Configuation_adv.h:
Now you can either use the TF card or USB disk, use TF card:
// #define USB_FLASH_DRIVE_SUPPORT
Use USB disk:
#define USB_FLASH_DRIVE_SUPPORT
- Update firmware:
- Enter the
.pio\build\mks_robin_nano35
directory, copy theassets
folder andRobin_nano_v3.bin
to the sd card or usb disk - Insert sdcard or usb disk to the motherboard, and you can see the update interface after power on.
- Example build config:
- Open the example configuration file.
- Modify the parameters, replace configuration.h and configuration_adv.h in the Marlin path of the source code.
- Compile the firmware.
- Prebuilt *.bin firmware for update
- We have prebuilt the robin nano v3 firmware for some type of printers and some extended usage.
Please refer to MKS Robin Nano github.
Please refer to MKS Robin Nano V2 github.
Please refer to MKS Robin Nano V3 github.