C51-- 蓝牙,WIFI模块

HC-08蓝牙模块: 

蓝牙 -- 最好用的 串口透传 模块


透传 -- 透明传送,指的是在数据传输的过程中,通过无线的方式这组数据不发生任何形式的改变,
仿佛传输过程是透明的,同时保证传输质量,最终原封不动的传送到接收者手里

只要通过串口编程 获得数据即可

波特率: 9600 MHZ

// 学会串口 就能使用蓝牙模块 
 -- 就能通过蓝牙 模块进行交互-- 比如通过蓝牙在串口上发送指令让单片机执行
================================================

通过USB转TTL 来插入电脑,就可以实现手机和电脑的串口数据传输

AT命令修改蓝牙名称: 
AT + NAME = 新的名字


 

wifi模块:

基本概念

通过wifi模块 让 51单片机上网:

使用的wifi模块 -- ESP-8266  -- 高度基础的wifi MCU -- 支持RTOS(实时系统) 和 wifi协议栈
基于AT指令设计:

AT指令 --是从终端设备 or 数据终端设备 or 数据电路终端设备发送的

每条AT命令行,只能包含一条AT指令,对于由终端设备主动向PC段报告的URC or response响应,也要求一行最多有一个,
不允许上限的一行有多条指令 or 响应 
-- AT指令以回车作为结尾, 响应 or 上报 以回车 换行作为结尾
===================================
 ESP-8266   -- 一般 默认波特率 -- 115200
因为都是AT指令去驱动,so玩wifi模块都是 通过 串口调试助手
接下来玩以下 AT指令:

通过命令 配置 9600 的波特率:

AT + UART =9600,8,1,0,0
//8 个 数据位 , 1 个停止位
=======================

常用AT指令:


1.设置3种工作模式: 


AT+CWMODE=3
//1.是station(设备模式)  2.AP(路由模式) 3.双模


2. 以设备模式接入家中的路由器配置:


AT+CWJAP="CU_a2ry","c5m66yaa" 
 // 第一个“”填wifi名字,第二个“”填 wifi密码

//连接成功 弹出:
WIFI CONNECTED
WIFI GOT IP

==================


3.查询IP地址:


AT+CIFSR

+CIFSR:APIP,"192.168.4.1"
+CIFSR:APMAC,"ce:50:e3:77:dd:4e"
+CIFSR:STAIP,"192.168.1.17"
+CIFSR:STAMAC,"cc:50:e3:77:dd:4e"
=============================

4.接收发送数据


1.先通过网络调试助手创建服务器


2.在通过AT指令连接服务器:
 AT+CIPSTART="TCP","192.168.1.9",8880
//连接成功:
CONNECT

OK

3. 发送数据:
AT+CIPSEND=4 //设置即将发送数据的长度--4个字节

发出上面AT指令后出现 > 
就可以在发送框里面传输 后面传输(注意不能添加新行)

---------------------------------------
这种模式效率太低:  每次都 AT+CIPSEND=4 

5.透传:


我们就可以设置为透传:

1. AT+CIPMODE=1 //开启透传模式
2. AT+CIPSEND    //带回车 -- 开始发送接收数据
3. 随便怎么 发送,接收
4.退出透传模式 发送 +++ 不带换新行

程序:

========================================


代码实现 51 和wifi模块的连接


code 关键字 -- 单独空间存储数据

#include"reg52.h"
#include<string.h>

#define SIZE 12

sfr AUXR = 0x8E;
sbit D5 = P3^7;

char cmd[SIZE];
code char LJWL[]="AT+CWJAP=\"CU_a2ry\",\"c5m66yaa\"\r\n";  //通过\r\n输出新行 -- 连接网络
code char LJFWQ[] ="AT+CIPSTART=\"TCP\",\"192.168.1.9\",8880\r\n"; // 链接服务器
char TCMS[]="AT+CIPMODE=1\r\n"; //开启透传模式
char SJCS[]="AT+CIPSEND\r\n"; //数据接收

void Delay1000ms()        //@11.0592MHz
{
    unsigned char i, j, k;

    
    i = 43;
    j = 6;
    k = 203;
    do
    {
        do
        {
            while (--k);
        } while (--j);
    } while (--i);
}

void UartInit(void)        //9600bps@11.0592MHz
{
    AUXR=0x01; //减少定时器辐射 -- 抗干扰
    SCON =0x50; //配置 串口口工作方式1,REN 使能接收
    //不配 PCON  -- 不设置倍数关系
    //配置定时器1为 8位自动重装
    TMOD &=0xF0; //高位清零
  TMOD |=0x20;  //00 10  -- 配置为定时器1为: 1 0 模式 -- 8位自动重装
  
    //定义初值
  TL1=0xFD;
    TH1=0xFD; // 9600 波特率的初值
  TR1= 1; // 定时器 -- 启动
    
    EA =1; // 开启总中断
    ES=1;  // 开启串口中断
    
}


void sendByte(char a)
{
SBUF = a;
while(!TI);
TI=0;    
}


void sendString(char *str)
{

 while(*str!='\0')
 {
 sendByte(*str);
 str++;
 } 

}


void main()
{
    
    D5=1;

    //配置C51串口的 通信方式:
    UartInit();
while(1){
   //Delay1000ms();
  //往发送缓冲区 写入数据-- 就完成数据的发送
  //sendString("mengxianggiegie\r\n");
    
    sendString(LJWL); // 链接网络 Delay1000ms();
    Delay1000ms();
    Delay1000ms();
    Delay1000ms();
     Delay1000ms();
  sendString(LJFWQ); //连接服务器
     Delay1000ms();
    Delay1000ms();
    Delay1000ms();
    Delay1000ms();
     Delay1000ms();
    sendString(TCMS); //开启透传
     Delay1000ms();
    Delay1000ms();
    Delay1000ms();
    Delay1000ms();
     Delay1000ms();
    sendString(SJCS); //接收数据
     Delay1000ms();
    Delay1000ms();
    Delay1000ms();
    Delay1000ms();
     Delay1000ms();
 }
}

void uartHandler() interrupt 4
{
    static i = 0;
 if(RI) // 中断处理函数中,对于接收中断的响应
 {
    RI=0; //清楚接收中断标志位
      cmd[i] = SBUF;
      i++;
      if(i==SIZE) 
            i=0;
     
    if(strstr(cmd,"en")){//收到 o-pen 开灯
     D5=0;
         i=0;    
         memset(cmd,'\0',SIZE);
    }
        else if(strstr(cmd,"se")){//收到c-lose 关灯
     D5=1;
         i=0;    
         memset(cmd,'\0',SIZE);
    }
            


 }
  
    
}

=============================


优化 上面代码 通过TCP 通信点灯: 

#include"reg52.h"
#include<string.h>

#define SIZE 12

sfr AUXR = 0x8E;
sbit D5 = P3^7;

char cmd[SIZE];
code char LJWL[]="AT+CWJAP=\"CU_a2ry\",\"c5m66yaa\"\r\n";  //通过\r\n输出新行 -- 连接网络
code char LJFWQ[] ="AT+CIPSTART=\"TCP\",\"192.168.1.9\",8880\r\n"; // 链接服务器
char TCMS[]="AT+CIPMODE=1\r\n"; //开启透传模式
char SJCS[]="AT+CIPSEND\r\n"; //数据接收

void Delay1000ms()        //@11.0592MHz
{
    unsigned char i, j, k;

    
    i = 43;
    j = 6;
    k = 203;
    do
    {
        do
        {
            while (--k);
        } while (--j);
    } while (--i);
}

void UartInit(void)        //9600bps@11.0592MHz
{
    AUXR=0x01; //减少定时器辐射 -- 抗干扰
    SCON =0x50; //配置 串口口工作方式1,REN 使能接收
    //不配 PCON  -- 不设置倍数关系
    //配置定时器1为 8位自动重装
    TMOD &=0xF0; //高位清零
  TMOD |=0x20;  //00 10  -- 配置为定时器1为: 1 0 模式 -- 8位自动重装
  
    //定义初值
  TL1=0xFD;
    TH1=0xFD; // 9600 波特率的初值
  TR1= 1; // 定时器 -- 启动
    
    EA =1; // 开启总中断
    ES=1;  // 开启串口中断
    
}


void sendByte(char a)
{
SBUF = a;
while(!TI);
TI=0;    
}


void sendString(char *str)
{

 while(*str!='\0')
 {
 sendByte(*str);
 str++;
 } 

}


void main()
{
    int mark = 0;
    D5=1;

    //配置C51串口的 通信方式:
    UartInit();
while(1){
   //Delay1000ms();
  //往发送缓冲区 写入数据-- 就完成数据的发送
  //sendString("mengxianggiegie\r\n");
    if(!mark){ //第一次打开链接服务器 和网络
    sendString(LJWL); // 链接网络 Delay1000ms();
    Delay1000ms();
    Delay1000ms();
    Delay1000ms();

  sendString(LJFWQ); //连接服务器
     Delay1000ms();
     Delay1000ms();
     Delay1000ms();
        
    sendString(TCMS); //开启透传
     Delay1000ms();
     Delay1000ms();
     Delay1000ms();
        
    sendString(SJCS); //接收数据
     Delay1000ms();
     Delay1000ms();    
     Delay1000ms();
        
     mark=1;
  }
    else{
   sendString("mengxianggiegie\r\n");
     Delay1000ms();
  }
 }
}

void uartHandler() interrupt 4
{
    static i = 0;
 if(RI) // 中断处理函数中,对于接收中断的响应
 {
    RI=0; //清楚接收中断标志位
      cmd[0] = SBUF;
     

     
    if(cmd[0] == '1'){//收到 o-pen 开灯
     D5=0;
         i=0;    
        
    }
        else if(cmd[0] == '0' ){//收到c-lose 关灯
     D5=1;
         i=0;    
        
    }
            


 }
  
    
}

========================


上方代码优化 -- 读取返回 结果以便 观察进度


#include"reg52.h"
#include<string.h>

#define SIZE 12

sfr AUXR = 0x8E;
sbit D5 = P3^7;
sbit D6 = P3^6;

char buffer[SIZE];
code char LJWL[]="AT+CWJAP=\"CU_a2ry\",\"c5m66yaa\"\r\n";  //通过\r\n输出新行 -- 连接网络
code char LJFWQ[] ="AT+CIPSTART=\"TCP\",\"192.168.1.9\",8880\r\n"; // 链接服务器
char TCMS[]="AT+CIPMODE=1\r\n"; //开启透传模式
char SJCS[]="AT+CIPSEND\r\n"; //数据接收


char AT_OK_Flag = 0; 
char AT_Connect_Net_Flag = 0;


void Delay1000ms()        //@11.0592MHz
{
    unsigned char i, j, k;

    
    i = 43;
    j = 6;
    k = 203;
    do
    {
        do
        {
            while (--k);
        } while (--j);
    } while (--i);
}

void UartInit(void)        //9600bps@11.0592MHz
{
    AUXR=0x01; //减少定时器辐射 -- 抗干扰
    SCON =0x50; //配置 串口口工作方式1,REN 使能接收
    //不配 PCON  -- 不设置倍数关系
    //配置定时器1为 8位自动重装
    TMOD &=0xF0; //高位清零
  TMOD |=0x20;  //00 10  -- 配置为定时器1为: 1 0 模式 -- 8位自动重装
  
    //定义初值
  TL1=0xFD;
    TH1=0xFD; // 9600 波特率的初值
  TR1= 1; // 定时器 -- 启动
    
    EA =1; // 开启总中断
    ES=1;  // 开启串口中断
    
}


void sendByte(char a)
{
SBUF = a;
while(!TI);
TI=0;    
}


void sendString(char *str)
{

 while(*str!='\0')
 {
 sendByte(*str);
 str++;
 } 

}


void main()
{
    int mark = 0;
    D5=1; //状态灯一开始是熄灭状态

    //配置C51串口的 通信方式:
     UartInit();
     Delay1000ms(); //给esp wifi 模块上电时间
    
    sendString(LJWL); // 链接网络 Delay1000ms();
  while(!AT_Connect_Net_Flag); // 等到有效才去执行下面的代码
    while(!AT_OK_Flag);
    AT_OK_Flag=0;
    
  sendString(LJFWQ); //连接服务器
    while(!AT_OK_Flag);
    AT_OK_Flag=0;  //用完清零, 方便下次做判断
    
    sendString(TCMS); //开启透传
    while(!AT_OK_Flag);
    AT_OK_Flag=0;
    
    sendString(SJCS); //接收数据
    while(!AT_OK_Flag);
    
    if(AT_Connect_Net_Flag){
    D5=0; // 通过灯判断是否联网成功  -- 点亮表示成功
   }
     if(AT_OK_Flag){
   D6=0; //代表连接服务器,并且打开 透传 成功 
  }
    
while(1){
   Delay1000ms();
  //往发送缓冲区 写入数据-- 就完成数据的发送
  //sendString("mengxianggiegie\r\n");
   sendString("mengxianggiegie\r\n");
  
 }
}

void uartHandler() interrupt 4
{
    static i = 0;
    char tmp;
    
 if(RI) // 中断处理函数中,对于接收中断的响应
 {
    RI=0; //清楚接收中断标志位
     
      tmp = SBUF;
      if(tmp == 'W' || tmp == 'O'|| tmp == 'L' ){ //匹配到W开头的时候,把下标定义为0,方便后面的[0] [5]的位置比较
     i=0;
    }
      buffer[i++]=tmp;
        
      if(buffer[0]=='W' && buffer[5]=='G'){//联网成功 WIFI GOT 
     AT_Connect_Net_Flag=1; //标志修改为联网状态
         memset(buffer,'\0',SIZE);
    }

        if(buffer[0]=='O' && buffer[1]=='K'){//联网成功 WIFI GOT 
     AT_OK_Flag=1;
         memset(buffer,'\0',SIZE);
    }
        /*
          if(buffer[0]=='F' && buffer[1]=='A'){//联网失败 FAIL 
     for(i=0;i<3;++i){
     D5=0;
         Delay1000ms();
         D5=1;
         Delay1000ms();
    }        
         sendString(LJWL);
         memset(buffer,'\0',SIZE);
    }
        */
        
    if(buffer[0] == 'L'&& buffer[2] == '1'){//收到 o-pen 开灯
     D5=0;
         memset(buffer,'\0',SIZE);
    }
        else if(buffer[0] == 'L'&& buffer[2] == '0'){//收到c-lose 关灯
     D5=1;
         memset(buffer,'\0',SIZE);
        
    }
        if(i==12)
            i=0;


 }
  
    
}

注释部分为进一步优化,没能连接成功就 AT+RET -- 重启 or 重新连接
==============================

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

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

相关文章

css酷炫边框

边框一 .leftClass {background: #000;/* -webkit-animation: twinkling 1s infinite ease-in-out; 1秒钟的开始结束都慢的无限次动画 */ } .leftClass::before {content: "";width: 104%;height: 102%;border-radius: 8px;background-image: linear-gradient(var(…

正则表达式引擎库汇合

1.总览表格 一些正则表达式库的对比 index库名编程语言说明代码示例编译指令1Posix正则C语言是C标准库中用于编译POSIX风格的正则表达式库 posix-re.cgcc posix-re.c 2PCRE库C语言提供类似Perl语言的一个正则表达式引擎库。 一般系统上对应/usr/lib64/libpcre.so这个库文件&am…

柔性数组详细讲解

动态内存函数的使用和综合实践-malloc&#xff0c;free&#xff0c;realloc&#xff0c;calloc-CSDN博客https://blog.csdn.net/Jason_from_China/article/details/137075045 柔性数组存在的意义 柔性数组在编程语言中指的是可以动态调整大小的数组。相比固定大小的数组&#…

Redis中惰性策略的启发和流量包应用设计

引言 在技术领域&#xff0c;许多中间件之所以获得巨大成功&#xff0c;部分原因在于它们所采用的思想之先进。这些思想解决了一个个世纪难题&#xff0c;接下来我将讲述一个我学习到的思想&#xff0c;并将其应用至工作中的案例。 惰性策略在日常编码中随处可见&#xff0c;但…

STL容器的一些操作(常用的,不全)

目录 string 1.string的一些创建 2.string 的读入和输出&#xff1a; 3.string的一些操作 4.彻底清空string 容器的函数 vector 1.vector的一些创建&#xff1a; 2.vector的一些操作&#xff1a; 3.vector的彻底清空并释放内存&#xff1a; queue 循环队列&#xff1…

兑换码生成算法

兑换码生成算法 兑换码生成算法1.兑换码的需求2.算法分析2.重兑校验算法3.防刷校验算法 3.算法实现 兑换码生成算法 兑换码生成通常涉及在特定场景下为用户提供特定产品或服务的权益或礼品&#xff0c;典型的应用场景包括优惠券、礼品卡、会员权益等。 1.兑换码的需求 要求如…

【DevOps工具篇】安装 LDAP 管理 GUI PhpLdapAdmin

【DevOps工具篇】安装 LDAP 管理 GUI PhpLdapAdmin 目录 【DevOps工具篇】安装 LDAP 管理 GUI PhpLdapAdmin启用远程管理功能安装 phpLDAPadmin对 phpLDAPadmin 进行补丁Apache 的配置编辑配置文件推荐超级课程: Docker快速入门到精通Kubernetes入门到大师通关课AWS云服务快速…

Pointnet++分类和分割数据集准备和实验复现

5.分类数据集Modelnet40及可视化 Modelnet40分类数据集 原始的modelnet40是off文件&#xff0c;是cad模型 OFF文件是一种用于存储三维对象信息的文件格式&#xff0c;全称为"Object File Format"。它主要用于存储几何体的顶点、边和面信息&#xff0c;以及可能的颜…

面对复杂多变的网络攻击,企业应如何守护网络安全

企业上云&#xff0c;即越来越多的企业把业务和数据&#xff0c;迁移到云端。随着云计算、大数据、物联网、人工智能等技术的发展&#xff0c;用户、应用程序和数据无处不在&#xff0c;企业之间的业务边界逐渐被打破&#xff0c;网络攻击愈演愈烈&#xff0c;手段更为多。 当前…

未来的发展趋势-无服务架构-即将到来-让我们欢呼吧

无服务架构&#xff08;Serverless Architecture&#xff09;是一种颠覆性的云计算架构范式&#xff0c;旨在简化应用程序开发和部署过程&#xff0c;提高开发效率和降低成本。在传统的基础设施即服务&#xff08;IaaS&#xff09;和平台即服务&#xff08;PaaS&#xff09;模型…

uni app 扫雷

闲来无聊。做个扫雷玩玩吧&#xff0c;点击打开&#xff0c;长按标记&#xff0c;标记的点击两次或长按取消标记。所有打开结束 <template><view class"page_main"><view class"add_button" style"width: 100vw; margin-bottom: 20r…

Pytorch实用教程:torch.from_numpy(X_train)和torch.from_numpy(X_train).float()的区别

在PyTorch中&#xff0c;torch.from_numpy()函数和.float()方法被用来从NumPy数组创建张量&#xff0c;并可能改变张量的数据类型。两者之间的区别主要体现在数据类型的转换上&#xff1a; torch.from_numpy(X_train)&#xff1a;这行代码将NumPy数组X_train转换为一个PyTorch张…

Docker容器监控之CAdvisor+InfluxDB+Granfana

介绍&#xff1a;CAdvisor监控收集InfluxDB存储数据Granfana展示图表 目录 1、新建3件套组合的docker-compose.yml 2、查看三个服务容器是否启动 3、浏览cAdvisor收集服务&#xff0c;http://ip:8080/ 4、浏览influxdb存储服务&#xff0c;http://ip:8083/ 5、浏览grafan…

如何利用CSS实现文字滚动效果

1. 使用CSS3的animation属性 CSS3的animation属性可以让元素在一段时间内不停地播放某个动画效果。我们可以利用这个特性来实现文字滚动效果。 我们需要定义一个包含所有需要滚动的文本的容器元素。比如&#xff1a; <div class"scroll-container"><p>…

【每日一道算法题】有序数组的平方、长度最小的子数组

文章目录 有序数组的平方写在前面题目思路解析暴力解法双指针法 我的代码暴力解法双指针法 参考答案解法暴力方法双指针法 长度最小的子数组原题思路解析暴力法滑动窗口法 我的代码官方题解滑动窗口法 有序数组的平方 写在前面 本人是一名在java后端寻路的小白&#xff0c;希…

JAV八股--redis

如何保证Redis和数据库数据一致性 关于异步通知中消息队列和Canal的内容。 redisson实现的分布式锁的主从一致性 明天继续深入看这个系列问题 介绍IO复用模型

【机器学习300问】59、计算图是如何帮助人们理解反向传播的?

在学习神经网络的时候&#xff0c;势必会学到误差反向传播&#xff0c;它对于神经网络的意义极其重大&#xff0c;它是训练多层前馈神经网络的核心算法&#xff0c;也是机器学习和深度学习领域中最为重要的算法之一。要正确理解误差反向传播&#xff0c;不妨借助一个工具——计…

代码随想录算法训练营第24天|理论基础 |77. 组合

理论基础 jia其实在讲解二叉树的时候&#xff0c;就给大家介绍过回溯&#xff0c;这次正式开启回溯算法&#xff0c;大家可以先看视频&#xff0c;对回溯算法有一个整体的了解。 题目链接/文章讲解&#xff1a;代码随想录 视频讲解&#xff1a;带你学透回溯算法&#xff08;理…

第22章-路由协议概述

1. 定义 2. 路由协议的功能 3. 路由协议的分类 1. 定义 1)概述: 路由协议(Routing Protocol):计算、维护路由信息的协议; 功能:根据相应的算法产生路由,确定路由的有效性,维护路由; 常见路由协议:RIP、OSPF、BGP等; 2)路由协议与可路由协议 路由协议:实现路由选择的…

gpt的构造和原理

gpt是序列预测模型。 问答是通过确定问答格式样本训练出来的&#xff01;比如“Q&#xff1a;xxxx.A:xxx"本质还是根据前面的序列预测后面的序列。在自回归训练过程中&#xff0c;文本序列&#xff08;可能包含问题和紧随其后的答案&#xff09;被视为一个整体输入到模型…