完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
`
左图是原图,右图是仿真出来的图 用LCD12864显示图片的时候,水平方向只有屏幕左边16个点会显示,垂直方向能够全部显示,大家能够帮忙回答一下吗?谢谢
` |
|
相关推荐
11个回答
|
|
楼主做的不错,希望继续努力
|
|
|
|
你的程序里K的循环就是只有16个,改成64试试吧
|
|
|
|
k=16,一次会写一个byte进去,也就是8个点,写16次正好一行128个点。k就是16吧 |
|
|
|
确定一下你选用的12864的参数吧,i=0和1,应该时左右屏的判断,如果分左右屏的话,那就是两个64X64点的屏,最多也只需要写64个点,而不是128个。
另外还有12864显示的方向,是一个字节代表横向显示,还是纵向显示。j的范围是32,这个也只是64的一半。 个人认为应该写个测试程序,能够显示全屏,来判断12864的各个参数 |
|
|
|
人中狼 发表于 2018-4-24 20:25 感谢你耐心的回复。 i的确是用来区分两个屏的,不过是上下两个屏。我用的这个12864在绘图显示模式的时候,分成上下两个128*32的屏幕。 显示的方向,是一个字节横向显示。每2个字节组成水平方向的基本单位,所以上半个屏幕的横坐标是0~7,下半个屏幕的横坐标是8~15。如图 我看器件手册上面说,在写入的时候不需要手动改横坐标,每写完2个字节横坐标会自动加1,这也就是为什么我只设置了两次横坐标 :sendCmd(0x80) 写上半个屏幕的时候;sendCmd(0x88)。(0x80和0x88的低几位才是用来存储地址信息的)。我怀疑是水平方向的地址没有自动增加,导致只有0x80和0x88这两个水平位置所对应的这一大列写入了数据。 j是用来写半个屏幕的,上面半个屏幕32行,下面也是。 我下去写一下测试的程序。 再次感谢你耐心的回复! |
|
|
|
很有可能的原因是你的显示超出了范围
|
|
|
|
有可能是显示范围太大,楼主试试修改代码!
|
|
|
|
不是超出范围了,是绘图的时候,水平方向的地址没有自动增加(手册上说会自动增加的),每写完16位之后手动设置水平地址再写就能够正常显示了。至于为什么水平地址没有自增,我也不知道。 |
|
|
|
不是超出范围了,是绘图的时候,水平方向的地址没有自动增加(手册上说会自动增加的),每写完16位之后手动设置水平地址再写就能够正常显示了。至于为什么水平地址没有自增,我也不知道。 |
|
|
|
原因找到了,是绘图的时候,水平方向的地址没有自动增加(手册上说会自动增加的),每写完16位之后手动设置水平地址再写就能够正常显示了。至于为什么水平地址没有自增,我也不知道。附上修改后的代码:
|
|
1 条评论
|
|
都是好资料,谢谢网友的共享。
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
求助一下关于51系列单片机的Timer0的计时问题,TH0、TL0+1的时间是怎么算的?
770 浏览 0 评论
【RA-Eco-RA4E2-64PIN-V1.0开发板试用】开箱+Keil环境搭建+点灯+点亮OLED
544 浏览 0 评论
【敏矽微ME32G070开发板免费体验】使用coremark测试敏矽微ME32G070 跑分
677 浏览 0 评论
【敏矽微ME32G070开发板免费体验】开箱+点灯+点亮OLED
904 浏览 2 评论
649 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
11990 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-21 16:58 , Processed in 1.029304 second(s), Total 94, Slave 76 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号