IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 嵌入式 -> 51单片机 多机通讯原理+代码 -> 正文阅读

[嵌入式]51单片机 多机通讯原理+代码

具体目的及原理

目的:使用一个51单片机作为主机通过面包板链接达到同时控制3个从机的目的。
原理:主机按下任意一个按键通过串口传输协议给所有的从机发送一个数据当做从机是否执行相应指令的开关,每个从机收到对应的指令后执行相对应的操作就行。
注意事项:
面包版的链接须在同一行内进行,因为面包版的同一行是互相连通的,若分开链接则从机不会收到信号的传输
接线时注意是会三合一杜邦线的可以主机的TX接口接到从机的RX接口,不会三合一杜邦线的可以通过面包板来达到同样的效果。

实现代码

主机发送代码:

#include<reg52.h>
sbit k1 = P3^4;
sbit k2 = P3^5;
sbit k3 = P3^6;
void delay(unsigned int xms)	//延迟函数
{
	unsigned i,j;
	for(i=xms;i>0;i--)
		for(j=112;j>0;j--);
}

void Send (unsigned char date)	//发送函数
{
		SBUF = date;
		while (!TI);
		TI = 0;
}

void main (void)
{
	TMOD = 0x20; //设置计数器工作方式2
	SCON = 0x40; //设置工作方式1
	PCON = 0x00; //SMOD=0.32分频
	TH1 = 0xfd;	 //波特率为6900
	TL1 = 0xfd; 
	TR1 = 1;	 //打开计数器
	ES = 1;		//打开接收中断
	EA = 1;		//打开总中断
	while(1)
	  {
	    if(k1==0)	//判断k1是否按下
			{
				delay(20); //延时20ms 
				if(k1==0)  //再次判断k1是否按下
				{
					SBUF=0xA1; //发送0xA1 
				}
				while(!k1);		//直到k1松开
			}
			if(k2==0)	//判断k2是否按下
			{
				delay(20);
				if(k2==0)
				{
					SBUF=0xA2;	//发送0xA2 
				}
				while(!k2);
			}
			if(k3==0)	//判断k3是否按下
			{
				delay(20);
				if(k3==0)
				{
					SBUF=0xA3; //发送0xA3
				}
				while(!k3);
			}
		}
	}

从机流水灯代码:

#include<reg52.h>
#define uint unsigned int
#define on 0
#define off 1
unsigned char date;
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;
sbit led8=P1^7;
void delay(uint xms)
{
	uint i,j;
	for(i=xms;i>0;i--)
		for(j=112;j>0;j--);
}

void ConfigUART(unsigned int baud);

void main()
{
	ConfigUART(9600);
	while(1)
	{
		while(!RI);
		RI = 0;
		date=SBUF;
if(date==0xA1)		//若为0xA1信号实现流水灯
	{
		while(1)
		{
			led1=on;
			delay(200);
			led1=off;
			
			led2=on;
			delay(200);
			led2=off;
			
			led3=on;
			delay(200);
			led3=off;
			
			led4=on;
			delay(200);
			led4=off;
			
			led5=on;
			delay(200);
			led5=off;
			
			led6=on;
			delay(200);
			led6=off;
			
			led7=on;
			delay(200);
			led7=off;
			
			led8=on;
			delay(200);
			led8=off;
		}
	}		
	}
}

void ConfigUART(unsigned int baud)	//设置接收函数 频率为9600
{
	SCON = 0x50;
	TMOD &= 0X0F;
	TMOD |= 0x20;
	TH1 = 256 - (11059200/12/32)/baud;
	TL1 = TH1;
	ET1 = 0;
	TR1 = 1;
}

从机LED流水代码:

#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char
#define duan P0
unsigned char date;
sbit wei1 =P2^4;
sbit wei2 =P2^5;
sbit wei3 =P2^6;
sbit wei4 =P2^7;
uchar code sz[13]={0x31,0x09,0x0f,0x01,0x07,0x0b,0x0d,0x0e,0x08,0x38,0x19,0x29,0x39};

void delay (unsigned int xms)
{
	unsigned int i,j;
	for (i=xms;i>0;i--)
		for (j=112;j>0;j--);
}

#include<reg52.h>
void ConfigUART(unsigned int baud);
void main()
{
	ConfigUART(9600);
	while(1)
	{
		while(!RI);
		RI = 0;
		date=SBUF;
if(date==0xA2)		//发送的信号为0xA2时执行LED流水代码
{
	int m;
	while(1)
	{
		for(m=1;m<100;m++)
		{
			duan=sz[0];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[2];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
	for(m=1;m<100;m++)
		{
			duan=sz[12];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[3];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[2];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
		for(m=1;m<100;m++)
		{
			duan=sz[12];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[3];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[2];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
		for(m=1;m<100;m++)
		{
			duan=sz[12];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[4];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
		for(m=1;m<100;m++)
		{
			duan=sz[12];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[5];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
		for(m=1;m<100;m++)
		{
			duan=sz[12];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[6];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
		for(m=1;m<100;m++)
		{
			duan=sz[12];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[7];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
		for(m=1;m<100;m++)
		{
			duan=sz[12];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[8];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[2];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
		for(m=1;m<100;m++)
		{
			duan=sz[12];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[8];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[2];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
		for(m=1;m<100;m++)
		{
			duan=sz[9];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[2];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
		for(m=1;m<100;m++)
		{
			duan=sz[10];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[2];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}	
		for(m=1;m<100;m++)
		{
			duan=sz[11];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[2];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
		for(m=1;m<100;m++)
		{
			duan=sz[0];
			wei1 =1;
			wei2 =0;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =1;
			wei3 =0;
			wei4 =0;
			delay(2);
			duan=sz[1];
			wei1 =0;
			wei2 =0;
			wei3 =1;
			wei4 =0;
			delay(2);
			duan=sz[2];
			wei1 =0;
			wei2 =0;
			wei3 =0;
			wei4 =1;
			delay(2);
		}
	}
}
}
}
void ConfigUART(unsigned int baud)
{
	SCON = 0x50;
	TMOD &= 0X0F;
	TMOD |= 0x20;
	TH1 = 256 - (11059200/12/32)/baud;
	TL1 = TH1;
	ET1 = 0;
	TR1 = 1;
}

从机蜂鸣器代码:

#include<reg52.h>
#include<intrins.h>
#define on 0
#define off 1
sbit fm = P2^3;


void delay(unsigned int xms)
{
	unsigned int i,j;
	for(i=xms;i>0;i--)
			for(j=112;j>0;j--);
}

void ConfigUART(unsigned int baud);
void main()
{
	ConfigUART(9600);
	while(1)
	{
	if(date==0xA3){			//信号为0XA3执行蜂鸣器代码
		while(1){
		P1 = 0xfe;//1111 1110
		delay(100);
		P1 = _crol_ (P1,1);
		fm = on;
		delay(100);
		fm = off;
		}
	}
	}
}
void ConfigUART(unsigned int baud)
{
	SCON = 0x50;
	TMOD &= 0X0F;
	TMOD |= 0x20;
	TH1 = 256 - (11059200/12/32)/baud;
	TL1 = TH1;
	ET1 = 0;
	TR1 = 1;
}

图片展示

请添加图片描述

  嵌入式 最新文章
基于高精度单片机开发红外测温仪方案
89C51单片机与DAC0832
基于51单片机宠物自动投料喂食器控制系统仿
《痞子衡嵌入式半月刊》 第 68 期
多思计组实验实验七 简单模型机实验
CSC7720
启明智显分享| ESP32学习笔记参考--PWM(脉冲
STM32初探
STM32 总结
【STM32】CubeMX例程四---定时器中断(附工
上一篇文章      下一篇文章      查看所有文章
加:2022-05-18 17:49:03  更:2022-05-18 17:49:26 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 0:37:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码