硬件新做了一个板子,试了下显示还是乱码,布线改了,但是没改原理图,原理图公司一直在用,没出过问题。现在来分析分析软件的原因
这是数据接口程序,由于DB0-DB7分布在三组GPIO上所以用了位操作,
//数据命令引脚设置void Screen_GPIO(u8 byte){ GPIOB->BSRR = (byte&0x0f) << 6 | ((~byte)&0x0f) << 22 ; GPIOC->BSRR = (byte&0x30) << 4 | ((~byte)&0x30) << 20 ; GPIOA->BSRR = (byte&0xc0) << 5 | ((~byte)&0xc0) << 21 ; // GPIOE->BSRR = byte | ~byte << 16;}
//写命令void ST7567_Write_Cmd(u8 cmd){ LCD_CS1 = 0; LCD_A0 = 0; LCD_RW = 0; Screen_GPIO(cmd); LCD_E = 1; LCD_E = 0; LCD_CS1 = 1; Screen_GPIO(0x00); delay_us(2);}
这是写命令时序,按理说写入数据是在LCD_E从1变为0的过程,对数据口赋值有时间间隔应该不影响显示才对
而且最后两句命令是为了减轻乱码才加上的,在别的单片机上使用屏幕不需要加置0和延时操作,加上以后乱码减少,但是还是存在
不同的单片机平台,机器周期不同,需要微调时序,我最近用proteus仿真也遇到了这种情况,后来发现还是时序有问题,有示波器可以看一下时序图是否有问题,此外显示算法也要报这个没问题才行。
delay();
LCD_E = 1;
delay(); LCD_E = 0;
这两句中间加点延时试试。
乱码一般也很可能是你现实函数有问题。