一、说明
文件名称:LED移位控制实验
* 实验目的:1.掌握单片机IO口操作的基本方法
* 2.掌握移位运算符的使用方法
* 实验配置:J3跳线配置为IO方式,J5配置为KBD、J2配置为1-3和2-4
* 实验现象:LED以0.2S为间隔移位操作
* 硬件环境:IAP15F2K61S2单片机,单片机内部振荡器频率:11.0592M
* 注意事项:要用到_nop_()必须要包含intrins.h头文件
二、电路图及分析
LED灯是一个二极管的发光器件,有单向导通性,只有阳极为高电平,阴极为低电平时,发光二极管才会导通发光。根据电路图,发光二极管的阳极,已经给了一个高电平,所以只要在阴极给出一个低电平,就可以让二极管发光。
却点亮了8个LED灯。事实上,蓝桥杯单片机的这块板子,你直接令P0口为0,是无法点亮IO口的。
这是因为在P0端口与发光二极管之间有一个芯片74HC573,也就是我们上节所说的锁存器。
1.锁存器的使能端(LE)被设置为高电平,这样锁存器就处于透明状态,即输入端的数据可以直接传递到输出端。
2.当锁存器的使能端(LE)被设置为低电平时,输入端的数据被锁存,即输出端的状态不再随输入端变化,保持输入时的状态。
锁存器的输出端连接到LED的驱动电路,当输出端为低电平时,LED点亮;当输出端为高电平时,LED熄灭。
138译码器接收来自单片机I/O口的信号,并根据这些信号的组合,选择一个对应的输出端为低电平,其他输出端为高电平。
74HC138的输出(Y0-Y7)连接到74HC02或非门的输入。当Y4输出低电平时,对应的或非门输出Y4C将为高电平。这个高电平将作为锁存器的使能信号。
当译码器的某个输出为低电平时,或非门输出高电平,使能对应的锁存器输出端口
138译码器这里的是用高三位来控制位选的,例如我们选择Y4(100,二进制)我们需控制高三位为这三个数字就行了。
在锁存器的基础上,通过改变P0端,控制各个元器件。
三、代码
#include "reg52.h" //定义51单片机特殊功能寄存器
#include "intrins.h"
//关闭外设
void cls_buzz(void)
{
P2 = (P2 & 0x1F | 0xA0);
P0 = 0x00;
P2 &= 0x1F;
}
//延时函数
void delay(void) //@11.0592MHz
{
unsigned char i, j, k;
_nop_();
_nop_();
i = 9;
j = 104;
k = 139;
do
{
do
{
while (--k);
}
while (--j);
}
while (--i);
}
//主函数
void main(void)
{
unsigned char i;
cls_buzz();
while(1)
{
for(i = 0; i < 8; i++)
{
P2 = ((P2 & 0x1f) | 0x80);
P0 = 0xfe << i; //左移i位,1111 1110
P2 &= 0x1f;
delay();
}
}
}
这个实验与之前的实验的不同就是在于实现LED的位移变化,我们可以通过位移运算符以及循环的方式去实现P0端低电平的依次输出。
四、硬件结果拍照
1.2LED移位控制实验