×

语音控制RGB LED

消耗积分:0 | 格式:zip | 大小:0.11 MB | 2022-11-14

张波

分享资料个

描述

我真的很喜欢用 Alexa 和 IFTTT 控制我的功能照明的想法,但是 wifi RGB 灯条的选项太贵了。所以我决定创建一个由 Particle 和 Alexa 驱动的易于使用的 RGB 灯条。换句话说,我只花了(19 美元的 Photon,0.50 美元的 IR LED,15 美元的 RGB Lightstrip)34 美元而不是 90 美元购买了 Phillips LightStrip,我开始享受为 Particle 编码的乐趣。

 
// This #include statement was automatically added by the Particle IDE.
//#include "martinhouse.h"
#include "IRremote.h"

#define On_Off 0xFF02FD
#define Red 0xFF1AE5
#define Green 0xFF9A65
#define Blue 0xFFA25D
#define White 0xFF22DD
#define Brighter 0xFF3AC5
#define Less_Bright 0xFFBA45
#define Flash 0xFFD02F
#define Fade7 0xFFE01F
#define Fade3 0xFF609F
#define Jump3 0xFF20DF
#define Jump7 0xFFA05F
#define Quick 0xFFE817
#define Slow 0xFFC837


IRsend irsend(D0);

bool lightStatus;
int currentHex;
int controlRGB(String command);
int wait = 1000;
int onoff = 0xFF02FD;
int hrz = 32;

void setup() {
    lightStatus = false;
    Particle.function("lights", controlRGB);
    Particle.variable("lightStatus", lightStatus);
}

void loop() {}

void lightOnOff(){
    irsend.sendNEC(On_Off, 32);
    lightStatus = !lightStatus;
}

void setLight(int hex){
     if(!lightStatus){
            lightOnOff();
            delay(wait);
        }
        irsend.sendNEC(hex,hrz);
}

int controlRGB(String command){
    
    if(command == "onoff"){
        lightOnOff();
    }
    if(command == "code"){
        setLight(currentHex);
    }
    if(command == "red"){
       setLight(Red);
    }
    if(command == "green"){
        setLight(Green);
    }
     if(command == "blue"){
         setLight(Blue);
    }
     if(command == "white"){
         setLight(White);
    }
     if(command == "brighter"){
         setLight(Brighter);
    }
     if(command == "lessBright"){
         setLight(Less_Bright);
    }
     if(command == "flash"){
         setLight(Flash);
    }
     if(command == "fade7"){
         setLight(Fade7);
    }
     if(command == "fade3"){
         setLight(Fade3);
    }
     if(command == "jump3"){
         setLight(Jump3);
    }
     if(command == "jump7"){
         setLight(Jump7);
    }
     if(command == "quick"){
         setLight(Quick);
    }
     if(command == "slow"){
         setLight(Slow);
    }
    if(command == "off"){
        if(lightStatus){
           lightOnOff(); 
        }
    }
    if(command == "isoff"){
        lightStatus = false;
    }
}

第一个挑战是记录来自 Lightstrip 遥控器的信号。我无法将 Arduino 的库移植到 Photon,所以我使用 Arduino 记录遥控器的信号,然后使用 https://github.com/qwertzguy/Spark-Core-IRremote 用 Photon 复制信号。

使用 Alexa 和 IFTTT 应用程序是最简单的步骤。现在您可以使用 Alexa 通道中的语音触发器来执行 Photon 中的注册功能,对于我们的示例,您可以调用函数 lights 并传递 onoff 参数来切换 RGB 灯。

在 IFTTT 工作

下面的例子展示了如何调用 Photon 中的函数将红光信号发送到 RGB 灯条。

第 1 步 - 登录IFTTT或创建一个免费帐户(如果您没有)。

第 2 步 - 创建配方并选择 Alexa 作为触发通道

pYYBAGNxISyAcGdfAADzlZV7x0U089.png
 

第 3 步 - 选择 Alexa 触发选项上的特定短语

poYBAGNxIS6AAPACAABWHzxhz_w923.png
 

第 4 步 - 设置一个易于记忆的短语,在本例中,我们将使用“红色厨房”

poYBAGNxITCAKkkEAABbP55or8s321.png
 

步骤 5 - 创建触发器并继续下一步。

pYYBAGNxITKAbuabAABFavf8zBQ243.png
 

第 6 步 - 寻找粒子通道并选择“调用函数”

 
 
 
poYBAGNxITWAbPQLAABOkF7YbWw675.png
 
1 / 2
 

第 7 步 - 在要控制 RGB 灯条的 Photon 上选择函数“lights”,并传递满足 if 语句条件的参数“red”

if(command == "red"){
       setLight(Red);
    }
pYYBAGNxITeAMCSZAAB9x6TTKnI116.png
 

第 8 步 - 任务完成,现在您可以告诉 Alexa 触发红色厨房。:)


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

评论(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.lene-v.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:'语音控制RGB LED',//标题 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.lene-v.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);