BLE_DCF_TYQ_CH592F/StdPeriphDriver/inc/CH59x_lcd.h

99 lines
3.5 KiB
C
Raw Normal View History

2024-12-02 16:26:55 +08:00
/********************************** (C) COPYRIGHT *******************************
* File Name : CH59x_lcd.h
* Author : WCH
* Version : V1.0
* Date : 2022/12/05
* Description :
********************************************************************************
* Copyright (c) 2021 Nanjing Qinheng Microelectronics Co., Ltd.
* Attention: This software (modified or not) and binary are used for
* microcontroller manufactured by Nanjing Qinheng Microelectronics.
*******************************************************************************/
#ifndef __CH59x_LCD_H__
#define __CH59x_LCD_H__
#ifdef __cplusplus
extern "C" {
#endif
#include "CH592SFR.h"
/**
* @brief Configuration LCD driver power
*/
typedef enum
{
LCD_PS_3V3 = 0, // 3.3V <20><><EFBFBD><EFBFBD>
LCD_PS_2V5, // 2.5V <20><><EFBFBD><EFBFBD>
}LCDDrvPowerTypeDef;
/**
* @brief Configuration LCD bias
*/
typedef enum
{
LCD_1_2_Bias = 0, // 2<><32><EFBFBD><EFBFBD>ѹ
LCD_1_3_Bias, // 3<><33><EFBFBD><EFBFBD>ѹ
}LCDBiasTypeDef;
/**
* @brief Configuration LCD duty
*/
typedef enum
{
LCD_1_2_Duty = 0, // COM0-COM1
LCD_1_3_Duty, // COM0-COM2
LCD_1_4_Duty, // COM0-COM3
}LCDDutyTypeDef;
/**
* @brief Configuration LCD scan clk
*/
typedef enum
{
LCD_CLK_256 = 0, // 256Hz
LCD_CLK_512, // 512Hz
LCD_CLK_1000, // 1KHz
LCD_CLK_128 // 128Hz
}LCDSCANCLKTypeDef;
/* LCD<43><44>ʽ<EFBFBD><CABD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʼ<EFBFBD><CABC><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
void LCD_Init(LCDDutyTypeDef duty, LCDBiasTypeDef bias);
#define LCD_PowerDown() (R32_LCD_CMD &= ~(RB_LCD_ON | RB_LCD_SYS_EN)) /* LCD<43><44><EFBFBD><EFBFBD>ģ<EFBFBD><C4A3><EFBFBD>ر<EFBFBD> */
#define LCD_PowerOn() (R32_LCD_CMD |= (RB_LCD_ON | RB_LCD_SYS_EN)) /* LCD<43><44><EFBFBD><EFBFBD>ģ<EFBFBD><EFBFBD><E9BFAA> */
// <20><><EFBFBD><EFBFBD>ֵ<EFBFBD>ο<EFBFBD> LCDDrvPowerTypeDef
#define LCD_PowerCfg( d ) (R32_LCD_CMD = (R32_LCD_CMD & ~RB_LCD_VLCD_SEL) | (d<<7)) /* <20><><EFBFBD><EFBFBD>LCD<43><44> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѹѡ<D1B9><D1A1> */
// <20><><EFBFBD><EFBFBD>ֵ<EFBFBD>ο<EFBFBD> LCDSCANCLKTypeDef
#define LCD_ScanCLKCfg( d ) (R32_LCD_CMD = (R32_LCD_CMD & ~RB_LCD_SCAN_CLK) | (d<<5)) /* <20><><EFBFBD><EFBFBD>LCD<43><44> ɨ<><C9A8>ʱ<EFBFBD><CAB1>ѡ<EFBFBD><D1A1> */
// <20><><EFBFBD><EFBFBD>ֵ<EFBFBD>ο<EFBFBD> LCDDutyTypeDef
#define LCD_DutyCfg( d ) (R32_LCD_CMD = (R32_LCD_CMD & ~RB_LCD_DUTY) | (d<<3)) /* <20><><EFBFBD><EFBFBD>LCD<43><44> dutyѡ<79><D1A1> */
// <20><><EFBFBD><EFBFBD>ֵ<EFBFBD>ο<EFBFBD> LCDBiasTypeDef
#define LCD_BiasCfg( d ) (R32_LCD_CMD = (R32_LCD_CMD & ~RB_LCD_BIAS) | (d<<2)) /* <20><><EFBFBD><EFBFBD>LCD<43><44> biasѡ<73><D1A1> */
#define LCD_WriteData0( d ) (R32_LCD_RAM0 = (R32_LCD_RAM0 & 0xffffff00) | ((UINT32)d)) /* <20><><EFBFBD><EFBFBD>SEG0<47><30><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#define LCD_WriteData1( d ) (R32_LCD_RAM0 = (R32_LCD_RAM0 & 0xffff00ff) | ((UINT32)d<<8)) /* <20><><EFBFBD><EFBFBD>SEG1<47><31><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#define LCD_WriteData2( d ) (R32_LCD_RAM0 = (R32_LCD_RAM0 & 0xff00ffff) | ((UINT32)d<<16)) /* <20><><EFBFBD><EFBFBD>SEG2<47><32><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#define LCD_WriteData3( d ) (R32_LCD_RAM0 = (R32_LCD_RAM0 & 0x00ffffff) | ((UINT32)d<<24)) /* <20><><EFBFBD><EFBFBD>SEG3<47><33><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#define LCD_WriteData4( d ) (R32_LCD_RAM1 = (R32_LCD_RAM1 & 0xffffff00) | ((UINT32)d)) /* <20><><EFBFBD><EFBFBD>SEG4<47><34><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#define LCD_WriteData5( d ) (R32_LCD_RAM1 = (R32_LCD_RAM1 & 0xffff00ff) | ((UINT32)d<<8)) /* <20><><EFBFBD><EFBFBD>SEG5<47><35><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#define LCD_WriteData6( d ) (R32_LCD_RAM1 = (R32_LCD_RAM1 & 0xff00ffff) | ((UINT32)d<<16)) /* <20><><EFBFBD><EFBFBD>SEG6<47><36><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#define LCD_WriteData7( d ) (R32_LCD_RAM1 = (R32_LCD_RAM1 & 0x00ffffff) | ((UINT32)d<<24)) /* <20><><EFBFBD><EFBFBD>SEG7<47><37><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#define LCD_WriteData8( d ) (R32_LCD_RAM2 = (R32_LCD_RAM2 & 0xffffff00) | ((UINT32)d)) /* <20><><EFBFBD><EFBFBD>SEG8<47><38><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#define LCD_WriteData9( d ) (R32_LCD_RAM2 = (R32_LCD_RAM2 & 0xffff00ff) | ((UINT32)d<<8)) /* <20><><EFBFBD><EFBFBD>SEG9<47><39><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#define LCD_WriteData10( d ) (R32_LCD_RAM2 = (R32_LCD_RAM2 & 0xff00ffff) | ((UINT32)d<<16)) /* <20><><EFBFBD><EFBFBD>SEG10<31><30><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ */
#ifdef __cplusplus
}
#endif
#endif // __CH59x_LCD_H__