×

基于ESP8266的家庭自动化

消耗积分:0 | 格式:rar | 大小:3.79 MB | 2022-12-21

香香技术员

分享资料个

这个家庭自动化项目是我们决定开展的一个简单项目,作为开始我们共同开展更大项目的计划的一种方式。该项目的最终目标是能够使用我们的语音来控制电视、电灯、风扇等家用电器。在我们的案例中,我们决定使用 Google 语音助手和 LED 灯泡来演示这个想法。

这个项目如何运作?
为了便于理解,我们把它分成几个部分:

第 1 部分:安装 Blynk 应用程序。

1. 前往 Play 商店并安装 Blynk 应用程序。完成后,创建一个帐户,然后登录。

2. 单击“新建项目”以创建一个新项目,然后根据您的意愿为其命名。创建项目时,选择硬件设备为 NodeMCU,连接类型为 WiFi。

3. 完成此操作后,您将在邮件中收到一个Auth 令牌。此令牌稍后将用于将 Blynk 应用程序与 NodeMCU 链接。

4. 由于我们使用的是四通道继电器,因此必须在空白项目中添加 4 个按钮。这是通过单击空白区域的任意位置并从侧面菜单中选择按钮来完成的。

5. 这些按钮可以命名为“Relay1”、“Relay2”等,以便更好地理解。在名称下方,为 4 个按钮分别选择引脚为数字引脚 D3、D4 等。

5. Blynk 应用程序现在可供我们使用。

第 2 部分:Arduino IDE 和 Blynk 库

1. 根据您的操作系统从https://www.arduino.cc/en/software安装 Arduino IDE 。

2. 从https://github.com/blynkkk/blynk-library/releases/下载 Blynk 库,将 Blunk 应用程序与 NodeMCU 连接。解压缩下载的 zip 文件。

3. 打开 Arduino IDE,进入 File > Preferences 并在Settings选项卡下,复制 Sketchbook 的位置路径。

4. 打开文件资源管理器并转到复制的路径位置。这是 Blynk 库的安装位置。新下载的 Blynk 库将被复制到这个文件夹中。

5.从下载的Blynk目录的Libraries文件夹中复制文件/文件夹并将其粘贴到Arduino IDE目录的Libraries文件夹中。同样,Tools文件夹也是如此。

第 3 部分:将代码上传到NodeMCU

1. 使用 USB 数据线将 ModeMCU 连接到 PC。

2. 打开 Arduino IDE 并转到 Tools> Port 并使用适当的端口来匹配连接 NodeMCU 的 USB 端口。

3.接下来,转到工具>开发板并选择' NodeMCU 1.0 (ESP-12E Module) '作为开发板。

4. 要编写代码,请转到文件 > 示例 > Blynk > Boards_WIFI > ESP8266_Standalone。将打开一个带有一些预写代码的新文件。

5. 更改显示“char auth[] = “YourAuthToken””的行,并将其替换为您在电子邮件中收到的 Blynk 的身份验证令牌。

6. 更改显示 'char ssid[] = “YourNetworkName”' 的行,并将其替换为您希望 NodeMCU 连接到的 WIFI 网络的名称。

7. 更改显示'char pass[] = “YourPassword”'的行,并将'YourPassword'部分替换为您的WIFI网络密码。

8. 单击顶部的上传按钮并等待该过程。代码会上传到NodeMCU,下次开机自动连接WiFi网络。

第 4 部分:硬件组装

1.用面包板将节点 MCU 与中继板连接起来。

2. 将NodeMCU 的D3 引脚与Relay 的引脚1 连接。D4 至引脚 2、D5 至引脚 3 和 D6 至引脚 4。

3. 将 Relay 的接地引脚连接到 NodeMCU 的接地。

4. 使用普通的低压手机充电器为 NodeMCU 供电,并使用 Arduino UNO 板为继电器板供电。

5. 由于我们使用了 4 个继电器引脚,因此可以连接四个电子设备,但在我们的例子中,我们只使用了一个 LED 灯泡。

6. 现在这个组装完成了,我们可以使用 Blynk 应用程序用我们的手机打开和关闭我们的电器!

第 5 部分:使用 IFTTT 连接 Google Assistant

我们无法将 Google Assistant 直接连接到 NodeMCU。相反,我们将语音命令的解释发送到 Blynk 应用程序,后者又将其发送到 NodeMCU。为了让 Google Assistant 理解我们发出的语音指令,必须使用 IFTTT。

1. 前往https://ifttt.com/并使用您的 Google 帐户注册。

2. 登录后,单击标题中的My Applets并选择New Applet 。

3. 单击“此”并搜索 Google Assistant。选择它,然后单击以连接。

4. 此时,IFTTT 会询问您是否允许使用您的 google 帐户向其添加语音命令。点击“允许”。

5. 选择写着“说一个简单的短语”的卡片。输入您希望 Google 助理理解为命令的短语。在我们的例子中,这可能是“打开灯泡”、“打开继电器 1”等。

6. 在第四个文本框中输入 Google 助理应回复的回复。然后单击“创建触发器”。

7. 接下来,单击“那个”并输入 webhooks。在 URL 字段中键入此 URL:

http://188.166.206.43/YourAuthTokenHere/更新/DigitalPinToBeUpdateHere

用 从 Blynk 应用程序收到的邮件中收到的身份验证令牌替换“ YourAuthTokenHere” 。将“DigitalPinToBeUpdateHere”部分替换为要更新的 NodeMCU 的数字引脚。

因此,当我们将 NodeMCU 的数字引脚 D3 分配给中继时,我们必须编写 D3 来代替“DigitalPinToBeUpdateHere”。但是等等我们不能在那里写 D3,因为当 Blynk 服务器从 IFTTT 收到这个命令时,它假设它收到的命令是要发送到“Arduino Uno”板,但在我们的例子中,我们将它发送到 NodeMCU.hen Blynk 服务器从 IFTTT 接收此命令,它假设它接收到的命令将发送到“Arduino Uno”板,但在我们的例子中,我们将它发送到 NodeMCU。所以我们改用 D0。

8. 接下来,选择“方法”字段作为 PUT 并选择“内容类型”作为应用程序/JSON。对于“身体”类型:[“0”]

这里的“0”表示打开,所以我们基本上是说 Blynk 打开连接到引脚 D3 的继电器,在我们的例子中是继电器 1。现在单击“创建操作”,然后单击“完成”。

9. 同样,我们创建另一个小程序来关闭继电器。

完成所有这些步骤后,我们注册的语音命令可用于打开和关闭连接到 NodeMCU 的电气/电子设备。

这就是我们的项目结果!

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

评论(0)
发评论

下载排行榜

全部0条评论

快来发表一下你的评论吧 !

'+ '

'+ '

'+ ''+ '
'+ ''+ ''+ '
'+ ''+ '' ); $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code ==5){ $(pop_this).attr('href',"/login/index.html"); return false } if(data.code == 2){ //跳转到VIP升级页面 window.location.href="//m.obk20.com/vip/index?aid=" + webid return false } //是会员 if (data.code > 0) { $('body').append(htmlSetNormalDownload); var getWidth=$("#poplayer").width(); $("#poplayer").css("margin-left","-"+getWidth/2+"px"); $('#tips').html(data.msg) $('.download_confirm').click(function(){ $('#dialog').remove(); }) } else { var down_url = $('#vipdownload').attr('data-url'); isBindAnalysisForm(pop_this, down_url, 1) } }); }); //是否开通VIP $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code == 2 || data.code ==5){ //跳转到VIP升级页面 $('#vipdownload>span').text("开通VIP 免费下载") return false }else{ // 待续费 if(data.code == 3) { vipExpiredInfo.ifVipExpired = true vipExpiredInfo.vipExpiredDate = data.data.endoftime } $('#vipdownload .icon-vip-tips').remove() $('#vipdownload>span').text("VIP免积分下载") } }); }).on("click",".download_cancel",function(){ $('#dialog').remove(); }) var setWeixinShare={};//定义默认的微信分享信息,页面如果要自定义分享,直接更改此变量即可 if(window.navigator.userAgent.toLowerCase().match(/MicroMessenger/i) == 'micromessenger'){ var d={ title:'基于ESP8266的家庭自动化',//标题 desc:$('[name=description]').attr("content"), //描述 imgUrl:'https://'+location.host+'/static/images/ele-logo.png',// 分享图标,默认是logo link:'',//链接 type:'',// 分享类型,music、video或link,不填默认为link dataUrl:'',//如果type是music或video,则要提供数据链接,默认为空 success:'', // 用户确认分享后执行的回调函数 cancel:''// 用户取消分享后执行的回调函数 } setWeixinShare=$.extend(d,setWeixinShare); $.ajax({ url:"//www.obk20.com/app/wechat/index.php?s=Home/ShareConfig/index", data:"share_url="+encodeURIComponent(location.href)+"&format=jsonp&domain=m", type:'get', dataType:'jsonp', success:function(res){ if(res.status!="successed"){ return false; } $.getScript('https://res.wx.qq.com/open/js/jweixin-1.0.0.js',function(result,status){ if(status!="success"){ return false; } var getWxCfg=res.data; wx.config({ //debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId:getWxCfg.appId, // 必填,公众号的唯一标识 timestamp:getWxCfg.timestamp, // 必填,生成签名的时间戳 nonceStr:getWxCfg.nonceStr, // 必填,生成签名的随机串 signature:getWxCfg.signature,// 必填,签名,见附录1 jsApiList:['onMenuShareTimeline','onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ //获取“分享到朋友圈”按钮点击状态及自定义分享内容接口 wx.onMenuShareTimeline({ title: setWeixinShare.title, // 分享标题 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享给朋友”按钮点击状态及自定义分享内容接口 wx.onMenuShareAppMessage({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 type: setWeixinShare.type, // 分享类型,music、video或link,不填默认为link dataUrl: setWeixinShare.dataUrl, // 如果type是music或video,则要提供数据链接,默认为空 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ”按钮点击状态及自定义分享内容接口 wx.onMenuShareQQ({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口 wx.onMenuShareWeibo({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ空间”按钮点击状态及自定义分享内容接口 wx.onMenuShareQZone({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); }); }); } }); } function openX_ad(posterid, htmlid, width, height) { if ($(htmlid).length > 0) { var randomnumber = Math.random(); var now_url = encodeURIComponent(window.location.href); var ga = document.createElement('iframe'); ga.src = 'https://www1.elecfans.com/www/delivery/myafr.php?target=_blank&cb=' + randomnumber + '&zoneid=' + posterid+'&prefer='+now_url; ga.width = width; ga.height = height; ga.frameBorder = 0; ga.scrolling = 'no'; var s = $(htmlid).append(ga); } } openX_ad(828, '#berry-300', 300, 250);