×

使用Quantum的按钮LED

消耗积分:0 | 格式:zip | 大小:1.48 MB | 2022-10-28

张敏

分享资料个

描述

构建过程

这个想法

这是经典 Hello World 电子项目的 Quantum 版本。该项目的目标是通过引导您完成配对客户端、构建应用程序、创建固件等操作,让您熟悉 Quantum 系统!

程序

第 1 步:启动并配对您的客户端

首先,我们需要确保您的 Builder Base 与您的 Q-Server 正确配对。为此,您需要启动客户端。在这个项目中,我们将使用提供的微型 USB 电缆和 USB 到墙壁插座适配器。

一旦客户端连接到电源,您应该会看到两个 Builder Base 底部的状态 LED 闪烁绿色。

接下来,在浏览器中输入您的服务器 IP 并使用您的密码登录。如果您不知道您的服务器 IP 地址,您可以按照我们的教程在此处设置您的服务器。

进入服务器主页后,选择窗口左侧工具面板中的“客户端”图标。

pYYBAGNY1hyAB787AAB52bDLSB0188.png
 

然后单击“Unpaired”选项卡,您应该会看到两个未配对的 Builder Bases。

pYYBAGNY1iGAQWAtAAA9QhZWlzI921.png
 

对于两个 Builder Base,单击“...”操作图标并选择“Pair”。

poYBAGNY1iOAScomAAAkRsQb284075.png
 

如果您的 Builder Bases 正确配对,状态 LED 应该从闪烁变为稳定的绿色状态,并且它们应该出现在您的“配对”列表下。

为了区分这两个客户端,您应该识别它们。对于第一个 Builder Base,单击操作按钮并选择“识别”命令。您应该注意到其中一个客户端上的状态 LED 闪烁红色和绿色。

poYBAGNY1iWAMFC5AABJVXpr6eU369.png
 

再次单击操作按钮并选择“编辑”功能。将此客户端命名为“按钮”并选择“保存”。

poYBAGNY1iiAWuU9AAAh_sab0dU620.png
 

 

pYYBAGNY1iqAae_NAAAkLGa_gnY806.png
 

对第二个 Builder Base 执行相同操作,但将其命名为“LED”。

poYBAGNY1i-AWczsAAAsb24qq48462.png
 

 

poYBAGNY1jGAG09FAAAtqYFp3Cs170.png
 

您的 Builder Bases 现在可以使用了!

第 2 步:组装硬件

收集名为“LED”的客户、两根公对公跳线和您的 LED。

接下来,确定 LED 上的哪些引线是正极和接地,并将其放在面包板上。在大多数情况下,较长的引线将是正极,较短的引线将是接地。现在取两根跳线,一根连接到 GND 引线,另一根连接到正极引线。将正极线连接到 Builder Base 上的 GPIO GP0 端口,将 GND 线连接到 Builder Base 上的 GND 端口。此 Builder Base 的接线现已完成!

pYYBAGNY1jSAImcMAAI0QzTLMeg880.png
 

 

poYBAGNY1jeADJ5tAADx-CXdY0Q316.png
 

接下来,收集名为“Button”的 Builder Base、两根公对公跳线和一个触觉按钮。

将您的按钮放在面包板上,并将两根电线连接到彼此对角线的任意一组引脚上。取出连接到按钮的引线,将一根连接到 GP0,另一根连接到 Builder Base 上的 3.3V。

poYBAGNY1j2AYrHzAAH76MU1cXc606.png
 

 

pYYBAGNY1kCACpZOAAEWJ0qlC1w570.png
 

第 3 步:构建固件

在这里,我们将构建两组固件文件:一组用于 Button,另一组用于 LED。

使用左侧的工具栏,导航到固件生成器。选择屏幕左上角的“+新建”。

poYBAGNY1kOAMsZoAABJdYjzsBc192.png
 

接下来,将您的固件文件命名为“Hello World - LED”并点击“创建”。

pYYBAGNY1kiAGaHtAAAn4tEubaM990.png
 

现在,选择“+ 添加设备”按钮。您可以使用搜索栏或滚动列表来查找设备。找到并选择“LED”设备,将其命名为 LED,然后单击“添加设备”。现在您已准备好配置设备。

poYBAGNY1kuAM982AABNzoKdKuA831.png
 

从驱动程序下拉菜单中选择“GPIO”。引脚选择 GP0,模式选择 Initially Low。

保存您的固件文件。

poYBAGNY1k-AKEXaAACIezowe_g142.png
 

现在我们将为连接到按钮的构建器基础创建固件文件。

单击“+新建”按钮。将新文件命名为“Hello World - Button”并点击“Create”。

pYYBAGNY1lGAXu-1AAAoMwUWLDs659.png
 

接下来,选择“+ 添加设备”。使用搜索功能找到“Button”设备并将其命名为“Button”。

poYBAGNY1lmAR7MhAABRUC1UoYI953.png
 

要配置按钮,请从驱动程序下拉菜单中选择 GPIO 驱动程序。

将引脚设置为 GP0,将去抖设置为启用,将引脚模式设置为输入下拉。

保存您的固件文件。

pYYBAGNY1luASh6EAACQ2HI1F_k378.png
 

现在您已准备好上传固件文件。

对于您的“Hello World - LED”固件文件,选择它旁边的“Action”按钮。在下拉菜单下选择“上传”按钮。

poYBAGNY1l-Ae3a0AAAqMPU6dII375.png
 

将出现您配对的 Builder Base 的列表。选择名为 LED 的 Builder Base 并点击上传。

poYBAGNY1mOAOdojAAAzJLuVf-4086.png
 

对于您的“Hello World - 按钮”固件文件,重复这些步骤,但请务必将其上传到名为 Button 的 Builder Base。

pYYBAGNY1maAEXCeAAAyo_sdS_4826.png
 

您可以同时上传两个固件。固件文件可能需要几分钟才能完成上传。您可以在页面右侧的通知选项卡上查看他们的上传进度。

 
 
 
poYBAGNY1miAVSvTAAAPPn5lx2s204.png
 
1 / 2
 

第 4 步:对应用程序进行编程

通过屏幕左侧的工具栏从固件生成器导航到应用生成器。

在那里,单击“+新建”。

pYYBAGNY1muACeEYAAA7fNG-UVA566.png
 

为您的应用命名并点击创建。

poYBAGNY1nCAfbAiAAAfGb9nWfk622.png
 

您将被重定向到您将在其中构建应用程序的画布。

使用屏幕左侧的搜索栏找到“LED”硬件对象并将其拖到画布上。

poYBAGNY1nKAPbqoAAAwz0lWZ6Y859.png
 

 

poYBAGNY1niALCmhAAAd9_XkiAI614.png
 

单击 LED 对象,屏幕右侧将显示一个文本字段。您可以在此处命名对象。我们将其命名为 LED。命名您的对象可以更容易地在映射阶段识别它们,因此我们建议您命名它们。

pYYBAGNY1nqAG1W-AABLUqOvPPw127.png
 

接下来,再次使用搜索功能找到“Button”硬件对象并将其拖到 Canvas 上。确保将此对象拖到画布上时为蓝色。我们建议您也将此对象命名。

poYBAGNY1n2AWVjSAAAwnCbOL-A273.png
 

您会看到按钮对象只有一个输出端口,而 LED 有一个输入端口。

poYBAGNY1oCAIl_lAAAnox7FO-8344.png
 

通过在其中一个端口上单击并按住鼠标按钮,然后将鼠标拖动到另一个端口并释放,在对象之间建立连接。

poYBAGNY1oKAa1E2AAAnCCQ5-jc110.png
 

您的应用程序现已完成。您可以通过单击屏幕右上角的“保存应用程序”按钮来保存它。

保存后点击“返回我的应用”

pYYBAGNY1oSAIt3hAAAhXwNcs_8907.png
 

 

pYYBAGNY1oeAdKJ5AAAc8jJxlC8358.png
 

第 5 步:映射硬件

您现在应该回到应用程序页面。

找到您的“按钮和 LED”应用程序并点击播放按钮。

poYBAGNY1oqARnzJAAAdjE1mDyY280.png
 

包含应用程序中所有设备的列表将展开。

pYYBAGNY1oyAAzRqAAB5fI48DKo405.png
 

接下来点击“LED”设备,右侧会出现客户端下拉菜单。

从下拉菜单中选择 LED 驱动器并点击“完成”。

poYBAGNY1o-AC_MeAAB4cMfknPo943.png
 

对“按钮”重复相同的步骤。

poYBAGNY1pGAbga0AABx8lVvQIc155.png
 

请注意状态符号如何变为绿色复选标记。

pYYBAGNY1pSATLcvAACDaO1_UfA371.png
 

**将固件设备映射到您的应用程序中的对象时,请务必注意,只有相同类型的设备和对象才能映射在一起。例如,使用此应用程序,我们只能选择将带有按钮固件的构建器库映射到按钮对象。**

第 6 步:运行应用程序!

恭喜你构建了你的第一个项目,现在是时候使用它了!

点击“保存+运行”。

pYYBAGNY1pSATLcvAACDaO1_UfA371.png
 

 

poYBAGNY1puAHHqyAAAa59KFQb4165.png
 

瞧!您的 Hello World 项目现已完成。

 

 


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

评论(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:'使用Quantum的按钮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.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);