Diy智能家居-声音卫士

下载地址(CODE):

https://pan.baidu.com/s/1LNfCTK7itR-JbkzU9mJPUg

实现效果:

小baby在楼上自己睡觉的时候,声音传感器开启,当发现有动静,通过LORA(无线串口)将信号通知到楼下的蜂鸣器接收端。

通过开关控制模块是否启用

通信协议:

9600 N 8 1    
标识头:5A AB
包类型:01
数据长度:01
数据内容
校验位:采用亦或校验

1#协议
启用模块
5A AB 01 01 01 F0

禁用模块
5A AB 01 01 00 F1

执行成功回馈
5A AB 01 01 64 95

2#协议
声音传感器:on
5A AB 02 01 01 F3

声音传感器:off
5A AB 02 01 00 F2

执行成功回馈
5A AB 02 01 64 96

 

代码片段:

按键去抖动(不使用delay,无延时)

int GpioInput::CheckDigitalStatus1()
{
  if ((0 != checkIndex) && (millis() - checkTime) <= checkInterval) return -1;// 过滤中间时段的数据

  int state = digitalRead(pin);

  Serial.print(String(state) + ",");
  
  if (state != stateTemp)
  {
      checkIndex = 0;
      stateOld = stateTemp;
  }
  else
  {
    if (state != stateOld)
    {
      checkIndex++;
      checkTime = millis();
    }
  }
  stateTemp = state;

  int ret = -1; 
  if (checkIndex == checkCount) 
  {
    checkIndex = 0;
    if (stateOld != state) 
    {
      stateOld = state;
      ret = state;
    }
  }

  return ret;
}

监测指定电平(不使用delay,无延时)

int GpioInput::CheckDigitalStatus2(int val)
{
  if ((0 != checkIndex) && (millis() - checkTime) <= checkInterval) return -1;// 过滤中间时段的数据

  int state = digitalRead(pin);

  //Serial.print(String(state) + ",");
  
  if (state == val)
  {
      checkIndex++;
      checkTime = millis();
  }
  else
  {
    checkIndex = 0;
  }
  
  int ret = -1; 
  if (checkIndex == checkCount) 
  {
    checkIndex = 0;
    ret = state;
  }

  return ret;
}

对串口数据进行垃圾包,掉包,粘包处理

void MySerial::SerialRecv()
{
   if (softSerial->available() > 0)
   {
      while ((softSerial->available() > 0))
      {
          byte inByte = softSerial->read();
          //Serial.println(inByte);
          bBuffer.Put(&inByte, 1);
      }
   }
   ProtocolHandle();
}

bool MySerial::ProtocolHandle()
{
  if (!bBuffer.HasRemaining()) return false;
  
  int iPosition = bBuffer.GetPosition();
  byte head1 = 0; byte head2 = 0; bool heardok = false;

  while (bBuffer.HasRemaining()) 
  {
      head1 = bBuffer.GetByte(); if (bBuffer.GetWaitRecvRemain()) { bBuffer.SetPosition(iPosition); return false; }
      if (HEAD1 == head1)
      {
          iPosition = bBuffer.GetPosition() - 1;
          head2 = bBuffer.GetByte(); if (bBuffer.GetWaitRecvRemain()) { bBuffer.SetPosition(iPosition); return false; }
          if (HEAD2 == head2)
          {
              heardok = true;
              break;
          }
          else
          {
            Serial.println("Error,Unable to parse the serial data(2):Position=" + String(iPosition) + ",Head2=" + String(head2));
          }
      }
      else
      {
         Serial.println("Error,Unable to parse the serial data(1):Position=" + String(iPosition) + ",Head1=" + String(head1));
      }
  }
  
  if (!heardok) return false;

  byte cmd = bBuffer.GetByte();                     if (bBuffer.GetWaitRecvRemain()) { bBuffer.SetPosition(iPosition); return false; };
  byte len = bBuffer.GetByte();                     if (bBuffer.GetWaitRecvRemain()) { bBuffer.SetPosition(iPosition); return false; } 
  SerialRecBuf source = bBuffer.GetByteArray(len);  if (bBuffer.GetWaitRecvRemain()) { bBuffer.SetPosition(iPosition); return false; } 
  byte check = bBuffer.GetByte();                   if (bBuffer.GetWaitRecvRemain()) { bBuffer.SetPosition(iPosition); return false; } 

  byte check_crc = CalcCheck2(head1, head2, cmd, len, source.byRxBuf);

  if (check != check_crc)
  {
     Serial.println("Error,CRC:check=" + String(check) + ",check_crc=" + String(check_crc));
  }
  else
  {
    switch (cmd)
    {
        case 1:
            // 是否启用
            if (1 == source.dwLength)
            {
              Work = source.byRxBuf[0];
              if (0 == Work || 1 == Work) 
              {
                softSerial->write(protocol_01_work_ok, 6);
              }
              else if (100 == Work)
              {
                Work = result_01_work;
              }
            }
            Serial.println("protocol 1 ok,Work:" + String(Work));
            break;
        case 2:
            // 声音传感器状态
            Serial.println("protocol 2 ok");
            if (1 == source.dwLength)
            {
              Speak = source.byRxBuf[0];
//              if (0 == Speak || 1 == Speak) 
//              {
//                softSerial->write(protocol_02_voice_ok, sizeof(protocol_02_voice_ok)/sizeof(protocol_02_voice_ok[0]));
//              }
            }
            Serial.println("protocol 1 ok,Speak:" + String(Speak));
            break;
    }
  }
  
  if (!bBuffer.HasRemaining()) bBuffer.Clear();
  
  return true;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本文首发于DF创客社区作者:2877137721 原文链接: DIY属于你的智能家居系统,zigbee,esp8266,51单片机 DIY家庭智能家居控制系统(2)51,zigbee,esp8266 相关附件于原文下方下载 【介绍】 随着微功耗处理器以及通讯芯片的发展,以往较为耗能的有线通讯方式越来越阻碍了通讯网络的发展,于是一大批的无线通讯方案应运而生,例如NBIOT,蓝牙4.0,zigbee等等。同时微功耗无线处理器的流行使得传统家电带上了智能的色彩,智能家居必将是未来家庭的必备。某些高科技企业也在揶揄这块市场,纷纷推出了自家的智能家居解决方案,比较知名的有米家方案以及阿里智能的解决方案。但是回到现实的使用上来说,每个家庭的条件环境其实不一样,同样的产品未必在每个家庭上都可以使用方便,所以个性化的定制产品才可以更好的方便我们的生活。 于是在暑假期间,萌生了DIY一套智能家居方案的想法,具有各种智能开关和传感器等节点,并且对接物联平台实现联网控制以及数据的上传。由于家庭中将会使用到的智能设备种类繁多,所以我将采用模块化的设计思路,即采用核心板加外围功能部分的思路,像搭积木一样的构建各个智能设备。大家有同样想制作的想法可以参考。 截至发帖前,我完成了智能网关,智能墙壁开关,无线遥控开关以及无线气象站的设计制作,之后有新的设备加入的话,我会及时的更新。 【准备事项】 完成这个涉及到多方面的项目,需要的硬件设备以及开发环境较多,所以我先大概给出一个列表: 软件篇: ArduinoIDE:用于给ESP8266编程使用 KEIL uVision5 :用于给51单片机编程使用 串口调试器:用于监控单片机输出数据 lceda设计软件:绘制电路原理图,设计PCB电路板 硬件篇: NodeMCU开发板一块 亿佰特zigbee模块若干(视节点数量而定) STC8F2系列单片机若干 核心的主要控制器件在此列出,其他元器件会在制作过程中一一说明。 【制作过程】 我构想了一张智能家庭的网络拓扑图,大家可以欣赏以下,后期图上的设备都将加入进来: 由于涉及到多个设备的设计制作,所以本个报名贴先奉上智能家居核心板,智能网关以及无线气象站的制作过程: #制作过程之核心板篇# >>>本项目使用zigbee网络进行智能家居之间的通信。 好早之前就接触过zigbee组网,对于这种低成本低功耗的网络还是抱有很大信心的。这里讲解选择这个网络的几大理由: mesh结构的网络很适合智能家居的控制结构,在入网的任何一个节点都可以访问到所有节点的数据,这点很适合网关控制各个设备。 低功耗使得终端设备甚至可以采用电池供电,使得所有的模组都尽量可能的无线化。 多跳传输,无线方案中最大的问题就是数据发送的不稳定以及障碍物对信号的遮挡导致数据无法正确传输,而ZigBee的多跳恰好解决了这个问题,节点会自动选择优质的传输路线多跳传输,保证信号质量。 总结一下:zigbee网络确实是好,但是对于我这种比较懒惰的人并不想去学习那复杂的传输理论以及zigbee通讯芯片的编程,于是我选择上网购买ZigBee模块,最后选择了一种小型的串口转zigbee模块,比较方便单片机通讯。 说到模块化,那么就需要核心的控制板。本质来说就是将单片机以及购买的zigbee模块集成到一张电路板上,并且预留各种接口,方便后期移植到各种设备上,这样一张电路板就可以适用各种智能家居设备了。 在保证功能足够的同时,体积也是我需要考虑的问题,如果核心板做的过大,会导致无法安装到某些空间狭小的智能设备中,所以小体积是我所着重考虑的。 基于多方面考虑之后,stc8F2k08s2进入了我的视线,小巧的sop16封装以及简单的外围电路,足够的IO口(14个)。这款芯片成为了核心板的控制单片机。于是一番绘制原理图以及PCB之后,成品大概明朗了: 焊接好的成品如下: 这将会成为以后所有我的智能家居方案的核心控制板。 #制作过程之智能网关篇# 完成了核心板的制作,网关成为了下一个比较关注的对象,因为家中的所有智能设备的控制以及通讯都会由他来完成,包括链接到互联网上传数据,所以说对于网关的硬件选取也是重中之重。上联互联网,下接zigbee小型通讯网,网关担任了一个家庭控制中心的角色,对于它的选择我认为esp8266是个不错的方案,可以支持arduino ide编程,这对于不太了解网络通讯协议的我来说是个好消息,因为在arduino的编程中,我可以借助强大的库函数来完成我想要的功能。 ESP8266是一个拥有了近80Mhz的主频的32位处理器,内置了wifi模组省去了网线,并且拥有丰富的外设以及较高的性能,可以胜任智能网关的工作。当然,近期乐鑫发布的ESP32系列芯片也会是个好的选择,更高的主频以及wifi蓝牙双模的设计让其拥有更加方便的接
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值