remove EPD_4in2_V2 driver

This commit is contained in:
Shuanglei Tao
2025-02-20 21:11:24 +08:00
parent 8bf77ee71a
commit 551a217210
8 changed files with 7 additions and 241 deletions

View File

@@ -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,
};

View File

@@ -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,
};

View File

@@ -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.

View File

@@ -414,11 +414,6 @@
<FileType>1</FileType>
<FilePath>..\EPD\EPD_4in2.c</FilePath>
</File>
<File>
<FileName>EPD_4in2_V2.c</FileName>
<FileType>1</FileType>
<FilePath>..\EPD\EPD_4in2_V2.c</FilePath>
</File>
<File>
<FileName>EPD_4in2b_V2.c</FileName>
<FileType>1</FileType>
@@ -1011,11 +1006,6 @@
<FileType>1</FileType>
<FilePath>..\EPD\EPD_4in2.c</FilePath>
</File>
<File>
<FileName>EPD_4in2_V2.c</FileName>
<FileType>1</FileType>
<FilePath>..\EPD\EPD_4in2_V2.c</FilePath>
</File>
<File>
<FileName>EPD_4in2b_V2.c</FileName>
<FileType>1</FileType>

View File

@@ -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 \

View File

@@ -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)

View File

@@ -45,9 +45,8 @@
<div>
<label for="epddriver">驱动</label>
<select id="epddriver" onchange="filterDitheringOptions()">
<option value="01">EPD_4in2</option>
<option value="02">EPD_4in2_V2</option>
<option value="03">EPD_4in2b_V2</option>
<option value="01">EPD_4in2(黑白屏)</option>
<option value="03">EPD_4in2b_V2(黑白红屏)</option>
</select>
<label for="epdpins">引脚</label>
<input id="epdpins" type="text" value="">
@@ -82,7 +81,7 @@
<input type="file" id="image_file" onchange="update_image()" accept=".png,.jpg,.bmp,.webp,.jpeg">
<label for="dithering">取模算法</label>
<select id="dithering" title="取模算法" onchange="update_image()">
<optgroup data-driver="01|02" label="黑白">
<optgroup data-driver="01" label="黑白">
<option value="none">二值化</option>
<option value="bayer">bayer</option>
<option value="floydsteinberg">floydsteinberg</option>
@@ -110,7 +109,7 @@
<fieldset>
<legend>提示</legend>
<ul>
<li><b>驱动选择:</b>黑白屏可尝试 EPD_4in2 / EPD_4in2_V2, 三色屏选择 EPD_4in2b_V2 (选错驱动可能会导致任何未知的异常,重启即可恢复)</li>
<li><b>驱动选择:</b>黑白屏选择 EPD_4in2, 三色屏选择 EPD_4in2b_V2 (选错驱动可能会导致任何未知的异常,重启即可恢复)</li>
<li><b>引脚配置:</b>格式为十六进制顺序MOSI/SCLK/CS/DC/ST/BUSY/BS必须按此顺序包含完整的 7 个引脚配置(没有用到的引脚可配置为 <code>FF</code></li>
<li><b>确认间隔: </b>这个间隔指的是数据包数量间隔,即发送此数量的不确认响应的数据包后才发送一次需确认响应的数据包。加大此值可优化传图速度,但是丢包风险也更大(你可能会发现图片有部分位置显示不正常,此时需调小这个值)。
<li><b>日历模式: </b>点击“日历模式”按钮将自动从浏览器同步时间到墨水屏,并切换到日历显示。</li>

2
main.c
View File

@@ -36,7 +36,7 @@
#define PERIPHERAL_LINK_COUNT 1 /**< Number of peripheral links used by the application. When changing this number remember to adjust the RAM settings*/
#define DEVICE_NAME "NRF_EPD" /**< Name of device. Will be included in the advertising data. */
#define APP_ADV_INTERVAL 320 /**< The advertising interval (in units of 0.625 ms. This value corresponds to 40 ms). */
#define APP_ADV_INTERVAL 320 /**< The advertising interval (in units of 0.625 ms. This value corresponds to 200 ms). */
#define APP_ADV_TIMEOUT_IN_SECONDS 120 /**< The advertising timeout (in units of seconds). */
#define APP_TIMER_PRESCALER 0 /**< Value of the RTC1 PRESCALER register. */
#define APP_TIMER_OP_QUEUE_SIZE 4 /**< Size of timer operation queues. */