diff --git a/EPD/EPD_4in2_V2.c b/EPD/EPD_4in2_V2.c deleted file mode 100644 index 06c112e..0000000 --- a/EPD/EPD_4in2_V2.c +++ /dev/null @@ -1,219 +0,0 @@ -/***************************************************************************** -* | File : EPD_4in2_V2.h -* | Author : Waveshare team -* | Function : 4.2inch e-paper V2 -* | Info : -*---------------- -* | This version: V1.0 -* | Date : 2023-09-12 -* ----------------------------------------------------------------------------- -# -# Permission is hereby granted, free of charge, to any person obtaining a copy -# of this software and associated documnetation files (the "Software"), to deal -# in the Software without restriction, including without limitation the rights -# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -# copies of the Software, and to permit persons to whom the Software is -# furished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in -# all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS OR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -# LIABILITY WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -# THE SOFTWARE. -# -******************************************************************************/ -#include "EPD_driver.h" - -// Display resolution -#define EPD_4IN2_V2_WIDTH 400 -#define EPD_4IN2_V2_HEIGHT 300 - -/****************************************************************************** -function : Software reset -parameter: -******************************************************************************/ -static void EPD_4IN2_V2_Reset(void) -{ - DEV_Digital_Write(EPD_RST_PIN, 1); - DEV_Delay_ms(100); - DEV_Digital_Write(EPD_RST_PIN, 0); - DEV_Delay_ms(2); - DEV_Digital_Write(EPD_RST_PIN, 1); - DEV_Delay_ms(100); -} - -/****************************************************************************** -function : Wait until the busy_pin goes LOW -parameter: -******************************************************************************/ -void EPD_4IN2_V2_ReadBusy(void) -{ - while(DEV_Digital_Read(EPD_BUSY_PIN) == 1) { //LOW: idle, HIGH: busy - DEV_Delay_ms(10); - } -} - -/****************************************************************************** -function : Turn On Display -parameter: -******************************************************************************/ -void EPD_4IN2_V2_TurnOnDisplay(void) -{ - EPD_WriteCommand(0x22); - EPD_WriteByte(0xF7); - EPD_WriteCommand(0x20); - EPD_4IN2_V2_ReadBusy(); -} - -/****************************************************************************** -function : Setting the display window -parameter: -******************************************************************************/ -static void EPD_4IN2_V2_SetWindows(UWORD Xstart, UWORD Ystart, UWORD Xend, UWORD Yend) -{ - EPD_WriteCommand(0x44); // SET_RAM_X_ADDRESS_START_END_POSITION - EPD_WriteByte((Xstart>>3) & 0xFF); - EPD_WriteByte((Xend>>3) & 0xFF); - - EPD_WriteCommand(0x45); // SET_RAM_Y_ADDRESS_START_END_POSITION - EPD_WriteByte(Ystart & 0xFF); - EPD_WriteByte((Ystart >> 8) & 0xFF); - EPD_WriteByte(Yend & 0xFF); - EPD_WriteByte((Yend >> 8) & 0xFF); -} - -/****************************************************************************** -function : Set Cursor -parameter: -******************************************************************************/ -static void EPD_4IN2_V2_SetCursor(UWORD Xstart, UWORD Ystart) -{ - EPD_WriteCommand(0x4E); // SET_RAM_X_ADDRESS_COUNTER - EPD_WriteByte(Xstart & 0xFF); - - EPD_WriteCommand(0x4F); // SET_RAM_Y_ADDRESS_COUNTER - EPD_WriteByte(Ystart & 0xFF); - EPD_WriteByte((Ystart >> 8) & 0xFF); -} - -/****************************************************************************** -function : Initialize the e-Paper register -parameter: -******************************************************************************/ -void EPD_4IN2_V2_Init(void) -{ - EPD_4IN2_V2_Reset(); - - DEV_Delay_ms(10); - EPD_WriteCommand(0x12); // soft reset - DEV_Delay_ms(10); - - // EPD_WriteCommand(0x01); //Driver output control - // EPD_WriteByte((EPD_4IN2_V2_HEIGHT-1)%256); - // EPD_WriteByte((EPD_4IN2_V2_HEIGHT-1)/256); - // EPD_WriteByte(0x00); - - EPD_WriteCommand(0x21); // Display update control - EPD_WriteByte(0x40); - EPD_WriteByte(0x00); - - EPD_WriteCommand(0x3C); //BorderWavefrom - EPD_WriteByte(0x05); - - EPD_WriteCommand(0x11); // data entry mode - EPD_WriteByte(0x03); // X-mode - - EPD_4IN2_V2_SetWindows(0, 0, EPD_4IN2_V2_WIDTH-1, EPD_4IN2_V2_HEIGHT-1); - - EPD_4IN2_V2_SetCursor(0, 0); -} - -/****************************************************************************** -function : Clear screen -parameter: -******************************************************************************/ -void EPD_4IN2_V2_Clear(void) -{ - UWORD Width, Height; - Width = (EPD_4IN2_V2_WIDTH % 8 == 0)? (EPD_4IN2_V2_WIDTH / 8 ): (EPD_4IN2_V2_WIDTH / 8 + 1); - Height = EPD_4IN2_V2_HEIGHT; - - EPD_WriteCommand(0x24); - for (UWORD j = 0; j < Height; j++) { - for (UWORD i = 0; i < Width; i++) { - EPD_WriteByte(0xFF); - } - } - - EPD_WriteCommand(0x26); - for (UWORD j = 0; j < Height; j++) { - for (UWORD i = 0; i < Width; i++) { - EPD_WriteByte(0xFF); - } - } - EPD_4IN2_V2_TurnOnDisplay(); -} - -static void _setPartialRamArea(UWORD x, UWORD y, UWORD w, UWORD h) -{ - EPD_WriteCommand(0x11); // set ram entry mode - EPD_WriteByte(0x03); // x increase, y increase : normal mode - EPD_WriteCommand(0x44); - EPD_WriteByte(x / 8); - EPD_WriteByte((x + w - 1) / 8); - EPD_WriteCommand(0x45); - EPD_WriteByte(y % 256); - EPD_WriteByte(y / 256); - EPD_WriteByte((y + h - 1) % 256); - EPD_WriteByte((y + h - 1) / 256); - EPD_WriteCommand(0x4e); - EPD_WriteByte(x / 8); - EPD_WriteCommand(0x4f); - EPD_WriteByte(y % 256); - EPD_WriteByte(y / 256); -} - -void EPD_4IN2_V2_Write_Image(UBYTE *black, UBYTE *color, UWORD x, UWORD y, UWORD w, UWORD h) -{ - int32_t wb = (w + 7) / 8; // width bytes, bitmaps are padded - x -= x % 8; // byte boundary - w = wb * 8; // byte boundary - if (x + w > EPD_4IN2_V2_WIDTH || y + h > EPD_4IN2_V2_HEIGHT) return; - _setPartialRamArea(x, y, w, h); - EPD_WriteCommand(0x24); - for (UWORD i = 0; i < h; i++) { - for (UWORD j = 0; j < w / 8; j++) { - EPD_WriteByte(black[j + i * wb]); - } - } -} - -/****************************************************************************** -function : Enter sleep mode -parameter: -******************************************************************************/ -void EPD_4IN2_V2_Sleep(void) -{ - EPD_WriteCommand(0x10); // DEEP_SLEEP - EPD_WriteByte(0x01); - DEV_Delay_ms(200); -} - -const epd_driver_t epd_driver_4in2v2 = { - .id = EPD_DRIVER_4IN2_V2, - .width = EPD_4IN2_V2_WIDTH, - .height = EPD_4IN2_V2_HEIGHT, - .init = EPD_4IN2_V2_Init, - .clear = EPD_4IN2_V2_Clear, - .send_command = EPD_WriteCommand, - .send_byte = EPD_WriteByte, - .send_data = EPD_WriteData, - .write_image = EPD_4IN2_V2_Write_Image, - .display = EPD_4IN2_V2_TurnOnDisplay, - .sleep = EPD_4IN2_V2_Sleep, -}; diff --git a/EPD/EPD_driver.c b/EPD/EPD_driver.c index 36ff258..059d30e 100644 --- a/EPD/EPD_driver.c +++ b/EPD/EPD_driver.c @@ -26,13 +26,11 @@ uint32_t EPD_BS_PIN = 13; static const nrf_drv_spi_t spi = NRF_DRV_SPI_INSTANCE(0); extern epd_driver_t epd_driver_4in2; -extern epd_driver_t epd_driver_4in2v2; extern epd_driver_t epd_driver_4in2bv2; /** EPD drivers */ static epd_driver_t *epd_drivers[] = { &epd_driver_4in2, - &epd_driver_4in2v2, &epd_driver_4in2bv2, }; diff --git a/EPD/EPD_driver.h b/EPD/EPD_driver.h index 7e26482..ee6c8bf 100644 --- a/EPD/EPD_driver.h +++ b/EPD/EPD_driver.h @@ -35,8 +35,7 @@ enum EPD_DRIVER_IDS { EPD_DRIVER_4IN2 = 1, - EPD_DRIVER_4IN2_V2, - EPD_DRIVER_4IN2B_V2, + EPD_DRIVER_4IN2B_V2 = 3, }; /**@brief EPD driver structure. diff --git a/Keil/EPD.uvprojx b/Keil/EPD.uvprojx index 3837006..25801a0 100644 --- a/Keil/EPD.uvprojx +++ b/Keil/EPD.uvprojx @@ -414,11 +414,6 @@ 1 ..\EPD\EPD_4in2.c - - EPD_4in2_V2.c - 1 - ..\EPD\EPD_4in2_V2.c - EPD_4in2b_V2.c 1 @@ -1011,11 +1006,6 @@ 1 ..\EPD\EPD_4in2.c - - EPD_4in2_V2.c - 1 - ..\EPD\EPD_4in2_V2.c - EPD_4in2b_V2.c 1 diff --git a/Makefile b/Makefile index ad1a089..a48e27f 100644 --- a/Makefile +++ b/Makefile @@ -35,7 +35,6 @@ SRC_FILES += \ $(SDK_ROOT)/components/softdevice/common/softdevice_handler/softdevice_handler.c \ $(PROJ_DIR)/main.c \ $(PROJ_DIR)/EPD/EPD_4in2.c \ - $(PROJ_DIR)/EPD/EPD_4in2_V2.c \ $(PROJ_DIR)/EPD/EPD_4in2b_V2.c \ $(PROJ_DIR)/EPD/EPD_driver.c \ $(PROJ_DIR)/EPD/EPD_ble.c \ diff --git a/README.md b/README.md index 4c6928d..d17f093 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ 4.2 寸电子墨水屏固件,带有一个[网页版上位机](https://tsl0922.github.io/EPD-nRF51/),可以通过蓝牙传输图像到墨水屏,也可以把墨水屏设置为日历模式(支持农历、节气)。 -理论上支持所有 nRF51 系列 MCU,内置 3 个微雪 4.2 寸墨水屏驱动(可切换),同时还支持自定义墨水屏到 MCU 的引脚映射,支持睡眠唤醒(NFC / 无线充电器)。 +理论上支持所有 nRF51 系列 MCU,支持 UC8176 驱动的 4.2 寸黑白/黑白红墨水屏(可切换驱动),同时还支持自定义墨水屏到 MCU 的引脚映射,支持睡眠唤醒(NFC / 无线充电器)。 ![](html/images/3.jpg) diff --git a/html/index.html b/html/index.html index 8a6011f..f083d6b 100644 --- a/html/index.html +++ b/html/index.html @@ -45,9 +45,8 @@
@@ -82,7 +81,7 @@