2017-11-02 20:57:08 -05:00
|
|
|
/**
|
|
|
|
* Marlin 3D Printer Firmware
|
2020-02-03 08:00:57 -06:00
|
|
|
* Copyright (c) 2020 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
|
2017-11-02 20:57:08 -05:00
|
|
|
*
|
|
|
|
* Based on Sprinter and grbl.
|
2019-06-27 23:57:50 -05:00
|
|
|
* Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
|
2017-11-02 20:57:08 -05:00
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
2020-07-23 05:20:14 +02:00
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
2017-11-02 20:57:08 -05:00
|
|
|
*
|
|
|
|
*/
|
2018-10-23 16:00:34 -05:00
|
|
|
#pragma once
|
2017-11-02 20:57:08 -05:00
|
|
|
|
2018-11-13 01:47:45 -06:00
|
|
|
#include "../../inc/MarlinConfig.h"
|
|
|
|
|
2017-11-02 20:57:08 -05:00
|
|
|
// use this file to create the public interface for device drivers that are NOT in the U8G library
|
|
|
|
|
|
|
|
extern u8g_dev_t u8g_dev_st7565_64128n_HAL_2x_sw_spi;
|
|
|
|
extern u8g_dev_t u8g_dev_st7565_64128n_HAL_2x_hw_spi;
|
2018-11-13 01:47:45 -06:00
|
|
|
|
|
|
|
class U8GLIB_64128N_2X_HAL : public U8GLIB {
|
|
|
|
public:
|
2021-04-08 22:35:21 -03:00
|
|
|
U8GLIB_64128N_2X_HAL() : U8GLIB() { }
|
|
|
|
U8GLIB_64128N_2X_HAL(pin_t sck, pin_t mosi, pin_t cs, pin_t a0, pin_t reset = U8G_PIN_NONE) { init(sck, mosi, cs, a0, reset); }
|
|
|
|
U8GLIB_64128N_2X_HAL(pin_t cs, pin_t a0, pin_t reset = U8G_PIN_NONE) { init(cs, a0, reset); }
|
|
|
|
void init(pin_t sck, pin_t mosi, pin_t cs, pin_t a0, pin_t reset = U8G_PIN_NONE) {
|
|
|
|
U8GLIB::init(&u8g_dev_st7565_64128n_HAL_2x_sw_spi, (uint8_t)sck, (uint8_t)mosi, (uint8_t)cs, (uint8_t)a0, (uint8_t)reset);
|
|
|
|
}
|
|
|
|
void init(pin_t cs, pin_t a0, pin_t reset = U8G_PIN_NONE) {
|
|
|
|
U8GLIB::init(&u8g_dev_st7565_64128n_HAL_2x_hw_spi, (uint8_t)cs, (uint8_t)a0, (uint8_t)reset);
|
|
|
|
}
|
2017-11-02 20:57:08 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
extern u8g_dev_t u8g_dev_st7920_128x64_HAL_4x_sw_spi;
|
|
|
|
extern u8g_dev_t u8g_dev_st7920_128x64_HAL_4x_hw_spi;
|
2018-11-13 01:47:45 -06:00
|
|
|
|
|
|
|
class U8GLIB_ST7920_128X64_4X_HAL : public U8GLIB {
|
|
|
|
public:
|
2021-04-08 22:35:21 -03:00
|
|
|
U8GLIB_ST7920_128X64_4X_HAL() : U8GLIB() { }
|
|
|
|
U8GLIB_ST7920_128X64_4X_HAL(pin_t sck, pin_t mosi, pin_t cs, pin_t reset = U8G_PIN_NONE) { init(sck, mosi, cs, reset); }
|
|
|
|
U8GLIB_ST7920_128X64_4X_HAL(pin_t cs, pin_t reset = U8G_PIN_NONE) { init(cs, reset); }
|
|
|
|
void init(pin_t sck, pin_t mosi, pin_t cs, pin_t reset = U8G_PIN_NONE) {
|
|
|
|
U8GLIB::init(&u8g_dev_st7920_128x64_HAL_4x_sw_spi, (uint8_t)sck, (uint8_t)mosi, (uint8_t)cs, U8G_PIN_NONE, (uint8_t)reset); // a0 = U8G_PIN_NONE
|
|
|
|
}
|
|
|
|
void init(pin_t cs, pin_t reset = U8G_PIN_NONE) {
|
|
|
|
U8GLIB::init(&u8g_dev_st7920_128x64_HAL_4x_hw_spi, (uint8_t)cs, U8G_PIN_NONE, (uint8_t)reset); // a0 = U8G_PIN_NONE
|
|
|
|
}
|
2017-11-02 20:57:08 -05:00
|
|
|
};
|
|
|
|
|
2018-11-13 01:47:45 -06:00
|
|
|
//
|
|
|
|
// AVR version uses ultralcd_st7920_u8glib_rrd_AVR.cpp
|
|
|
|
// HAL version uses u8g_dev_st7920_128x64_HAL.cpp
|
|
|
|
//
|
2017-11-02 20:57:08 -05:00
|
|
|
extern u8g_dev_t u8g_dev_st7920_128x64_rrd_sw_spi;
|
2018-11-13 01:47:45 -06:00
|
|
|
|
|
|
|
class U8GLIB_ST7920_128X64_RRD : public U8GLIB {
|
|
|
|
public:
|
2021-04-08 22:35:21 -03:00
|
|
|
U8GLIB_ST7920_128X64_RRD() : U8GLIB() { }
|
|
|
|
U8GLIB_ST7920_128X64_RRD(pin_t sck, pin_t mosi, pin_t cs, pin_t reset = U8G_PIN_NONE) { init(sck, mosi, cs, reset); }
|
|
|
|
void init(pin_t sck, pin_t mosi, pin_t cs, pin_t reset = U8G_PIN_NONE) {
|
|
|
|
U8GLIB::init(&u8g_dev_st7920_128x64_rrd_sw_spi, (uint8_t)sck, (uint8_t)mosi, (uint8_t)cs, U8G_PIN_NONE, (uint8_t)reset); // a0 = U8G_PIN_NONE
|
|
|
|
}
|
2017-11-02 20:57:08 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
extern u8g_dev_t u8g_dev_sh1106_128x64_2x_i2c_2_wire;
|
2018-11-13 01:47:45 -06:00
|
|
|
|
2017-11-02 20:57:08 -05:00
|
|
|
class U8GLIB_SH1106_128X64_2X_I2C_2_WIRE : public U8GLIB {
|
2018-11-13 01:47:45 -06:00
|
|
|
public:
|
2021-04-08 22:35:21 -03:00
|
|
|
U8GLIB_SH1106_128X64_2X_I2C_2_WIRE() : U8GLIB() { }
|
|
|
|
U8GLIB_SH1106_128X64_2X_I2C_2_WIRE(uint8_t options) { init(options); }
|
|
|
|
void init(uint8_t options = U8G_I2C_OPT_NONE) { U8GLIB::init(&u8g_dev_sh1106_128x64_2x_i2c_2_wire, options); }
|
2017-11-02 20:57:08 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
extern u8g_dev_t u8g_dev_ssd1306_128x64_2x_i2c_2_wire;
|
2018-11-13 01:47:45 -06:00
|
|
|
|
2017-11-02 20:57:08 -05:00
|
|
|
class U8GLIB_SSD1306_128X64_2X_I2C_2_WIRE : public U8GLIB {
|
2018-11-13 01:47:45 -06:00
|
|
|
public:
|
2021-04-08 22:35:21 -03:00
|
|
|
U8GLIB_SSD1306_128X64_2X_I2C_2_WIRE() : U8GLIB() { }
|
|
|
|
U8GLIB_SSD1306_128X64_2X_I2C_2_WIRE(uint8_t options) { init(options); }
|
|
|
|
void init(uint8_t options = U8G_I2C_OPT_NONE) { U8GLIB::init(&u8g_dev_ssd1306_128x64_2x_i2c_2_wire, options); }
|
2017-11-02 20:57:08 -05:00
|
|
|
};
|
2019-01-03 19:38:39 +03:00
|
|
|
|
|
|
|
//
|
|
|
|
// Very basic support for 320x240 TFT screen
|
|
|
|
// Tested on MKS Robin TFT_V2.0 with ST7789V controller
|
|
|
|
//
|
|
|
|
extern u8g_dev_t u8g_dev_tft_320x240_upscale_from_128x64;
|
|
|
|
|
|
|
|
class U8GLIB_TFT_320X240_UPSCALE_FROM_128X64 : public U8GLIB {
|
|
|
|
public:
|
2021-04-08 22:35:21 -03:00
|
|
|
U8GLIB_TFT_320X240_UPSCALE_FROM_128X64() : U8GLIB() { }
|
|
|
|
U8GLIB_TFT_320X240_UPSCALE_FROM_128X64(uint8_t cs, uint8_t rs, uint8_t reset = U8G_PIN_NONE) { init(cs, rs, reset); }
|
|
|
|
void init(uint8_t cs, uint8_t rs, uint8_t reset = U8G_PIN_NONE) { U8GLIB::init(&u8g_dev_tft_320x240_upscale_from_128x64, cs, rs, reset); }
|
2019-01-03 19:38:39 +03:00
|
|
|
};
|
2019-04-21 20:48:53 -05:00
|
|
|
|
|
|
|
|
|
|
|
extern u8g_dev_t u8g_dev_uc1701_mini12864_HAL_2x_sw_spi, u8g_dev_uc1701_mini12864_HAL_2x_hw_spi;
|
|
|
|
|
|
|
|
class U8GLIB_MINI12864_2X_HAL : public U8GLIB {
|
|
|
|
public:
|
2021-04-08 22:35:21 -03:00
|
|
|
U8GLIB_MINI12864_2X_HAL() : U8GLIB() { }
|
|
|
|
U8GLIB_MINI12864_2X_HAL(uint8_t sck, uint8_t mosi, uint8_t cs, uint8_t a0, uint8_t reset = U8G_PIN_NONE) { init(sck, mosi, cs, a0, reset); }
|
|
|
|
U8GLIB_MINI12864_2X_HAL(uint8_t cs, uint8_t a0, uint8_t reset = U8G_PIN_NONE) { init(cs, a0, reset); }
|
|
|
|
void init(uint8_t sck, uint8_t mosi, uint8_t cs, uint8_t a0, uint8_t reset = U8G_PIN_NONE) {
|
|
|
|
U8GLIB::init(&u8g_dev_uc1701_mini12864_HAL_2x_sw_spi, sck, mosi, cs, a0, reset);
|
|
|
|
}
|
|
|
|
void init(uint8_t cs, uint8_t a0, uint8_t reset = U8G_PIN_NONE) {
|
|
|
|
U8GLIB::init(&u8g_dev_uc1701_mini12864_HAL_2x_hw_spi, cs, a0, reset);
|
|
|
|
}
|
2019-04-21 20:48:53 -05:00
|
|
|
};
|
2021-01-17 14:46:57 +08:00
|
|
|
|
|
|
|
extern u8g_dev_t u8g_dev_ssd1309_sw_spi;
|
|
|
|
extern u8g_dev_t u8g_dev_ssd1309_hw_spi;
|
|
|
|
|
|
|
|
class U8GLIB_SSD1309_128X64_HAL : public U8GLIB {
|
|
|
|
public:
|
2021-04-08 22:35:21 -03:00
|
|
|
U8GLIB_SSD1309_128X64_HAL() : U8GLIB() { }
|
|
|
|
U8GLIB_SSD1309_128X64_HAL(pin_t sck, pin_t mosi, pin_t cs, pin_t a0, pin_t reset = U8G_PIN_NONE) { init(sck, mosi, cs, a0, reset); }
|
|
|
|
U8GLIB_SSD1309_128X64_HAL(pin_t cs, pin_t a0, pin_t reset = U8G_PIN_NONE) { init(cs, a0, reset); }
|
|
|
|
void init(pin_t sck, pin_t mosi, pin_t cs, pin_t a0, pin_t reset = U8G_PIN_NONE) {
|
|
|
|
U8GLIB::init(&u8g_dev_ssd1309_sw_spi, (uint8_t)sck, (uint8_t)mosi, (uint8_t)cs, (uint8_t)a0, (uint8_t)reset);
|
|
|
|
}
|
|
|
|
void init(pin_t cs, pin_t a0, pin_t reset = U8G_PIN_NONE) {
|
|
|
|
U8GLIB::init(&u8g_dev_ssd1309_hw_spi, (uint8_t)cs, (uint8_t)a0, (uint8_t)reset);
|
|
|
|
}
|
2021-01-17 14:46:57 +08:00
|
|
|
};
|