单片机 按键(采用独立式按键)按下一次,让液晶第一位显示的数码加1,显示范围0~9

单片机 按键(采用独立式按键)按下一次,让液晶第一位显示的数码加1,显示范围0~9,第1张

程序清单如下:

#include < reg51h >// 51单片机头文件

#define uchar unsigned char // 宏定义,用uchar替代无符号字符型

#define uint  unsigned int // 宏定义,用uint 替代无符号整数型

sbit Key = P2 ^ 7;

uchar Count = 0;

uchar code DataChar[10] = // 定义数码管的段码 '0'~'9'、'-'、' ' 'P'

{

0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,

};//延时N毫秒

void DelayNms( uint N ) // 利用x、y作简单的自减运算,消耗单片机指令周期,达到延时的目的

{

uint x,y;

for( x=N; x>0; x-- )

for( y=110; y>0; y-- );

}

//数码管显示   // 显示方式为动态扫描,视觉暂留原理

void Display( uchar Num ) // p指向Main函数中的数组ShowNum的首地址

{

P0 = DataChar[ Num ]; // 向P0赋段码值

DelayNms(2); // 短暂的延时

P0 = 0x00; // 让数码管熄灭,否则会造成数字重叠

}

void main( void )

{

while(1)

{

if( Key == 0 )

{

DelayNms(30);

if( Key == 0 )

{

Count += 1;

Count = (Count>9) 0 : Count;

}

while( !Key );

}

Display( Count );

}

}

在数码管依次排列好这一句话,首先取模,然后写显示函数,写完函数放置while(1)中无限循环下去

代码如下:

#include; //用的是单独 *** 作,没有用总线

sbit led1 = P1^0;

sbit led2 = P1^1;

sbit led3 = P1^2;

sbit led4 = P1^3;

sbit led5 = P1^4;

sbit led6 = P1^5;

sbit led7 = P1^6; //看清楚自己的管脚,不一定对应,这里采用P0对应段选

code unsigned char led_paly[5] = {0x76,0x79,0x38,0x38,0x5c};// H E L L O

void delay(unsigned int um)//延时函数

{

int i,j;

for(i = 0;i &lt; um;i++)

{

for(j = 0;j &lt; 200;j++);

}

}

void display()

{

P0 = led_paly[0];//显示H

led2 = 0;

delay(50);

led2 = 1;

P0 = led_paly[1];//显示E

led3 = 0;

delay(50);

led3 = 1;

P0 = led_paly[2];//显示L

led4 = 0;

delay(50);

led4 = 1;

P0 = led_paly[3];//显示E

led5 = 0;

delay(50);

led5 = 1;

P0 = led_paly[4];//显示O

led6 = 0;

delay(50);

led6 = 1;

}

void main(void)

{

while(1)

{

display();

}

}

扩展资料:

51单片机的接口作用

P0口:可以被定义为数据/地址的低八位,能够用于外部程序/数据存储器。在FIASH编程时,P0口作为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。

P1口:标准输入输出I/O,P1口管脚写入1后,被内部上拉为高,可用作输入。在FLASH编程和校验时,P1口作为第八位地址接收。

P2口:既可用于标准输入输出I/O,也可用于外部程序存储器或数据存储器访问时的高八位地址。

P3口:既可以做标准输入输出I/O,也可作为AT89C51的一些特殊功能口。

希望以下能够给你帮助:

/ 实验目的:1掌握键盘扫描的原理以及十/十六进制的转换

2了解单片机输入和输出的过程,以及如何对数据进行采集的

实验内容:键盘上对应有16个按键,从0到F,按下相应的键会在数码管上显示相应的数字,

其中K0到K15是采用44的方式连接的

/

;

; 0 1 2 3 ---P30

; 4 5 6 7 ---P31

; 8 9 A B ---P32

; C D E F ---P33

; | | | |

; P34 P35 P36 P37

;

ORG 0000h

LJMP MAIN

ORG 0030h

MAIN:

MOV DPTR,#TAB ;将表头放入DPTR

LCALL KEY ;调用键盘扫描程序

MOVC A,@A+DPTR ;查表后将键值送入ACC

MOV P0,A ;将Acc值送入P0口

CLR P13 ;开显示

LJMP MAIN ;返回调用子程序反复循环显示

KEY: LCALL KS ;调用检测按键子程序

JNZ K1 ;有键按下继续

LCALL DELAY2 ;无键按下调用延时去抖动程序

AJMP KEY ;返回继续检测有无按键按下

K1: LCALL DELAY2

LCALL DELAY2 ;有键按下继续延时去抖动

LCALL KS ;再一次调用检测按键程序

JNZ K2 ;确认有按下进行下一步

AJMP KEY ;无键按下返回继续检测

K2: MOV R2,#0EFH ;将扫描值送入 R2暂存

MOV R4,#00H ;将第一列的列值00H送入R4暂存,R4用于存放列值。

K3: MOV P3,R2 ;将R2的值送入P3口

L6: JB P30,L1 ;P30等于1跳转到L1

MOV A,#00H ;将第一行的行值00H送入ACC

AJMP LK ;跳转到键值处理程序

L1: JB P31,L2 ;P31等于1跳转到L2

MOV A,#04H ;将第二行的行值送入ACC

AJMP LK ;跳转到键值理程序进行键值处理

L2: JB P32,L3 ;P12等于1跳转到L3

MOV A,#08H ;将第三行的行值送入ACC

AJMP LK ;跳转到键值处理程序

L3: JB P33,NEXT ;P33等于1跳转到NEXT处

MOV A,#0cH ;将第四行的行值送入ACC

LK: ADD A,R4 ;行值与列值相加后的键值送入A

PUSH ACC ;将A中的值送入堆栈暂存

K4: LCALL DELAY2 ;调用延时去抖动程序

LCALL KS ;调用按键检测程序

JNZ K4 ;按键没有松开继续返回检测

POP ACC ;将堆栈的值送入ACC

RET

NEXT:

INC R4 ;将列值加一

MOV A,R2 ;将R2的值送入A

JNB ACC7,KEY ;扫描完成跳至KEY处进行下一回合的扫描

RL A ;扫描未完成将A中的值右移一位进行下一列的扫描

MOV R2,A ;将ACC的值送入R2暂存

AJMP K3 ;跳转到K3继续

KS: MOV P3,#0FH ;将P3口高四位置0低四位值1

MOV A,P3 ;读P3口

XRL A,#0FH ;将A中的值与A中的值相异或

RET ;子程序返回

DELAY2: ;40ms延时去抖动子程序8FA2=40ms

MOV R5,#08H

L7: MOV R6,#0FAH

L8: DJNZ R6,L8

DJNZ R5,L7

RET

TAB:

DB 0C0H;0

DB 0F9H;1

DB 0A4H;2

DB 0B0H;3

DB 099H;4

DB 092H;5

DB 082H;6

DB 0F8H;7

DB 080H;8

DB 090H;9

DB 088H;A

DB 083H;b

DB 0C6H;C

DB 0A1H;d

DB 086H;E

DB 08EH;F

END赞同3| 评论(2)

下面这个程序是4x4距阵键盘,LED数码管显示,一共可以到0-F显示,你可以稍微改一下就可以实现你的功能了,如还有问题请发信息,希望能帮上你!

#include<at89x52h>

unsigned char code Dig[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e}; //数码管 0-F 代码

unsigned char k; //设置全局变量k 为键盘的键值

/键盘延时函数/

void key_delay(void) //延时函数

{

int t;

for(t=0;t<500;t++);

}

/键盘扫描函数/

void keyscan(void) //键盘扫描函数

{

unsigned char a;

P2 = 0xf0; //键盘初始化

if(P2!=0xf0) //有键按下?

{

key_delay(); //延时

if(P2!=0xf0) //确认真的有键按下?

{

P2 = 0xfe; //使行线P24为低电平,其余行为高电平

key_delay();

a = P2; //a作为缓存

switch (a) //开始执行行列扫描

{

case 0xee:k=15;break;

case 0xde:k=11;break;

case 0xbe:k=7;break;

case 0x7e:k=3;break;

default:P2 = 0xfd; //使行线P25为低电平,其余行为高电平

a = P2;

switch (a)

{

case 0xed:k=14;break;

case 0xdd:k=10;break;

case 0xbd:k=6;break;

case 0x7d:k=2;break;

default:P2 = 0xfb; //使行线P26为低电平,其余行为高电平

a = P2;

switch (a)

{

case 0xeb:k=13;break;

case 0xdb:k=9;break;

case 0xbb:k=5;break;

case 0x7b:k=1;break;

default:P2 = 0xf7; //使行线P27为低电平,其余行为高电平

a = P2;

switch (a)

{

case 0xe7:k=12;break;

case 0xd7:k=8;break;

case 0xb7:k=4;break;

case 0x77:k=0;break;

default:break;

}

}

}

break;

}

}

}

}

/ 主函数/

void main(void)

{

while(1)

{

keyscan(); //调用键盘扫描函数

switch(k) //查找按键对应的数码管显示代码

{

case 0:P0=Dig[0];break;

case 1:P0=Dig[1];break;

case 2:P0=Dig[2];break;

case 3:P0=Dig[3];break;

case 4:P0=Dig[4];break;

case 5:P0=Dig[5];break;

case 6:P0=Dig[6];break;

case 7:P0=Dig[7];break;

case 8:P0=Dig[8];break;

case 9:P0=Dig[9];break;

case 10:P0=Dig[10];break;

case 11:P0=Dig[11];break;

case 12:P0=Dig[12];break;

case 13:P0=Dig[13];break;

case 14:P0=Dig[14];break;

case 15:P0=Dig[15];break;

default:break; //退出

}

}

}

/end/

以上就是关于单片机 按键(采用独立式按键)按下一次,让液晶第一位显示的数码加1,显示范围0~9全部的内容,包括:单片机 按键(采用独立式按键)按下一次,让液晶第一位显示的数码加1,显示范围0~9、用89c51单片机写一个数码管显示HELLO的程序,是在一个七段数码管上依次出现几个字母、急求51单片机数码管显示程序等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9313884.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存