基于 51 的点阵屏显示·16*16 点阵仿真实验(静态显示,左移显示)

本文详细介绍了基于51单片机的16*16点阵屏显示原理,通过38译码器实现行选,并探讨了如何通过74HC595实现列选,节省IO资源。实验内容包括静态显示和点阵的上移、左移控制。提供了源代码和仿真资源,帮助理解点阵屏的移位显示机制。
摘要由CSDN通过智能技术生成

若想更详细了解可以先跳转到:

基于 51 的点阵屏显示 8*8 点阵仿真实验:

基于 51 的点阵屏显示 8*8 点阵仿真实验-CSDN博客

对一个模块进行了解

16*16 点阵的显示原理

        虽然完成了上面 8*8 点阵的显示,但是由于点的数量太少以至于它的显示效果并不是很理想,事实上现在大部分点阵的汉字都是16*16显示的,下面让我们来学习16*16点阵的显示。和上面一样我们先选择元件 :AT89C52 ,74LS138, ,MATRIX-8*8-GREEN ,因为要显示16*16的汉字,我们就不能再使用一个38译码器进行行选了,这里我们用两个38译码器组合成一个4 选 16的译码器(当然也可以使用 74159)。而MATRIX-8*8-GREEN 点阵需要4个。完成后如下图:

        先来看看 4 选 16 的译码器是如何工作的,这里有 4 个输入端a、b、c、d,16 个输出端 HO~H15,如上图连线后即可完成类似于38译码器一样的工作。只不过扩展到了16 行选。关于连线的原理这里不再赘述,只要明白38译码器的原理这个可以轻松理解。接着完成全部布线。如下图所示:

        连好线后,P1作为行选,P2、P3一起作为列选。现在16*16的点阵被分成两块并不完整的部分,我们可以整体移动(包括点阵屏、连线以及连接点,)来方便我们观察显示的效果(最好同时去掉仿真中电平的指示灯)。接着我们来看一个程序,还是让此点阵屏显示一个汉字:“明。”先看效果图:

源代码如下:

#include<reg52.h> 
char code table[]={0x00,0x20,0x20,0x7F,0x7E,0x21,0x22,0x21, 
 0x22,0x21,0x22,0x3F,0x3E,0x21,0x22,0x21, 
 0x22,0x21,0x22,0x3F,0x3E,0x21,0x22,0x21, 
 0x80,0x20,0x80,0x20,0x40,0x28,0x20,0x10}; // 明
void delay(int z) 
{ 
 int x,y; 
 for(x=0;x<z;x++) 
 for(y=0;y<110;y++); 
} 
void main() 
{ 
 int num; 
 while(1) 
 { 
 for(num=0;num<16;num++) 
 { 
 P1=nu
  • 17
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

时光の尘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值