📄 hal_lcdc.c
字号:
/************************************************************************/
/* */
/* Copyright (C) 2006 Oki Electric Industry Co., LTD. */
/* */
/* System Name : ML675050 series */
/* Module Name : ML675050 LCDC HAL program */
/* File Name : hal_lcdc.c */
/* Date : 2005/12/26 initial version */
/* */
/************************************************************************/
/****************************************************************************************
* 文件名:LCD320240.C
* 功能:图形液晶320*240驱动(型号为PG3580DBSW)。32K显示存,0000H-7FFFH地址。显示是横向字节,高位
* 在前。
* 说明:图形液晶采用RA8835为LCD控制芯片,内带负压产生器,单5伏供电,并行接口(使用STR710FZ2T6驱动)。
* 硬件连接: D0--D7 <===> D0--D7
* /WR <===> WEn0
* /RD <===> RDn
* /CE <===> A19
* A0 <===> A14
*
* /RST <===> /RET
****************************************************************************************/
#include <string.h>
#include "hal_lcdc.h"
#include "common.h"
#include "hal_spi.h"
#include "common.h"
#include "ml675050.h"
/*
#include "common.h"
#if defined(__arm)
#else
#include "ml675050sim.h"
#endif
#include "hal_interrupt.h"
*/
//void DisCursorSetup(uint8_t CursorMovDir,uint16_t CSRADR);
//#define PG320240_COM *(uint8_t *)0x62088000
//#define PG320240_DAT *(uint8_t *)0x62080000
/***********************************************************************
* 名称:LCD_ReadState()
* 功能:读取状态字子程序。
* 入口参数:无
* 出口参数:返回值即为读出的状态字
* 说明:函数会设置LCM数据总线为输入方式
***********************************************************************/
#define LCD_ReadState() PG320240_COM
/***********************************************************************
* 名称:LCD_ReadData()
* 功能:读取数据子程序。
* 入口参数:无
* 出口参数:返回值即为读出的数据
* 说明:函数会设置LCM数据总线为输入方式
***********************************************************************/
#define LCD_ReadData() PG320240_DAT
TCOLOR gui_disp_buf[GUI_LCM_YMAX][GUI_LCM_XMAX/8]; // 声明GUI显示缓冲区
/* 定义LCM地址 */
static void DisCursorSetup(uint8_t CursorMovDir,uint16_t CSRADR);
uint16_t HalPio_PioSetIo(uint16_t port_no, uint8_t port_io);
void LcdEnable(void)
{
OkiCLib_set8bit(PM4, 0x10);
OkiCLib_set8bit(PO4, 0x10);
}
void LcdDisable(void)
{
}
/***********************************************************************
* 名称:LCD_Read_Write_CNT();
* 功能:读取数据子程序。
* 入口参数:无
* 出口参数:返回值即为读出的数据
* 说明:函数会设置LCM数据总线为输入方式
***********************************************************************/
void LCD_Read_Write_CNT()
{
}
/***********************************************************************
* 名称:LCD_WriteCommand()
* 功能:写命令子程序。(发送命令前,不检查液晶模块的状态)
* 入口参数:command 要写入LCM的命令字
* 出口参数:无
* 说明:函数会设置LCM数据总线为输出方式
***********************************************************************/
//#define LCD_WriteCommand(command) PG320240_COM = (uint16_t)command
static void LCD_WriteCommand(uint8_t command)
{
uint32_t i;
OkiCLib_set8bit(PM4, 0x10);//LCD_A0设置
OkiCLib_set8bit(PO4, 0x10);
OkiCLib_write8(0xf0000000,command);
// while(LCD_ReadState()&0x80!=0);
for(i=0;i<1;i++);
}
/***********************************************************************
* 名称:LCD_WriteData()
* 功能:写数据子程序。(发送数据前,不检查液晶模块的状态)
* 入口参数:dat 要写入LCM的数据
* 出口参数:无
* 说明:函数会设置LCM数据总线为输出方式
***********************************************************************/
//#define LCD_WriteData(dat) PG320240_DAT = (uint16_t)dat
void LCD_WriteData(uint8_t dat)
{
uint32_t i;
OkiCLib_set8bit(PM4, 0x10);
OkiCLib_clr8bit(PO4, 0x10);
OkiCLib_write8(0xf0000000,dat);
for(i=0;i<1;i++);
}
//设置显示光标地址及光标移动方向
static void DisCursorSetup(uint8_t CursorMovDir,uint16_t CSRADR)
{
LCD_WriteCommand(CursorMovDir);//设置光标移动方向
LCD_WriteCommand(CSRW); //设置光标地址命令
LCD_WriteData(CSRADR); //写入光标地址的低位
LCD_WriteData(CSRADR>>8); //写入光标地址的高位
LCD_WriteCommand(MWRITE); //将数据写入显示缓冲区命令
}
/* 以下为LCM的用户接口层,主要负责解释用户命令,并发送到LCM,为用户编程提供接口 */
/***********************************************************************
* 名称:LCD_FillAll()
* 功能:LCD填充。以图形方式进行填充,起始地址为0x0000。
* 入口参数:dat 要填充的数据
* 出口参数:无
***********************************************************************/
void LCD_FillAll(uint8_t dat)
{
uint8_t i,j;
DisCursorSetup(CSRDIR_RIGHT,0);
for(i=0;i<40;i++) //320/8=40字节宽度
{
for(j=0;j<240;j++)
{
LCD_WriteData(dat);
}
}
DisCursorSetup(CSRDIR_RIGHT,0x4000);
for(i=0;i<40;i++) //320/8=40字节宽度
{
for(j=0;j<240;j++)
{
LCD_WriteData(dat);
}
}
}
/***********************************************************************
* 名称:LCD_Initialize()
* 功能:LCM初始化,将LCM初始化为纯图形模式,显示起始地址为0x0000,。
* 入口参数:无
* 出口参数:无
* 说明:函数会设置LCM数据总线为输出方式
***********************************************************************/
void LCD_Initialize(void)
{
//30H,87H,07H,27H,42H,0F0H,28H,00H
// while(1)
// SelectLCD;
LCD_WriteCommand(SYSTEMSET); //初始化指令
LCD_WriteData(0x30);
LCD_WriteData(0x87);
LCD_WriteData(0x07);
LCD_WriteData(0x27);
LCD_WriteData(0x42);
LCD_WriteData(0xF0);
LCD_WriteData(0x28);
LCD_WriteData(0x00);
//00H,00H,0F0H,00H,40H,0F0H,00H,80H,00H,00H ;SRCOLL
LCD_WriteCommand(SCROLL);
LCD_WriteData(0x00);
LCD_WriteData(0x00);
LCD_WriteData(0xf0); //第一显示区首地址及其占有显示屏上的点行数
LCD_WriteData(0x00);
LCD_WriteData(0x40);
LCD_WriteData(0xf0); //第二显示区首地址及其占有显示屏上的点行数
LCD_WriteData(0x00);
LCD_WriteData(0x80);
LCD_WriteData(0x00);
LCD_WriteData(0x00);
LCD_WriteCommand(HDOTSCR); //点位置设置
LCD_WriteData(0x00);
LCD_WriteCommand(OVLAY); //显示合成方式设置
//LCD_WriteData(0x0c);//0x0c
LCD_WriteData(0x0d);//0x0d//异或方式
LCD_WriteCommand(DISON); //显示方式
LCD_WriteData(0x54);//0x54
LCD_WriteCommand(CSRFORM); //光标形状设置
LCD_WriteData(0x00);
LCD_WriteData(0x8F);
// LCD_FillAll(0x55);
GUI_ClearSCR();
}
/****************************************************************************
* 名称:LCD_UpdatePoint()
* 功能:在指定位置上画点,刷新某一点。
* 入口参数: x 指定点所在列的位置
* y 指定点所在行的位置
* 出口参数:返回值为1时表示操作成功,为0时表示操作失败。
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
void LCD_UpdatePoint(uint16_t x, uint16_t y)
{
uint32_t addr;
/* 找出目标地址 */
addr = y*(GUI_LCM_XMAX>>3) + (x>>3);
//LCD_WriteCommand(0x4c); //设置光标移动方向
LCD_WriteCommand(0x46); // 置地址指针
LCD_WriteData(addr&0xFF);
LCD_WriteData(addr>>8);
/* 输出数据 */
LCD_WriteCommand(0x42);
LCD_WriteData(gui_disp_buf[y][x>>3]);
}
/****************************************************************************
* 与LCM相关的GUI接口函数
****************************************************************************/
/****************************************************************************
* 名称:GUI_FillSCR()
* 功能:全屏填充。直接使用数据填充显示缓冲区。
* 入口参数:dat 填充的数据(对于黑白色LCM,为0的点灭,为1的点显示)
* 出口参数:无
****************************************************************************/
void GUI_FillSCR(uint8_t dat)
{ uint16_t i, j;
for(i=0; i<GUI_LCM_YMAX; i++) // 历遍所有行
{ for(j=0; j<GUI_LCM_XMAX/8; j++) // 历遍所有行
{ gui_disp_buf[i][j] = dat; // 填充数据
}
}
/* 填充LCM */
LCD_FillAll(dat);
}
/****************************************************************************
* 名称:GUI_Initialize()
* 功能:初始化GUI,包括初始化显示缓冲区,初始化LCM并清屏。
* 入口参数:无
* 出口参数:无
****************************************************************************/
void GUI_Initialize(void)
{
LCD_Initialize();
// 初始化LCM模块工作模式,纯图形模式
GUI_FillSCR(0x00);
// 初始化缓冲区为0x00,并输出屏幕(清屏)
}
/****************************************************************************
* 名称:GUI_ClearSCR()
* 功能:清屏。
* 入口参数:无
* 出口参数:无
* 说明:用户根据LCM的实际情况编写此函数。
****************************************************************************/
void GUI_ClearSCR(void)
{ GUI_FillSCR(0x00);
}
uint8_t const DCB_HEX_TAB[8] = {0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01};
/****************************************************************************
* 名称:GUI_Point()
* 功能:在指定位置上画点。
* 入口参数: x 指定点所在列的位置
* y 指定点所在行的位置
* color 显示颜色(对于黑白色LCM,为0时灭,为1时显示)
* 出口参数:返回值为1时表示操作成功,为0时表示操作失败。(操作失败原因是指定地址超出有
* 效范围)
* 说明:用户根据LCM的实际情况编写此函数。对于单色,只有一个位有效,则要使用左移的方法
* 实现point_dat = (point_dat&MASK_TAB [i]) | (color<<n),其它位数的一样
* 处理。
****************************************************************************/
uint8_t GUI_Point(uint16_t x, uint16_t y, TCOLOR color)
{ /* 参数过滤 */
if(x>=GUI_LCM_XMAX) return(0);
if(y>=GUI_LCM_YMAX) return(0);
/* 设置缓冲区相应的点 */
if( (color&0x01) != 0 ) gui_disp_buf[y][x>>3] |= DCB_HEX_TAB[x&0x07];
else gui_disp_buf[y][x>>3] &= (~DCB_HEX_TAB[x&0x07]);
/* 刷新显示 */
LCD_UpdatePoint(x, y);
return(1);
}
/****************************************************************************
* 名称:GUI_ReadPoint()
* 功能:读取指定点的颜色。
* 入口参数:x 指定点所在列的位置
* y 指定点所在行的位置
* ret 保存颜色值的指针
* 出口参数:返回0时表示指定地址超出有效范围。
* 说明:对于单色,设置ret的d0位为1或0,4级灰度则为d0、d1有效,8位RGB则d0--d7有效,
* RGB结构则R、G、B变量有效。
****************************************************************************/
uint16_t GUI_ReadPoint(uint16_t x, uint16_t y, TCOLOR *ret)
{ TCOLOR bak;
/* 参数过滤 */
if(x>=GUI_LCM_XMAX) return(0);
if(y>=GUI_LCM_YMAX) return(0);
/* 取得该点颜色(用户自行更改) */
bak = gui_disp_buf[y][x>>3];
if( (bak&DCB_HEX_TAB[x&0x07])!=0 ) *ret = 1;
else *ret = 0;
return(1);
}
/****************************************************************************
* 名称:GUI_HLine()
* 功能:画水平线。
* 入口参数: x0 水平线起点所在列的位置
* y0 水平线起点所在行的位置
* x1 水平线终点所在列的位置
* color 显示颜色(对于黑白色LCM,为0时灭,为1时显示)
* 出口参数:无
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
void GUI_HLine(uint16_t x0, uint16_t y0, uint16_t x1, uint8_t color)
{ uint16_t bak;
if(x0>x1) // 对x0、x1大小进行排列,以便画图
{ bak = x1;
x1 = x0;
x0 = bak;
}
if(x0==x1)
{
SelectLCD;
GUI_Point(x0, y0, color);
return;
}
do
{ /* 设置相应的点为1 */
if(0!=color) gui_disp_buf[y0][x0>>3] |= DCB_HEX_TAB[x0&0x07];
else gui_disp_buf[y0][x0>>3] &= (~DCB_HEX_TAB[x0&0x07]);
/* 刷新显示(一次刷新一字节) */
if( (x0&0x07)==0x07 ) LCD_UpdatePoint(x0, y0);
x0++;
}while(x1>x0);
/* 对最后一点显示操作 */
if(0!=color) gui_disp_buf[y0][x0>>3] |= DCB_HEX_TAB[x0&0x07];
else gui_disp_buf[y0][x0>>3] &= (~DCB_HEX_TAB[x0&0x07]);
LCD_UpdatePoint(x0, y0);
SelectNull;
}
/****************************************************************************
* 名称:GUI_RLine()
* 功能:画垂直线。
* 入口参数: x0 垂直线起点所在列的位置
* y0 垂直线起点所在行的位置
* y1 垂直线终点所在行的位置
* color 显示颜色(对于黑白色LCM,为0时灭,为1时显示)
* 出口参数:无
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
void GUI_RLine(uint16_t x0, uint16_t y0, uint16_t y1, uint8_t color)
{ uint16_t bak;
if(y0>y1) // 对y0、y1大小进行排列,以便画图
{ bak = y1;
y1 = y0;
y0 = bak;
}
if(y0==y1)
{ GUI_Point(x0, y0, color);
return;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -