[stm32] 一个简单的stm32vet6驱动的天马4线SPI-1.77寸LCD彩屏DEMO

时间:2023-03-09 16:41:00
[stm32] 一个简单的stm32vet6驱动的天马4线SPI-1.77寸LCD彩屏DEMO

书接上文《1、一个简单的nRF51822驱动的天马4线SPI-1.77寸LCD彩屏DEMO》

我们发现用16MHz晶振的nRF51822驱动1.77寸的spi速度达不到要求

本节主要采用72MHz的stm32尝试刷屏效果

效果如下:

工程结构如下:

[stm32] 一个简单的stm32vet6驱动的天马4线SPI-1.77寸LCD彩屏DEMO

注:整个工程最重要的部分在USR中,其它是必须!

首先是LCD.c:

1、类似与用nRF51822做的彩屏驱动,这里主要的不同点在于引脚的初始化~

2、同时,为了使刷屏速度更快点,在39~46行将原来的循环拆成了8行命令~

3、没写的地方和基于nRF51的一样,上一篇说的很详细

 #include "LCD.h"

  4 void LCD_GPIO_Init()
5 {
6 GPIO_InitTypeDef GPIO_InitStructure;
7
8 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE);
9
10 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3 | GPIO_Pin_4;
11 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
12 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //口线翻转速度为50MHz
13 GPIO_Init(GPIOA, &GPIO_InitStructure);
14 }

////////////////////////////////////////////////////////////////////////////////////
//下面是SPI函数及实现LCD通信基础的写数据和写命令函数
//有了这两个函数就能实现复杂的LCD初始化和GUI了
////////////////////////////////////////////////////////////////////////////////////
/*
SPI Send Data
*/
void SendDataSPI(unsigned char DatByte)
{
// unsigned char i;
// for(i = 0; i < 8; i++)
// {
// if((dat&0x80)!=0)SDA_SET;
// else SDA_CLEAR; // dat <<= 1; // SCL_CLEAR;
// SCL_SET;
// }
int bit; bit = DatByte >> ; LCD_SCK = ; LCD_SDA = bit; LCD_SCK = ;
bit = DatByte >> ; LCD_SCK = ; LCD_SDA = bit; LCD_SCK = ;
bit = DatByte >> ; LCD_SCK = ; LCD_SDA = bit; LCD_SCK = ;
bit = DatByte >> ; LCD_SCK = ; LCD_SDA = bit; LCD_SCK = ;
bit = DatByte >> ; LCD_SCK = ; LCD_SDA = bit; LCD_SCK = ;
bit = DatByte >> ; LCD_SCK = ; LCD_SDA = bit; LCD_SCK = ;
bit = DatByte >> ; LCD_SCK = ; LCD_SDA = bit; LCD_SCK = ;
bit = DatByte >> ; LCD_SCK = ; LCD_SDA = bit; LCD_SCK = ; } /*
LCD WRITE COMMAND AND DATA
*/
void WriteComm(unsigned int i)
{ }
void WriteData(unsigned int i)
{ } /*
写显示数据向屏幕(屏幕显示数据需要2字节)
*/
void WriteDispData(unsigned char DataH, unsigned char DataL)
{ }
//////////////////////////////////////////////////////////////////////////////////// /*
LCD初始化函数
*/
void LCD_Init(void)
{ } /*
LCD块写(大量数据修改,相当于擦除)
*/
void BlockWrite(unsigned int Xstart, unsigned int Xend, unsigned int Ystart, unsigned int Yend)
{ } /*
LCD显示颜色(颜色已在.h文件中定义)
*/
void DispColor(unsigned int color)
{ } /*
写一个点(带颜色)
*/
void WriteOneDot(unsigned int color)
{ } //////////////////////////////////////////////////////////////////////////////////// /*
绘制一个像素点
*/
void PutPixel(unsigned int x, unsigned int y, unsigned int color)
{ } /*
绘制一片区域(名字为线,其实可以刷一个面)
*/
void DrawLine(unsigned int Xstart, unsigned int Xend, unsigned int Ystart, unsigned int Yend, unsigned int color)
{ } void Delay_ms(u16 time)
{
u16 i=;
while(time--)
{
i=;
while(i--);
}
}

同样的为了适配stm32,.H文件中宏定义也做了相应调整:

1、蓝色部分引脚高低电平宏定义是根据stm引脚设置特性做的修改~

2、黄色部分是为了使stm32的引脚能够像51单片机一样直接给赋值,如:LCD_CS=0或LCD_CS=1

3、其他部分没变,这就说明了之前我们用宏定义的好处了~

 #include "stm32f10x.h"

 /*
引脚高低电平宏定义
*/
8 #define CS_SET GPIO_SetBits(GPIOA, GPIO_Pin_0)//GPIO_Mode_Out_PP
9 #define CS_CLEAR GPIO_ResetBits(GPIOA, GPIO_Pin_0)//普通推挽输出
10 #define RS_SET GPIO_SetBits(GPIOA, GPIO_Pin_1)
11 #define RS_CLEAR GPIO_ResetBits(GPIOA, GPIO_Pin_1)
12 #define RET_SET GPIO_SetBits(GPIOA, GPIO_Pin_2)
13 #define RET_CLEAR GPIO_ResetBits(GPIOA, GPIO_Pin_2)
14 #define SCL_SET GPIO_SetBits(GPIOA, GPIO_Pin_3)//GPIO_Mode_AF_PP
15 #define SCL_CLEAR GPIO_ResetBits(GPIOA, GPIO_Pin_3)//复用推挽输出
16 #define SDA_SET GPIO_SetBits(GPIOA, GPIO_Pin_4)
17 #define SDA_CLEAR GPIO_ResetBits(GPIOA, GPIO_Pin_4)
19 #define BitBand(Addr, Bit) *((volatile int*)(((int)(Addr) & 0x60000000) + 0x02000000 + (int)(Addr) * 0x20 + (Bit) * 4))
20 #define LCD_CS BitBand(&GPIOA->ODR, 0)
21 #define LCD_RS BitBand(&GPIOA->ODR, 1)
22 #define LCD_SDA BitBand(&GPIOA->ODR, 4)
23 #define LCD_SCK BitBand(&GPIOA->ODR, 3)
/*
宏定义等待函数
*/
#define DELAY_MS(n) Delay_ms(n) //-------------------------------------------------------------
#define ROW 160 //显示的行、列数
#define COL 128 #define BLUE 0xF800 //定义颜色常量
#define GREEN 0x07E0
#define RED 0x001F
#define WHITE 0xFFFF
#define BLACK 0x0000
#define GRAY 0xEF5D //0x2410
#define GRAY75 0x39E7
#define GRAY50 0x7BEF
#define GRAY25 0xADB5 void Delay(u16 time);
void Delay_ms(u16 time);
void DrawLine(unsigned int Xstart, unsigned int Xend, unsigned int Ystart, unsigned int Yend, unsigned int color);
void PutPixel(unsigned int x, unsigned int y, unsigned int color);
void WriteOneDot(unsigned int color);
void DispColor(unsigned int color);
void BlockWrite(unsigned int Xstart, unsigned int Xend, unsigned int Ystart, unsigned int Yend);
void LCD_Init(void);
void WriteDispData(unsigned char DataH, unsigned char DataL);
void LCD_GPIO_Init(void);

这样在main函数中只要简单调用即可:

 #include "stm32f10x.h"
#include "LCD.h" void RCC_Configuration(void); int main(void)
{
RCC_Configuration(); //系统时钟配置
11 LCD_GPIO_Init();
12 // Delay_ms(5000);
13 LCD_Init();
while (>)
{
16 DispColor(RED);
Delay_ms();
DispColor(BLUE);
Delay_ms();
}
} void RCC_Configuration(void)//系统时钟配置为72MHZ
{
SystemInit();
}

小结:

从上面视频来看即使改成了STM32,驱动SPI屏幕还是不能实现肉眼分辨不出的刷屏效果

接下来试着采用并口数据传输试试~

本节工程链接:http://pan.baidu.com/s/1gdfkwoz

@beautifulzzzz

  2015-11-26 持续更新中~