PC 机与单片机通信(RS232 协议)

news2024/11/18 5:41:39

PC 机与单片机通信(RS232 协议)

目录:

1、单片机串口通信的应用

2、PC控制单片机IO口输出

3、单片机控制实训指导及综合应用实例

4、单片机给计算机发送数据:

[实验任务]

单片机串口通信的应用,通过串口,我们的个人电脑和单片机系统进行通信。

个人电脑作为上位机,向下位机单片机系统发送十六进制或者ASCLL码,单片机

系统接收后,用LED显示接收到的数据和向上位机发回原样数据。

[硬件电路图]

[实验原理]

RS-232是正式公布的串行总线标准,也是目前最常用的串行接口标准,用来实现计算机与计算机之间、计算机与外设之间的数据通讯。RS-232串行接口总线适用于:设备之间的通讯距离不大于15m,传输速率最大为20kBps。RS-232协议以-5V-15V表示逻辑1;以+5V-15V 表示逻辑0。 我们是用MAX232芯片将RS232电平转换为TTL电平的。 一个完整的RS-232接口有22根线,采用标准的25芯插头座。我们在 这里使用的是简化的9芯插头座。注意我们在这里使用的晶振是11.0592M的,而不是12M。因为波特率的设置需要11.0592M的。“串口调试助手V2.1.exe” 软件的使用很简单,只要将串口选择‘CMO1’波特率设置为‘9600’ 数据位为 8 位。打开串口(如果关闭)。然后在发送区里输入要发送的数据,单击手动发送就将数据发送出去了。注意,如果选中‘十六进制发送’那么发送的数据是十六进制的,必须输入两位数据。如果没有选中,则发送的是ASCLL码,那么单片机控制的数码管将显示ASCLL码值。

数字

二进制

Px0~Px7

Abcdefg p

十六进制

0

00111111

00000011

11111100

0xco

1

00000110

10011111

01100000

0xf9

2

01011011

00100101

11011010

0xa4

3

01001111

00001101

11110010

0xb0

4

00110110

10010011

01101100

0x99

5

01101101

01001001

10110110

0x92

6

01111101

01000001

10111110

0x82

7

00000111

00011111

11100000

0xf8

8

01111111

00000001

11111110

0x80

9

01101111

00001001

11110110

0x90

A

01110111

00010001

11101110

0x88

B

01111100

11000001

00111110

0x83

C

00111001

01100011

10011100

0xc6

D

01011110

10000101

01111010

0xa1

E

01111001

01100001

10011110

0x86

F

01110001

01110001

10001110

0x8e

                              ASCII常用代码表

字符

代码

字符

代码

字符

代码

字符

代码

字符

32

52

4

72

H

92

\

112

p

33

!

53

5

73

I

93

]

113

q

34

54

6

74

J

94

^

114

r

35

#

55

7

75

K

95

_

115

s

36

$

56

8

76

L

96

`

116

t

37

%

57

9

77

M

97

a

117

u

38

&

58

:

78

N

98

b

118

v

39

59

;

79

O

99

c

119

w

40

(

60

<  

80

P

100

d

120

x

41

)

61

=

81

Q

101

e

121

y

42

*

62

>  

82

R

102

f

122

z

43

+

63

?

83

S

103

g

123

{

44

,

64

@

84

T

104

h

124

|

45

-

65

A

85

U

105

i

125

}

46

.

66

B

86

V

106

j

126

~

47

/

67

C

87

W

107

k

48

0

68

D

88

X

108

l

49

1

69

E

89

Y

109

m

50

2

70

F

90

Z

110

n

51

3

71

G

91

[

111

o

[C语言源程序]

#include "reg52.h" //包函8051 内部资源的定义

unsigned char dat; //用于存储单片机接收发送缓冲寄存器SBUF里面的内容

sbit gewei=P2^4; //个位选通定义

sbit shiwei=P2^5; //十位选通定义

sbit baiwei=P2^6; //百位选通定义

unsigned char code table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,}; //1~10

void Delay(unsigned int tc) //延时程序

{

while( tc != 0 )

{unsigned int i;

for(i=0; i<100; i++);

tc--;}

}

void LED() //LED显示接收到的数据(十进制)

{

gewei=0; P0=table[dat%10]; Delay(10); gewei=1;

shiwei=0; P0=table[dat/10]; Delay(10); shiwei=1;

baiwei=0; P0=table[dat/100]; Delay(10); baiwei=1;

}

///功能:串口初始化,波特率9600,方式1/

void Init_Com(void)

{

TMOD = 0x20;

PCON = 0x00;

SCON = 0x50;

TH1 = 0xFd;

TL1 = 0xFd;

TR1 = 1;

}

/主程序功能:实现接收数据并把接收到的数据原样发送回去///

void main()

{

Init_Com();//串口初始化

while(1)

{                     

if ( RI ) //扫描判断是否接收到数据,

{

dat = SBUF; //接收数据SBUF赋与dat

RI=0; //RI 清零。

SBUF = dat; //在原样把数据发送回去(接收数据为发送数据的ASCII码,如发送q显示为113)

}

LED(); //显示接收到的数据

}

}

///这一个例子是以扫描的方式编写的,还可以以中断的方式编写,请大家思考//

[实验任务]PC控制单片机IO口输出

#include "reg52.h" //包函8051 内部资源的定义

unsigned char dat; //用于存储单片机接收发送缓冲寄存器SBUF里面的内容

void Delay(unsigned int tc) //延时程序

{

while( tc != 0 )

{unsigned int i;

for(i=0; i<100; i++);

tc--;}

}

///功能:串口初始化,波特率9600,方式1/

void Init_Com(void)

{

TMOD = 0x20;

PCON = 0x00;

SCON = 0x50;

TH1 = 0xFd;

TL1 = 0xFd;

TR1 = 1;

}

/主程序功能:实现接收数据并把接收到的数据原样发送回去///

void main()

{

Init_Com();//串口初始化

while(1)

{                     

if ( RI ) //扫描判断是否接收到数据,

{

dat = SBUF; //接收数据SBUF赋与dat

if(dat==0x00)     //如果PC发送十六进制00,单片机P1口全亮。

P1=0x00;

else if(dat==0x01)

P1=0x01;

else if(dat==0x02)

P1=0x02;

else if(dat==0x03)

P1=0x03;

else if(dat==0x04)

P1=0x04;

RI=0; //RI 清零。

SBUF = dat; //在原样把数据发送回去(接收数据为发送数据的ASCII码,如发送q显示为113)

}

}

}

[实验任务]单片机控制实训指导及综合应用实例

#include "reg52.h" //包函AT89S52 内部资源的定义

#define uchar unsigned char                  //宏定义

uchar led [10]={0xbf,0x06,0xdb,0xcf,0x66,0xed,0xfd,0x87,0xff,0xef};    //数字1~10,字符串

uchar led1[64];   //存储接收数据

unsigned int i,j,t,k;

sbit P32=P3^2;

void scjs(void)interrupt 4 //定义中断

{

ES=0;// 使能串行口的中断

k=1;

while(1)

{

RI=0;

led1[k-1]=SBUF;       //将接收数据送段码表

k++;

TH0=0x3c; //t0定时50sm内接收不到数据跳过接收

TL0=0xb0;

TR0=1;

while(!RI)

{

if(!TF0) goto FH;

}

}

FH:TF0=0;//TF0不清零不能重新接收

   TR0=0;

   P32=1;

for(j=1;j<k;j++)

{

SBUF=led[j-1];//数据送回给pc

while(!TI);

TI=0;

}

P32=0;

}

delay(t)

{

ES=1;

SCON=0x50;

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

ES=0;

SCON=0x00;

}

void main (void)

{

int a,c;

TMOD=0x21;

TH1=0Xfd;

TL1=0xfd;

SCON=0x50;

PCON=0x00;

IE=0x90;

TR1=1;

k=1;

P32=0;

while(1)

{

ES=0;

SCON=0x00;

for(a=0;a<=k+1/k*8;a++)

{

for(c=5;c>=0;c--)

{

if(a+c<k+1/k*8+1)

{

if(k==1)SBUF=led[a+c];

else SBUF=led1[a+c];

}

else SBUF=0x00;

while(!TI);

TI=0;

}

delay(39000);

}

}

}
#include "reg52.h" //包函8051 内部资源的定义

#define uchar unsigned char

sbit P3_2=P3^2;

uchar zdzt=0x0c;

uchar zsgw=0x02;

uchar zsdw=0x00;

uchar bs=0;

uchar zqsbw=0;

uchar zqssw=0;

uchar zqsgw=0;

uchar yxsj=0x11;

uchar zs=20;

int zqs=0;

uchar zqsgzj=0x00;

uchar zqsdzj=0x00;

uchar zsscgw=0x1f;

uchar zsscdw=0x00;

uchar bzsj;

uchar ztsj;

void key (void);

void keyprc();

void binbcd();

void disp();

void delay();

code uchar tab[13]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x7f,0x6f,0x77,0x7c,0x39};

code uchar zssc[160]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x7f,0x6f,0x77,0x7c,

0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x7f,0x6f,0x77,0x7c,0x3f,0x06,0x5b,0x4f,

0x66,0x6d,0x7d,0x7f,0x6f,0x77,0x7c,0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x7f,

0x6f,0x77,0x7c,0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x7f,0x6f,0x77,0x7c,0x3f,

0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x7f,0x6f,0x77,0x7c,0x3f,0x06,0x5b,0x4f,0x66,

0x6d,0x7d,0x7f,0x6f,0x77,0x7c,0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x7f,0x6f,

0x77,0x7c,0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x7f,0x6f,0x77,0x7c,0x3f,0x06,

0x5b,0x4f,0x66,0x6d,0x7d,0x7f,0x6f,0x77,0x7c,};

void key(void)

{

TR0=0;

if(!(P2&0X01))

{

delay();

while(!(P2&0X01));

zdzt=0x0a;

disp();

}

else if(!(P3&0X08))

{

delay();

while(!(P3&0X08));

zdzt=0x0b;

disp();

}

else if(!(P3&0X10))

{

delay();

while(!(P3&0X10));

zs=zs+1;

keyprc();

disp();

}

else if(!(P2&0X02))

{

delay();

while(!(P2&0X02));

zs=zs-1;

keyprc();

disp();

}

}

void keyprc()

{

if(zs<20)

zs=20;

if(zs>99)

zs=99;

zsgw=zs/10;

zsdw=zs%10;

}

void djzd(void) interrupt 1

{

TH0=zssc[(zs-20)*2];

TL0=zssc[(zs-20)*2+1];

if(zdzt==0x0a)

yxsj=yxsj<<1|yxsj>>7;

else if (zdzt==0x0b)

yxsj=yxsj<<7|yxsj>>1;

else if(zdzt==0x0c)

{

P1=0xff;

goto LP;

}

P1=yxsj;

bs++;

if(bs==48)

{

bs=0;

zqs++;

}

LP:binbcd();

disp();

}

void binbcd()

{

zqsbw=zqs/100;

zqssw=zqs%100/10;

zqsgw=zqs%10;

}

void disp()

{

TR1=0;

ES=0;

SCON=0x00;

TMOD=0x01;

SBUF=tab[zqsgw];

while(!TI);TI=0;

SBUF=tab[zqssw];

while(!TI);TI=0;

SBUF=tab[zqsbw];

while(!TI);TI=0;

SBUF=tab[zsdw];

while(!TI);TI=0;

SBUF=tab[zsgw];

while(!TI);TI=0;

SBUF=tab[zdzt];

while(!TI);TI=0;

TMOD=0x02;

TH1=0Xfd;

TL1=0xfd;

SCON=0x50;

TR1=1;

ES=1;

}

void delay()

{

int k;

for(k=0;k<1200;k++);

}

void sin()interrupt 4

{

P1=0xff;

ES=0;

bzsj=SBUF;

RI=0;

while(!RI);

RI=0;

ztsj=SBUF;

if(bzsj==0x30)

zdzt=ztsj-0x37;

if(bzsj==0x31)

{

if(ztsj==0x49)

zs++;

else zs--;

}

ES=1;

P3_2=0;

keyprc();

zqs=0;

disp();

}

main()

{

TMOD=0x21;

TH1=0xfd;

TL1=0xfd;

SCON=0x50;

PCON=0x00;

IE=0X92;

PS=1;

TR1=1;

P3_2=0;

TH0=0x1f;

TL0=0x00;

SP=0x60;

disp();

while(1)

{

key();

if(zdzt==0x0c)

{

TR0=0;

P1=0xff;

}

else TR0=1;

}

}

单片机给计算机发送数据

#include "reg52.h" //包函8051 内部资源的定义

unsigned char dat; //用于存储单片机接收发送缓冲寄存器SBUF里面的内容

unsigned char fan;

int i,j;

void Delay() //延时程序

{

for(i=0; i<100; i++)

for(j=0; j<100; j++);

}

void delays()

{

int k;

for (k=0;k<1200;k++);

}

///功能:串口初始化,波特率9600,方式1/

void Init_Com(void)

{

TMOD = 0x20;

PCON = 0x00;

SCON = 0x50;

TH1 = 0xFd;

TL1 = 0xFd;

TR1 = 1;

}

/主程序功能:实现接收数据并把接收到的数据原样发送回去///

void main()

{

Init_Com();//串口初始化

while(1)

{

                

if ( RI ) //扫描判断是否接收到数据,

{

dat = SBUF; //接收数据SBUF赋与dat

if(dat==0x30)     //如果PC发送十六进制00,单片机P1口全亮。

{P1=0x00;

Delay();   }

else if(dat==0x31)

{P1=0x01;

Delay();}

else if(dat==0x32)

{P1=0x03;

Delay();}

else if(dat==0x33)

{P1=0x07;

Delay(); }

else if(dat==0x34)

{P1=0x0f;

Delay(); }

else if(dat==0x35)

{P1=0x1f;

Delay();}

else if(dat==0x06)

{P1=0x3f;

Delay(); }

else if(dat==0x07)

{P1=0x7f;

Delay();}

else if(dat==0x08)

{P1=0xff;

Delay(); }

else if(!(P2&0x01))

{ delays();

while(!(P2&0x01));

fan = 0x36;}

else if(!(P2&0x02))

{ delays();

while(!(P2&0x02));

fan = 0x37;}

else if(!(P2&0x04))

{ delays();

while(!(P2&0x04));

fan = 0x38;}

else if(!(P2&0x08))

{ delays();

RI=0; //RI 清零。

SBUF =dat; //在原样把数据发送回去(接收数据为发送数据的ASCII码,如发送q显示为113)

}

}

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1302995.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

智能优化算法应用:基于阴阳对算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于阴阳对算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于阴阳对算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.阴阳对算法4.实验参数设定5.算法结果6.参考文…

搜集怎么绘制三维曲线和曲面?

1、针对函数对象是单一变量、两个函数的情况。用plot3函数&#xff1b;&#xff08;三维曲线&#xff09; 看一下matlab官方的例子&#xff1a; t 0:pi/50:10*pi; st sin(t); ct cos(t); plot3(st,ct,t) 绘制出来的曲线&#xff1a; 几个比较关键的点&#xff1a; &…

手把手教你玩转ESP8266(原理+驱动)

在嵌入式开发中&#xff0c;无线通信的方式有很多&#xff0c;其中 WIFI 是绕不开的话题。说到 WIFI 通信&#xff0c;就不得不提 ESP8266了。 ESP8266 是一款高性能的 WIFI 串口模块&#xff0c;实现透明传输。只要有一定的串口知识&#xff0c;不需要知道 WIFI 原理就可以上…

数据结构:第13关:查找两个单词链表共同后缀的起始结点

任务描述编程要求 输入输出测试说明来源 任务描述 本关任务&#xff1a;假定采用带头结点的单链表保存单词&#xff0c;当两个单词有相同的后缀时&#xff0c;则可共享相同的后缀空间。 例如&#xff0c;“loading”和“being”的存储映像如下图所示&#xff1a; 设str1和str2…

论文阅读《Domain Generalized Stereo Matching via Hierarchical Visual Transformation》

论文地址&#xff1a;https://openaccess.thecvf.com/content/CVPR2023/html/Chang_Domain_Generalized_Stereo_Matching_via_Hierarchical_Visual_Transformation_CVPR_2023_paper.html 概述 立体匹配模型是近年来的研究热点。但是&#xff0c;现有的方法过分依赖特定数据集上…

使用 PyTorch FSDP 微调 Llama 2 70B

通过本文&#xff0c;你将了解如何使用 PyTorch FSDP 及相关最佳实践微调 Llama 2 70B。在此过程中&#xff0c;我们主要会用到 Hugging Face Transformers、Accelerate 和 TRL 库。我们还将展示如何在 SLURM 中使用 Accelerate。 完全分片数据并行 (Fully Sharded Data Paral…

游戏中小地图的制作__unity基础开发教程

小地图的制作 Icon标识制作制作摄像机映射创建地图UI效果“不一样的效果” 在游戏中经常可以看到地图视角的存在&#xff0c;那么地图视角是如何让实现的呢&#xff1f; 这一期教大家制作一个简易的小地图。 &#x1f496;点关注&#xff0c;不迷路。 老样子&#xff0c;我们还…

使用MfgTool烧写前需准备的文件

一. 简介 本文我们就来学习&#xff0c;如何将我们编译的 uboot&#xff0c;zImage&#xff08;内核镜像&#xff09;&#xff0c;xxx.dtb设备树文件&#xff0c;还有制作的根文件系统&#xff0c;这四个文件烧写到开发板中&#xff0c;最后 开发板能正常启动。 本文这里使用…

Linux实用操作篇-下篇

Linux实用操作篇-上篇&#xff1a;Linux实用操作-上篇-CSDN博客 一、网络传输 1.1 ping命令 网络是否可联通 可以通过ping命令&#xff0c;检查指定的网络服务器是否是可联通状态 语法: ping [-c num] ip或主机名 选项&#xff1a;-c&#xff0c;检查的次数&#xff0c;…

# 一些视觉-激光、加速度传感器类的铣削振动测试方法案例

一些视觉-激光类的铣削振动测试方法 1. 基于激光测振仪的振动测试2. 切削加工的 加速度传感器实测信号2.1 x轴向信号2.2 Y轴向信号2.3 第二次廊坊实验3. 关于数值频域积分1. 基于激光测振仪的振动测试 【1】舜宇LDV|激光测振—机床铣刀寿命预测 新刀具为100hz主频 旧刀具为800…

多源异构数据融合是什么,在进行故障预测、诊断、辨识的时候有什么有优点和缺点!

文章目录 1、多源异构数据融合是什么2、多源异构数据融合的优点主要包括&#xff1a;3、多源异构数据融合进行故障辨识的缺点 1、多源异构数据融合是什么 多源异构数据融合是将来自于不同设备、传感器、系统或网络等多个数据源的数据进行整合并综合分析处理的一种技术。这种数…

AcWing 95. 费解的开关(递推)

题目链接 活动 - AcWing 本活动组织刷《算法竞赛进阶指南》&#xff0c;系统学习各种编程算法。主要面向有一定编程基础的同学。https://www.acwing.com/problem/content/97/ 题解 只要第一行开关的状态确定&#xff0c;则所有开关的状态都可以被推出来。第一行开关总共有种操…

了解 git rebase

了解 git rebase 大多数人习惯使用 git merge 将更改从功能分支合并到主分支&#xff0c;但还有其他方法。我们是否曾经遇到过 git rebase 这个术语并想知道它是什么&#xff1f;或者我们可能听说过 rebase 和 merge &#xff0c;但不确定何时使用哪个&#xff1f;不用担心&am…

Axure的安装及基本功能介绍

目录 一. Axure概述 二. Axure安装 2.1 安装包下载 2.2 安装步骤 三. Axure功能介绍​ 3.1 工具栏介绍 3.1.1 复制&#xff0c;剪切及粘贴 3.1.2 选择模式和连接 3.1.3 插入形状 3.1.4 点&#xff08;编辑控点&#xff09; 3.1.5 置顶和置底 3.1.6 组合和取消组合 …

论文笔记:A review on multi-label learning

一、介绍 传统的监督学习是单标签学习&#xff0c;但是现实中一个实例可能对应多个标签。这篇文章介绍了多标签分类的定义和评价指标、多标签学习的算法还有其他相关的任务。 二、问题相关定义 2.1 多标签学习任务 假设 X R d X R^d XRd&#xff0c;表示d维的输入空间&am…

LabVIEW开发矿井排水监控系统

LabVIEW开发矿井排水监控系统 针对矿井水害对煤矿安全生产构成的威胁&#xff0c;设计了一种基于嵌入式PLC和LabVIEW的矿井排水监控系统。该系统结合了PLC的可靠控制与单片机的应用灵活性&#xff0c;有效克服了传统排水方法中的不足&#xff0c;如测量不准确、效率低下等问题…

Panalog 日志审计系统 sprog_deletevent.php SQL 注入漏洞复现

0x01 产品简介 Panalog大数据日志审计系统定位于将大数据产品应用于高校、 公安、 政企、 医疗、 金融、 能源等行业之中&#xff0c;针对网络流量的信息进行日志留存&#xff0c;可对用户上网行为进行审计&#xff0c;逐渐形成大数据采集、 大数据分析、 大数据整合的工作模式…

PairLIE论文阅读笔记

PairLIE论文阅读笔记 论文为2023CVPR的Learning a Simple Low-light Image Enhancer from Paired Low-light Instances.论文链接如下&#xff1a; openaccess.thecvf.com/content/CVPR2023/papers/Fu_Learning_a_Simple_Low-Light_Image_Enhancer_From_Paired_Low-Light_Instan…

IO函数及应用

1.实现登录功能。自定义- -个usr.txt,手动输入账户密码&#xff0c;格式如下:账户密码 例如: zhangsan 12345 lisi abcde wangwu abc123 需求如下: a.从终端获取账户密码&#xff0c;与文件中的账户密码比较 b.若终端输入的账户不存在&#xff0c;则输出账户不存在 c.若终端输入…

【文心一言】使用飞桨 AI Studio 快速搭建,看图识猜成语应用

目录 一、背景二、实践三、创建应用3.1、零代码开发3.2、应用名称3.2、模型训练3.3、开始训练 四、应用部署4.1、发布项目4.2、搜索应用4.3、应用部署4.4、获取令牌4.4、导入依赖4.5、配置CORS4.6、使用测试API4.7、运行4.8、测试API接口4.9、前端API接口 五、启动前端5.1、模块…