㈠ 单片机定时器控制数码管动态显示程序
基本上不算消耗太多时间。
每个指令的消耗时间可以KEIL模拟仿真的时候可以大概算出时间。
if(++t!=350)return,这句是没有达到350,就退出中断函数,到了中断时间载再进入就是另外一次了。
㈡ 单片机数码管如何显示数字
从电路图来看,是需要数码管共阳极的,哪一位的三极管导通,则该位的数码管就有被点亮的机会。
那么七段码数据,低电平的位对应该笔画的LED亮。
大致代码:
P2=0xff;
P0=s_code[1]; //0xF9
P2=0xfe;// P2.0=0
delay_ms();
P2=0xff;
P0=s_code[2]; //0xA4
P2=0xfd;// P2.1=0
delay_ms();
P2=0xff;
P0=s_code[3]; //0xB0
P2=0xfb;// P2.2=0
delay_ms();
P2=0xff;
P0=s_code[4]; //0x99
P2=0xf7;// P2.3=0
delay_ms();
㈢ 单片机用一个按键控制数码管显示图
#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char //宏定义
sbit key1=P0^0; //定义键盘IO口
sbit key2=P0^1; //
sbit beep=P2^3;
sbit key3=P0^2;
uchar code table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,
0x82,0xf8,0x80,0x90}; //共阳数码管编码号
uchar num;
void keyscan();//键扫描函数
void display();
void delayms(uint);
void main() //主函数
{
while(1) //大循环
{
///display(); //显示函数
keyscan(); //键扫描函数
display(); //显示函数
}
}
void display()//显示函数,使函数调回主函数
{
P1=table[num];//显示数码管编码数
delayms(5);
}
void keyscan() //键扫描函数
{
if(key1==0) //判断键一是否按下
{
if(key1==0)
{
delayms(10);
while(!key1);//未按下,键开路
num++;
beep=~beep;
delayms(50);
beep=~beep;
if(num==10)
{
num=0;
}
while(!key1);
}
}
if(key2==0)
{
if(key2==0)
{
delayms(10);
beep=~beep;
delayms(50);
beep=~beep;
while(!key2);
num--;
if(num==0)
{num=10;}
while(!key2);
}
}
if(key3==0)
{
if(key3==0)
{
delayms(50);
beep=~beep;
num=0;
while(!key3);
}
}
}
void delayms(uint xms) //延时函数
{
int i,j;
for(i=xms;i>0;i--)
for(j=110;j>0;j--);
}
㈣ 51单片机怎么用按键控制一个数码管,按一下显示一个数字,顺序显示
1、首先,要把代码写好,点亮数码管。
㈤ 怎样用单片机驱动LED数码管显示
数码管是由若干个LED发光字段组成,当不同字段点亮时可形成不同的数字或字符。所有字段的LED阳极接在一起,点亮字段靠控制LED阴极的称共阳极数码管,反之为共阴极数码管。单片机就是通过输出端口控制数码管不同字段的亮暗完成字符显示的(有时要加电流驱动电路)。对于多位数码管显示器在显示方式上分为静态显示(多位同时显示)和动态显示(扫描各位依次显示)。
如果你有单片机学习板的话最好,自己看教程学习,这方面你可以看吴鉴鹰单片机开发板,教程和板子功能做得全面
㈥ 用51单片机控制4位led数码管,使其显示出想要的数字,程序怎样写,谢谢
模拟串口方式0:
#include"reg52.h"
#define
uint
unsigned
int
#define
uchar
unsigned
char
sbit
P3_2=P3^2;
//模拟接受
sbit
P3_3=P3^3;
//模拟发送
uchar
code
smg[11]={0x03,0x9f,0x25,0x0d,0x99,0x49,0x41,0x1f,0x01,0x09,0xff};//数码管编码0~
9
void
display(uchar
z);
main()
{
display(5);
display(0);
display(4);
while(1);
}
/************模拟串口显示**************/
void
display(uchar
z)
{
uchar
i;
uchar
temp;
temp
=
smg[z];
for(i=0;i<8;i++)
{
P3_3=
0;
if(temp
&
0x01)
P3_2=1;
else
P3_2
=
0;
P3_3=
1;
temp
=
temp>>1
;
}
}
串口}方式0:
void
display()
{
SM0=0;
SM1=0;
//方式0
for(i=0;i<3;i++)
{
SBUF=smg[snum[2-i]];
while(!TI)
;
TI=0;
delay(1000);
}
}
还有并行口方式
占用I/O不推荐
不过程序很简单
㈦ 单片机驱动数码管显示程序
这样写:动态扫描的方法,送段码,开位,延时,关位(关本位就可以了)。再下一位。。。。
MAIN:MOV P0,#0F9H
SETB P2.0
ACALL DELAY
MOV P0,#0FFH
MOV P2,#0FFH
MOV P0,#0A4H
SETB P2.1
ACALL DELAY
;MOV P0,#0FFH
clr p2.1 ;MOV P2,#0FFH
MOV P0,#0B0H
SETB P2.2
ACALL DELAY
;MOV P0,#0FFH
clr p2.2 ;MOV P2,#0FFH
MOV P0,#99H
SETB P2.3
ACALL DELAY
;MOV P0,#0FFH
clr p2.3 ;MOV P2,#0FFH
AJMP MAIN
DELAY:MOV R1,#10
Y1:MOV R2,#100
DJNZ R2,$
DJNZ R1,Y1
RET
END
㈧ 单片机按键控制数码管显示
你有原理图没?
设置三个标志位,全局变量,需要在倒计时中断里改变状态的。
程序流程是:
主程序流程:
上电初始化(设置LED状态,设置定时器相关寄存器参数,设置三个标志位状态)--->
死循环(判断标志位是否容许按键有效,然后判断是否有按键按下,转入响应的子程序处理段)
定时器中断任务:
判断是否到15秒,到了就置位标志位。
㈨ 51单片机控制8个数码管并显示1-8
数码管段选连接到单片机P0口,位选连接到P2口
ORG0000h
MAIN:
CALLDISPLAY
AJMPMAIN
DISPLAY:
MOVR0,#0
MOVR1,#0x01
MOVDPTR,#TAB
LOOP:
INCR0
MOVA,R0
MOVCA,@A+DPTR
MOVP0,#0;消隐
MOVP0,A;送段码
CALLDELAY
MOVA,R1;送位码
RLA;移位
MOVP2,A
MOVR1,A
CALLDELAY
CJNER0,#8,LOOP;判断8次是否循环完成
RET
DELAY:
MOVR6,#25
DD:MOVR7,#50
DJNZR7,$
DJNZR6,DD
RET
TAB:DB0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90H
㈩ 用51单片机控制数码管显示
1. 接电源:VCC(PIN40)、GND(PIN20)。加接退耦电容0.1uF
2. 接晶体:X1(PIN18)、X2(PIN19)。注意标出晶体频率(选用12MHz),还有辅助电容30pF
3. 接复位:RES(PIN9)。接上电复位电路,以及手动复位电路,分析复位工作原理
4. 接配置:EA(PIN31)。说明原因。
发光二极的控制:单片机I/O输出
将一发光二极管LED的正极(阳极)接P1.1,LED的负极(阴极)接地GND。只要P1.1输出高电平VCC,LED就正向导通(导通时LED上的压降大于1V),有电流流过LED,至发LED发亮。实际上由于P1.1高电平输出电阻为10K,起到输出限流的作用,所以流过LED的电流小于(5V-1V)/10K = 0.4mA。只要P1.1输出低电平GND,实际小于0.3V,LED就不能导通,结果LED不亮。
开关双键的输入:输入先输出高
一个按键KEY_ON接在P1.6与GND之间,另一个按键KEY_OFF接P1.7与GND之间,按KEY_ON后LED亮,按KEY_OFF后LED灭。同时按下LED半亮,LED保持后松开键的状态,即ON亮OFF灭。
代码
1. #include <at89x52.h>
2. #define LED P1^1 //用符号LED代替P1_1
3. #define KEY_ON P1^6 //用符号KEY_ON代替P1_6
4. #define KEY_OFF P1^7 //用符号KEY_OFF代替P1_7
5. void main( void ) //单片机复位后的执行入口,void表示空,无输入参数,无返回值
6. {
7. KEY_ON = 1; //作为输入,首先输出高,接下KEY_ON,P1.6则接地为0,否则输入为1
8. KEY_OFF = 1; //作为输入,首先输出高,接下KEY_OFF,P1.7则接地为0,否则输入为1
9. While( 1 ) //永远为真,所以永远循环执行如下括号内所有语句
10. {
11. if( KEY_ON==0 ) LED=1; //是KEY_ON接下,所示P1.1输出高,LED亮
12. if( KEY_OFF==0 ) LED=0; //是KEY_OFF接下,所示P1.1输出低,LED灭
13. } //松开键后,都不给LED赋值,所以LED保持最后按键状态。
14. //同时按下时,LED不断亮灭,各占一半时间,交替频率很快,由于人眼惯性,看上去为半亮态
15. }
数码管的接法和驱动原理
一支七段数码管实际由8个发光二极管构成,其中7个组形构成数字8的七段笔画,所以称为七段数码管,而余下的1个发光二极管作为小数点。作为习惯,分别给8个发光二极管标上记号:a,b,c,d,e,f,g,h。对应8的顶上一画,按顺时针方向排,中间一画为g,小数点为h。
我们通常又将各二极与一个字节的8位对应,a(D0),b(D1),c(D2),d(D3),e(D4),f(D5),g(D6),h(D7),相应8个发光二极管正好与单片机一个端口Pn的8个引脚连接,这样单片机就可以通过引脚输出高低电平控制8个发光二极的亮与灭,从而显示各种数字和符号;对应字节,引脚接法为:a(Pn.0),b(Pn.1),c(Pn.2),d(Pn.3),e(Pn.4),f(Pn.5),g(Pn.6),h(Pn.7)。
如果将8个发光二极管的负极(阴极)内接在一起,作为数码管的一个引脚,这种数码管则被称为共阴数码管,共同的引脚则称为共阴极,8个正极则为段极。否则,如果是将正极(阳极)内接在一起引出的,则称为共阳数码管,共同的引脚则称为共阳极,8个负极则为段极。
以单支共阴数码管为例,可将段极接到某端口Pn,共阴极接GND,则可编写出对应十六进制码的七段码表字节数据如右图:
16键码显示的程序
我们在P1端口接一支共阴数码管SLED,在P2、P3端口接16个按键,分别编号为KEY_0、KEY_1到KEY_F,操作时只能按一个键,按键后SLED显示对应键编号。
代码
1. #include <at89x52.h>
2. #define SLED P1
3. #define KEY_0 P2^0
4. #define KEY_1 P2^1
5. #define KEY_2 P2^2
6. #define KEY_3 P2^3
7. #define KEY_4 P2^4
8. #define KEY_5 P2^5
9. #define KEY_6 P2^6
10. #define KEY_7 P2^7
11. #define KEY_8 P3^0
12. #define KEY_9 P3^1
13. #define KEY_A P3^2
14. #define KEY_B P3^3
15. #define KEY_C P3^4
16. #define KEY_D P3^5
17. #define KEY_E P3^6
18. #define KEY_F P3^7
19. Code unsigned char Seg7Code[16]= //用十六进数作为数组下标,可直接取得对应的七段编码字节
20. // 0 1 2 3 4 5 6 7 8 9 A b C d E F
21. {0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7f, 0x6f, 0x77, 0x7c, 0x39, 0x5e, 0x79, 0x71};
22. void main( void )
23. {
24. unsigned char i=0; //作为数组下标
25. P2 = 0xff; //P2作为输入,初始化输出高
26. P3 = 0xff; //P3作为输入,初始化输出高
27. While( 1 )
28. {
29. if( KEY_0 == 0 ) i=0; if( KEY_1 == 0 ) i=1;
30. if( KEY_2 == 0 ) i=2; if( KEY_3 == 0 ) i=3;
31. if( KEY_4 == 0 ) i=4; if( KEY_5 == 0 ) i=5;
32. if( KEY_6 == 0 ) i=6; if( KEY_7 == 0 ) i=7;
33. if( KEY_8 == 0 ) i=8; if( KEY_9 == 0 ) i=9;
34. if( KEY_A == 0 ) i=0xA; if( KEY_B == 0 ) i=0xB;
35. if( KEY_C == 0 ) i=0xC; if( KEY_D == 0 ) i=0xD;
36. if( KEY_E == 0 ) i=0xE; if( KEY_F == 0 ) i=0xF;
37. SLED = Seg7Code[ i ]; //开始时显示0,根据i取应七段编码
38. }
39. }