双机通信综合实验(c51代码)

双机通信综合实验(c51代码)

原创代码,供参考

编程控制单片机实现复杂功能的双机通信。具体要求为:

(1)甲机可将4*4的矩阵上对应的按键值通过串行口发送给乙机

(2)甲机保留最近传送给甲机的八个键值,在自己的八位一体LED数码管上一位一位地进行显示(数码管的动态显示方式)。

(3)乙机接收到甲机发送的字符后,将其显示在自己的八位一体数码管上(数码管的静态显示方式)

(4)乙机接收到甲机发送的字符后,需反馈给甲机截止至目前已收到的字符个数(约定小于256)。甲机在收到反馈的字符个数后,将其值通过八个发光二极管上显示出来(显示其二进制值)。

发送方代码

//PA	段码
//PB	位码
//PC 	led灯
//P1	键盘
#include<reg51.h>
#include<intrins.h>
#include<absacc.h>
unsigned char code key_code[17]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00};
unsigned char b[8]={0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00};
unsigned char code wei_code[8]={0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe};
sbit H1=P1^0;
sbit H2=P1^1;
sbit H3=P1^2;
sbit H4=P1^3;

#define pa XBYTE [0x8000]
#define pb XBYTE [0x8001]
#define pc XBYTE [0x8002]
#define con_8255 XBYTE [0x8003]

unsigned char num=16;
unsigned char flag=0;
void delay(unsigned int time)//延时
{
    unsigned int i=0;
	for(;time>0;time--)
	    for(;i<125;i++);
}
void Getkey()//得到键值
{
	unsigned char i=0;
	unsigned char x=0xef;
	P1=0x0f;
	flag=0;
	if(P1!=0x0f)
	{
		flag=1;
		delay(10);
		for(i=0;i<4;i++)
		{
			P1=x;
			if(H1==0){num=0+i;while(H1==0); delay(10);while(H1==0);}
			if(H2==0){num=4+i;while(H2==0); delay(10);while(H2==0);}
			if(H3==0){num=8+i;while(H3==0); delay(10);while(H3==0);}
			if(H4==0){num=12+i;while(H4==0); delay(10);while(H4==0);}
			x=_crol_(x,1);
		}
		for(i=7;i>0;i--)
		{
			b[i]=b[i-1];
		}
		b[0]=key_code[num];	
	}

}
void display()//显示
{
	unsigned char j=0;
	while(j<8)
	{
		pb=wei_code[j];
		pa=b[j];
		delay(5);
		j++;
	}
}
void main()
{
	con_8255=0x80;//控制方式
	SCON=0x50;
	TMOD=0x20;
	TH1=TL1=0xf4;
	TR1=1;
	while(1)
	{
		Getkey();
		display();
		if(flag==1)
		{
			SBUF=num;
			while(TI==0);
			TI=0;
		}
		while(RI)
		{
			pc=SBUF;
			RI=0;
		}		
	}
	
}

接收方代码

//P1段码
//P2位码
#include <reg51.h>
#include <intrins.h>
unsigned char code key_code[17]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00};

void delay(unsigned int time)//延时
{
    unsigned int i=0;
	for(;time>0;time--)
	    for(;i<125;i++);
}
void main()
{
	unsigned char i,num=0;
	SCON=0x50;
	TMOD=0x20;
	TH1=TL1=0xf4;
	TR1=1;
	while(1)
	{
		while(RI)
		{
			RI=0;
			i=SBUF;
			num++;
		}
		SBUF=num;
		while(TI==0);
		TI=0;
		P1=key_code[i];
		P2=0x00;
	}		
}
  • 3
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值