[STM32F1]使用STM32F103驱动ST7567液晶屏

 前言:第一次使用社区的背景,感觉还不错,此处要@21小跑堂 还是跑堂兄教我的呢,跑堂兄太棒了,超级奈斯。5.20快乐哦!!!
      回到正题,ST7567是一种LCD液晶屏的驱动芯片之一,它是单芯片点矩阵式的LCD驱动器,集成了LCD控制器和公共/段驱动器。从MPU发送的显示数据存储在65x132位的内部显示数据RAM(DDRAM)中。DDRAM中存储的显示数据位与LCD面板的像素直接相关。ST7567包含132个段输出,64个公共输出和1个图标公共输出。借助内置的振荡电路和低功耗电源电路,ST7567无需外部时钟或电源即可生成LCD驱动信号,从而可以使显示系统的组件最少,功耗最小。而且它还具有6800,8080和4线SPI等通信方式,其中6800和8080是屏幕专用的一种并口通信方式,但是我们常用的就是8080总线方式和4线SPI通信方式来驱动液晶屏,本次使用的是4线SPI通信方式来驱动ST7567的LCD液晶屏。今天我们就来驱动一款TM9665ACC的LCD液晶屏。

 

 

      这个是老王的屏幕,这个屏幕最大的特点就是便宜好用,驱动简单,但是这个屏里有个背景纸,不是太好看,如果动手能力强的话,可以把背景纸去掉,显示效果会更好看。非常通透。

      首先,要知道屏的各个引脚,而且要知道每个引脚是什么功能。屏幕引脚如下图所示。

      首先,这个屏有14个引脚,1,2,3,11和14引脚是GND其次是4,5引脚是VCC,电压是3.3V接下来6,7,8,9,10,都是功能引脚,分别是复位引脚,CS片选引脚,A0数据/命令引脚,数据信号,时钟信号,12和13是背光引脚,A代表正极,K代表负极,知道每个引脚的定义之后,就可以焊接或者做电路板了,由于之前做好了电路,就不用很麻烦的飞线了。电路板的图纸是搬抄群里大佬的,在这里深表感谢

接下来由于知道驱动是ST7567,所以就可以直接写驱动代码了,驱动代码部分展示。

void Lcd_Init(void)

{

    delay_ms(10);

    LCD_RST_LOW();

    delay_us(100);

    LCD_RST_HIGH();

    delay_ms(255);

    delay_ms(255);

    delay_ms(255);

    LCD_WR_REG(0X2F);                //开内部升压,不然要接外部VLCD

    LCD_WR_REG(0X81);                //要求输入对比度

    LCD_WR_REG(0XB0);                //对比度数值,这个要自己试验一下最佳效果。

    LCD_WR_REG(0XEB);                //液晶偏压设置  1/9

    LCD_WR_REG(0XC2);                //设置扫描方式,默认从左到右,上到下。

    LCD_WR_REG(0XAF);                //开显示

}

//清屏函数

void LCD_Clear(void)

{

    u16 i, j;

    i = 192 * 64 / 8; //128X64像素,但是RAM192列的,我也没有找到如何设置列结束位置。数据大小要除以8位数据

    for(; i > 0; i--)

    LCD_WR_DATA8(0x00); //DAT =0X00,清全白,OXFF,清全黑

}

//-------LCD设置坐标---------------------------------------

void LCD_SetPos(u8 page, u8 column)

{

    column = column - 1; //我们平常所说的第 1 列,在 LCD 驱动 IC 里是第 0 列。所以在这里减去 1.

    page = page - 1;

    LCD_WR_REG(0xb0 + page);/*设置页地址。每页是 8 行。一个画面的 64 行被分成 8 个页。我们平常所说的第 1 页,在 LCD

                                                                                                        驱动 IC 里是第 0 页,所以在这里减去 1*/

                LCD_WR_REG(column & 0x0f); //设置列地址的低 4

          column >>= 4;

    column        =        column | 0x10;

    LCD_WR_REG(column);                                                                //取高4位行地址

}

//显示 16x16 点阵图像、汉字、生僻字或 16x16

void display_graphic_16x16(u8 page, u8 column, unsigned char *dp)

{

    u8 i, j;

    LCD_SetPos(page, column);                //发送地址,第一页

    for (i = 0; i < 16; i++)                                //第一页的数据16字节,列号自动累加

    {

        LCD_WR_DATA8( *dp); //写数据到LCD,如果要反色显示,就在*P前用~取反。

        dp++;

    }

    LCD_SetPos(page + 1, column);                //发送地址,第二页

    for (i = 0; i < 16; i++)                                //第二页的数据16字节

    {

        LCD_WR_DATA8( *dp); //写数据到LCD,如果要反色显示,就在*P前用~取反。

        dp++;

    }

}

汉字取模部分代码

unsigned char huan[] =

{

    0x04, 0x24, 0x44, 0x84, 0x64, 0x9C, 0x40, 0x30, 0x0F, 0xC8, 0x08, 0x08, 0x28, 0x18, 0x00, 0x00,

    0x10, 0x08, 0x06, 0x01, 0x82, 0x4C, 0x20, 0x18, 0x06, 0x01, 0x06, 0x18, 0x20, 0x40, 0x80, 0x00

};/*"",0*/

unsigned char ying[] =

{

    0x40, 0x40, 0x42, 0xCC, 0x00, 0x00, 0xFC, 0x04, 0x02, 0x00, 0xFC, 0x04, 0x04, 0xFC, 0x00, 0x00,

    0x00, 0x40, 0x20, 0x1F, 0x20, 0x40, 0x4F, 0x44, 0x42, 0x40, 0x7F, 0x42, 0x44, 0x43, 0x40, 0x00

};/*"",1*/

unsigned char shi[] =

{

    0x80, 0x60, 0xF8, 0x07, 0x04, 0xE4, 0x24, 0x24, 0x24, 0xFF, 0x24, 0x24, 0x24, 0xE4, 0x04, 0x00,

    0x00, 0x00, 0xFF, 0x00, 0x80, 0x81, 0x45, 0x29, 0x11, 0x2F, 0x41, 0x41, 0x81, 0x81, 0x80, 0x00

};/*"使",0*/

unsigned char yong[] =

{

    0x00, 0x00, 0xFE, 0x22, 0x22, 0x22, 0x22, 0xFE, 0x22, 0x22, 0x22, 0x22, 0xFE, 0x00, 0x00, 0x00,

    0x80, 0x60, 0x1F, 0x02, 0x02, 0x02, 0x02, 0x7F, 0x02, 0x02, 0x42, 0x82, 0x7F, 0x00, 0x00, 0x00

};/*"",1*/

主函数部分代码

int main(void)

{

        u8 t;

        u8 *temp;

        u16 SET_VOLTAGE = 123;

                SystemInit ();

                NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);

            delay_init();                        //延时初始化

            LCD_IO_init();                        //显示屏IO初始化

                   Lcd_Init();                        //显示屏寄存器初始化

                   LCD_Clear();                        //显示屏清屏操作

                uart_init(9600);                 //波特率使用115200

            printf("欢迎使用\r\n");

    while(1)

    {

                display_graphic_16x16(3, 16, 0, huan);

                display_graphic_16x16(3, 32, 0, ying);

                display_graphic_16x16(3, 48, 0, shi);

                display_graphic_16x16(3, 64, 0, yong);

}

}





 

      “欢迎使用”是最终的显示效果,感觉显示的效果还是不错的,而且比较清晰好看。不过显示过程中也有很多麻烦,比如显示位置不对,最后发现是设置坐标函数有问题导致的,重新计算和修改之后就没有这种问题发生了。最后把驱动程序部分分享出来,方便大家使用。
---------------------
作者:yangjiaxu
链接:https://bbs.21ic.com/icview-3133844-1-1.html
来源:21ic.com
此文章已获得原创/原创奖标签,著作权归21ic所有,任何人未经允许禁止转载。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
STM32F103是意法半导体(STMicroelectronics)推出的一款32位微控制器系列产品,而ST7567是一款单片式点阵图形LCD控制器。要驱动ST7567,我们需要在STM32F103上进行相应的配置和编程。 首先,我们需要配置GPIO引脚,将其作为SPI接口的引脚使用。可以根据ST7567的引脚定义,连接到STM32F103的相应引脚上,然后通过STM32的寄存器设置相应的GPIO模式和输出。 接下来,我们需要配置SPI控制器,并设置SPI的通信参数,如速度、数据位宽等。可以通过初始化SPI控制寄存器、设置SPI时钟和数据位宽等步骤来完成配置。 然后,我们需要编写驱动程序,通过SPI接口与ST7567进行通信。可以使用STM32的SPI库函数来简化编程过程。通过发送命令和数据,我们可以设置ST7567的工作模式、显示区域、画点、清屏等操作。 在编写驱动程序时,我们需要根据ST7567的规格手册来了解其指令集和寄存器的操作方式。根据规格手册,我们可以编写相应的函数来发送指令和数据,并通过SPI接口与ST7567进行通信。 最后,我们还可以编写一些高级的显示函数,用于在ST7567上显示文本、图像等。可以使用适当的算法将图像数据转换为ST7567可识别的格式,并使用驱动程序中的函数将数据写入ST7567的显示缓冲区。 通过以上步骤,我们就可以在STM32F103上成功驱动ST7567,实现对LCD的控制和显示。当然,在实际的驱动过程中,还需要考虑SPI通信的时序、时钟同步等问题,以确保数据的正确传输和显示效果的稳定性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值