2019-04-04 23:24:37 weixin_44229819 阅读数 511
  • 静态和动态控制数码管-第1季第7部分

    本课程是《朱有鹏老师单片机完全学习系列课程》第1季第7个课程,全面讲解了静态数码管、无38译码器式动态数码管、有38译码器式动态数码管等各种数码管驱动方式,学完本课程将会对数码管的驱动方式彻底熟悉和掌握。

    2846 人正在学习 去看看 朱有鹏

单片机的数码管动态实现


在这里插入图片描述
#单片机数码管实现其实很简单首先你注意两个问题
1:你要控制是哪一个数码管亮(74HC138)
2:你要控制数码管的那个位置亮(74HC245)

74HC138芯片

数码管的位

  1. 由单片机接口控制输出
    下面是单片机各个接口的真值表:
LED P2.2 P2.3 P2.4
LED1: 0 0 0
LED2: 0 0 1
LED3: 0 1 0
LED4: 0 1 1
LED5: 1 0 0
LED6: 1 0 1
LED7: 1 1 0
LED8: 1 1 1
  1. 这是单片机中74HC138芯片的接法
    在这里插入图片描述

74HC245芯片

数码管各位置代号 a b c d e f g
接口 P0.1 P0.2 P0.3 P0.4 P0.5 P0.6 P0.7

tip注意每个接口接低电位时,相应的位置为高亮
这是接口对应图

一段漂亮的代码片用于自研究,目前尚还不知道为啥数码管不亮—┭┮﹏┭┮
--------------------希望大神指导-------------------

#include <reg52.h>
int code table[]={0x3f,0x03,0x5b,0x4f,0x66,0x6d,0x7c,0x07,0x7f};
sbit HC138A=P2^2;
sbit HC138B=P2^3;
sbit HC138C=P2^4;
void led(int x)
{
 if   (x==1){    HC138A=0; HC138B=0; HC138C=0; };
 if   (x==2){    HC138A=0; HC138B=0; HC138C=1; };
 if   (x==3){    HC138A=0; HC138B=1; HC138C=0; };
 if   (x==4){    HC138A=0; HC138B=1; HC138C=1; };
 if   (x==5){    HC138A=1; HC138B=0; HC138C=0; };
 if   (x==6){    HC138A=1; HC138B=0; HC138C=1; };
 if   (x==7){    HC138A=1; HC138B=1; HC138C=0; };
 if   (x==8){    HC138A=1; HC138B=1; HC138C=1; };
 
 
}
void main()
{
 int x;
 while(1)
 {
 led(1);
 P0=table[0];
             P0=0Xff;
 led(2);
 P0=table[1];
             P0=0Xff;
 led(3);
 P0=table[2];
             P0=0Xff;
 led(4);
 P0=table[3];
             P0=0Xff;
 led(5);
 P0=table[4];
             P0=0Xff;
 led(6);
 P0=table[5];
             P0=0Xff;
 led(7);
 P0=table[6];
             P0=0Xff;
 led(8);
 P0=table[7];
             P0=0Xff;
 };
}

#其实现在我这代码还是有很多小瑕疵,希望大神能致电小白----万分感谢

2015-07-29 15:50:11 C1033177205 阅读数 6959
  • 静态和动态控制数码管-第1季第7部分

    本课程是《朱有鹏老师单片机完全学习系列课程》第1季第7个课程,全面讲解了静态数码管、无38译码器式动态数码管、有38译码器式动态数码管等各种数码管驱动方式,学完本课程将会对数码管的驱动方式彻底熟悉和掌握。

    2846 人正在学习 去看看 朱有鹏

51单片机一位数码管汇编程序

程序:

;数码管从0-9显示

		ORG		0000H
		AJMP	MAIN
		ORG		0030H
			
MAIN:	
		MOV	R4,	#00H	;记录码表的值
		MOV	DPTR,	#TABLE	;把地址送DPTR
		
STRAT:	MOV		A,	R4	
		MOVC	A,	@A+DPTR		;取码
		MOV	P2,	A		;显示
		INC	R4			;自增,取下个值做准备
		CALL	DELAY			;调用
		CJNE	R4,	#16,	STRAT	;判断是否显示完16个数值
		AJMP	MAIN

DELAY:	
	MOV	R6,	#1
DELAY4:	MOV	R1,	#10
DELAY3:	MOV	R2,	#100
DEALY1: MOV	R3,	#250
DEALY2: NOP
		NOP
		DJNZ	R3,DEALY2
		DJNZ	R2, DEALY1
		DJNZ	R1, DELAY3
		DJNZ	R6, DELAY4
		RET
		
;码表
TABLE:	DB<span style="white-space:pre">	</span>0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e

END

仿真图:


程序截图:


2019-06-05 21:40:46 qq_41879767 阅读数 113
  • 静态和动态控制数码管-第1季第7部分

    本课程是《朱有鹏老师单片机完全学习系列课程》第1季第7个课程,全面讲解了静态数码管、无38译码器式动态数码管、有38译码器式动态数码管等各种数码管驱动方式,学完本课程将会对数码管的驱动方式彻底熟悉和掌握。

    2846 人正在学习 去看看 朱有鹏
 计划:通过51单片机和stm32单片机实现一些组合功能想法,这是第一记,希望能坚持下去。
 开发环境:STC89C52单片机普中HC6800-ES V2.0
 任务目标:利用数码管实现99999999的计时与数码管逐位显示
 程序分块:利用定时器中断+静态数组存储与动态刷新,存储数码管数字1-9的code char数组
 定时时间以1ms按照11.052MHZ计算对应的TH0和TL0值写入,累积1s后产生中断数码管计时,
 通过关闭段选,消除了重影。
 接下来是主要程序代码:
#include <reg52.h>	   

unsigned char code LEDCHAR[] = {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
unsigned char LEDBUFF[8] = 0;

sbit  A  = P2^2;
sbit  B1  = P2^3;
sbit  C  = P2^4;
unsigned char i = 0;//动态扫描索引时间
unsigned int cnt = 0 ;//记录中断次数

void main()
{

	unsigned long sec = 0 ;//经过时间
	EA  = 1;
	
	//由于使能位已经处于高电平使能状态故不需要激活
	TMOD = 0x01;
	TH0 =  0xFC;
	TL0 =  0x67;//1ms计时
	ET0 = 1;
	TR0 = 1;
	while(1)
	{
		if(TF0 == 1)
		{
			TF0 = 0;
			TH0 = 0xFC;
			TL0 = 0x67;
			cnt++;
			if(cnt >= 1000)
			{
				cnt = 0;
				sec++;
				LEDBUFF[0] = LEDCHAR[sec%10];
				LEDBUFF[1] = LEDCHAR[sec/10%10];
				LEDBUFF[2] = LEDCHAR[sec/100%10];
				LEDBUFF[3] = LEDCHAR[sec/1000%10];
				LEDBUFF[4] = LEDCHAR[sec/10000%10];
				LEDBUFF[5] = LEDCHAR[sec/100000%10];
				LEDBUFF[6] = LEDCHAR[sec/1000000%10];
				LEDBUFF[7] = LEDCHAR[sec/10000000%10];
				//可以通过该改变cnt验证位数,发现这块开发板上数码管驱动的译码器编号与其不同
			}
		}
	}
}

void interrupt_timer0() interrupt 1
{
	TH0 = 0xFC;
	TL0 = 0x67;
	cnt++;
	P0 = 0x00;
	switch(i)
			{
				case 0:A = 0;B1 = 0;C = 0;i++;P0 = LEDBUFF[0];break;
				case 1:A = 0;B1 = 0;C = 1;i++;P0 = LEDBUFF[4];break;
				case 2:A = 0;B1 = 1;C = 0;i++;P0 = LEDBUFF[2];break;
				case 3:A = 0;B1 = 1;C = 1;i++;P0 = LEDBUFF[6];break;
				case 4:A = 1;B1 = 0;C = 0;i++;P0 = LEDBUFF[1];break;
				case 5:A = 1;B1 = 0;C = 1;i++;P0 = LEDBUFF[5];break;
				case 6:A = 1;B1 = 1;C = 0;i++;P0 = LEDBUFF[3];break;
				case 7:A = 1;B1 = 1;C = 1;i=0;P0 = LEDBUFF[7];break;
				default:break;
			}
}
2015-11-18 11:15:51 u013151320 阅读数 5662
  • 静态和动态控制数码管-第1季第7部分

    本课程是《朱有鹏老师单片机完全学习系列课程》第1季第7个课程,全面讲解了静态数码管、无38译码器式动态数码管、有38译码器式动态数码管等各种数码管驱动方式,学完本课程将会对数码管的驱动方式彻底熟悉和掌握。

    2846 人正在学习 去看看 朱有鹏

一.数码管基础知识

LED数码管是由多个发光二极管封装在一起组成“8”字型的器件,引线已在内部连接完成,只需引出它们的各个笔划,公共电极。LED数码管常用的段数一般为7段,有的另加一个小数点 。LED数码管根据LED的接法不同,分为共阳和共阴两类 。
1.共阳极数码管
指八段数码管的八段发光二极管的阳极(正极)都连在一起,而阴极对应的各段可分别控制,如图a所示。
这里写图片描述
2.共阴极数码管
指八段数码管的八段发光二极管的阴极(负极)都连在一起,而阳极对应的各段分别控制,如图b所示。
这里写图片描述

二.静态数码管(以共阳极为例)

1.原理分析
LED 发光二极管的正极共同接在VCC上,这里以单片机P1口为例,当P1口对应引脚为0(即低电平)时数码管的该段发光二极管亮。
这里写图片描述
2.共阳极数码管段选编码
这里写图片描述

显示0到F的编码:0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e

3.例程
单个数码管显示0到F:

#include <reg51.h>
unsigned char code num[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e};
void delay_ms(unsigned int z)   
{
  unsigned int i,j;
  for(i=z;i>0;i--)
     for(j=110;j>0;j--);        
}
void main()
{
    unsigned int i;
    while(1)
    {
        for(i=0;i<16;i++)
        {
           P0=num[i];
           delay_ms(300);
           P0=0xff;
           delay_ms(100);
        }
    }
}

三.动态数码管(以共阴极为例)

1.原理分析
动态显示是多个数码管,交替显示,利用人的视觉暂停作用使人看到多个数码管同时显示的效果。就像我们看的电影是有一帧一帧的画面显示的,当速度够快的时候我们看到它就是动态的。当我们显示数码管的速度够快的时候,也就可以看到它们是同时显示了。

2.数码管动态扫描的一般步骤
(1).给对应的IO口赋位选编码选择让哪一位亮。
(2).给选中的数码管赋段选编码,使其显示对应的数字或字母。
(3).适当延时使其显示稳定(特别注意延时不宜过长)
(4).消隐,即消除上一次IO输出段码对本次段码的影响。

3.共阴极数码管编码
(1).位选编码
位选即让第几个数码管显示,以8个数码管为例
让第1到8个显示的编码:0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f

(2).段选编码
段选即让数码管显示什么,共阴极数码管给1(即高电平)时该段亮
显示0到F:0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x7f
*位选和段选的编码还与电路设计有关,具体情况请根据电路图接线具体分析

4 .例程
让八位数码管显示稳定的0到7:

#include<reg51.h>
unsigned char code wei[8] = {0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};//位选控制   查表的方法控制
unsigned char code duan[17] ={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
//0、1、2、3、4、5、6、7、8、9、A、b、C、d、E、F的显示码

void delay_ms(unsigned int z)   
{
  unsigned int i,j;
  for(i=z;i>0;i--)
     for(j=110;j>0;j--);        
}

void main(void)
{
    unsigned char i;
    for(i=0;i<8;i++)
    {
        P0=wei[i];    //位选,选择让哪一位亮
        P1=duan[i];   //段选,让数码管显示什么
        delay_ms(2);  //延时使显示充分
        P1=0x00;         //消隐
    }           
}
2018-07-26 13:49:00 tjy199610_10 阅读数 778
  • 静态和动态控制数码管-第1季第7部分

    本课程是《朱有鹏老师单片机完全学习系列课程》第1季第7个课程,全面讲解了静态数码管、无38译码器式动态数码管、有38译码器式动态数码管等各种数码管驱动方式,学完本课程将会对数码管的驱动方式彻底熟悉和掌握。

    2846 人正在学习 去看看 朱有鹏

数码管分类:共阴极数码管,共阳极数码管
数码管的显示方式:静态和动态
共阴级数码管:1亮0不亮
共阳极数码管:0亮1不亮
数码管的基础知识就不多讲了,下面是我写的几个数码管的程序,通过和单片机连接可以实现其相应的功能。

/*-------------------------------
    2018.7.22
    七段显示实验
    功能让数码管从0到99不停的显示
-----------------------------*/
#include <reg51.h>
#include "delay.h"
#define DataPort P1 //宏定义,如果换接口,只需要修改这里
//#define DataPort2 P1 //宏定义,如果换接口,只需要修改这里

sbit Seg_Latch = P2^2;//段锁存
sbit Bit_Latch = P2^3;//位锁存
unsigned char Seg_Code[] = {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
unsigned char code Bit_Code[] = {0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
//段码,位码
unsigned char Template[8];
void delay(unsigned int t)
{
    while(t--);
}
void display(unsigned char n)
{
    unsigned char i;
    for(i = 0; i < n; i++)
    {
        DataPort = 0;//清除数据,防止重影
        Seg_Latch = 1;//开门
        Seg_Latch = 0;//关门

        DataPort = Bit_Code[i];//送位码
        Bit_Latch = 1;//开门
        Bit_Latch = 0;//关门

        DataPort = Template[i];//送段码
        Seg_Latch = 1;//开门
        Seg_Latch = 0;//关门
        delay(200);
    }
}

void main()
{
    unsigned char count;
    unsigned char j = 0;
    while(1)
    {
        j++;
        if(j == 50)
        {
            j = 0;
            count++;
            if(count == 100)
                count = 0;
        }
        Template[0] = Seg_Code[count / 10];
        Template[1] = Seg_Code[count % 10];
        display(2);

    }

}

单片机控制数码管

阅读数 1453

没有更多推荐了,返回首页