第一次接触慧编程的时候,你是不是和我一样,有过这样的疑惑:
为什么在慧编程里,我们不需要像专业的开发者那样敲代码,只要拖动积木块就可以实现想要的功能?
其实,这里涉及到编程中所谈及的“封装”的概念。
所谓封装,就是把可以实现一段功能的算法写在一个子程序里(在一些主流的编程语言中也叫函数或者方法),然后给这个子程序起一个名字,我们想要实现这个功能的时候直接调用这个子程序就可以了,而这个子程序就是我们在慧编程里看到的各种积木块。
今天,我们特别邀请了慧编程的开发小哥,一起来看看他是怎么为慧编程创作积木块的吧~
注:本文将使用扩展设计器为慧编程添加新设备的积木块。扩展设计器是专门提供给用户快速开发扩展的一个工具,使用它,你只要略懂代码就可以支持想要的新设备/传感器/新功能啦~
data:image/s3,"s3://crabby-images/d628b/d628b682b444a81b9183c183640ffb8d39e5c175" alt="https://www.china-scratch.com/Uploads/timg/190820/1121544257-1.jpg"
1.登录慧编程扩展设计器
打开慧编程扩展设计器登录界面 https://ext.makeblock.com,输入邮箱和密码进入设计器主页。(若还没有帐号,可直接免费注册)
data:image/s3,"s3://crabby-images/ecd1d/ecd1d796561ec9d11155609966e36ed3f4b8b667" alt="https://www.china-scratch.com/Uploads/timg/190820/11215411Z-2.jpg"
2.新建设备
在设计器主页的左侧点击“我的插件”,选择“新建设备”
data:image/s3,"s3://crabby-images/31df5/31df52a106bd177df787e84baf3b563b58c48829" alt="https://www.china-scratch.com/Uploads/timg/190820/11215B934-3.jpg"
3. 填写设备基本信息
填写“标识 ID ,版本号,名称”,上传设备图片,并勾选支持的平台,点击“确定”完成填写。
注:红框信息为必填,其他信息已默认设置好,除特殊情况外,一般不需要更改。
data:image/s3,"s3://crabby-images/8cee8/8cee8b97cb363dc57c36c42c9dad59cbba709d97" alt="https://www.china-scratch.com/Uploads/timg/190820/1121563396-4.jpg"
4. 为设备添加积木块
1)点击设备名称进入积木编辑页
data:image/s3,"s3://crabby-images/63f0d/63f0d613de6df29600e5f1d56712a58873df39cd" alt="https://www.china-scratch.com/Uploads/timg/190820/11215SN9-5.jpg"
2)点击“新增分类”
data:image/s3,"s3://crabby-images/43843/4384360a6800f5db3387dd062532b50f84cb2e09" alt="https://www.china-scratch.com/Uploads/timg/190820/112159E39-6.jpg"
3) 输入分类名,点击“确定”完成积木分类的新建
data:image/s3,"s3://crabby-images/c3f65/c3f650a0b1868125678f86c2b4a086413b2994f1" alt="https://www.china-scratch.com/Uploads/timg/190820/1122013I2-7.jpg"
4)现在,我们要为这个积木类型添加一个积木,点击积木列表最下面的“+”
data:image/s3,"s3://crabby-images/22de2/22de2d7713177b5aa2dea6a38b069aeda7f7e654" alt="https://www.china-scratch.com/Uploads/timg/190820/112201I21-8.jpg"
5)为积木设置内容
注:空格+@即可添加参数
data:image/s3,"s3://crabby-images/fc009/fc00952e9e24449cfca1141dc35891cb45545edf" alt="https://www.china-scratch.com/Uploads/timg/190820/11220215Y-9.jpg"
6)在 “下拉框”添加“高电平、低电平”选项
data:image/s3,"s3://crabby-images/b1d37/b1d37ed564e729868cc26a46be5e1dab1bbdbf5c" alt="https://www.china-scratch.com/Uploads/timg/190820/112202O31-10.jpg"
7)勾选支持的平台,点击“保存”
data:image/s3,"s3://crabby-images/e5c58/e5c58b69c2870524f08c655b47ddc4bece2e5f4d" alt="https://www.china-scratch.com/Uploads/timg/190820/1122033323-11.jpg"
5.转码Arduino C
切换到“转码设置”,选择ArduinoC,点击“保存”
data:image/s3,"s3://crabby-images/56f5d/56f5d9cfcb9c43360c374f03d1f55cf8014e97ef" alt="https://www.china-scratch.com/Uploads/timg/190820/1122044044-12.jpg"
代码如下:
//generated by mBlock5for// codes make you happy//( include //)//( lib //)//({this.$ALL_VARIABLES.length==0?'':this.$ALL_VARIABLES.map(v=>"float"+v+" = 0;").join('n')}//)//( declare //)void_delay(float seconds) {long endTime = millis() + seconds *1000;while(millis() < endTime) _loop();}//(void setup() {//(setup //)//( code //)}//)void _loop() {//( _loop //)}void loop(){//( loop //)_loop();}这段代码用于延时以及自定义_loop
data:image/s3,"s3://crabby-images/0c539/0c5398b0c00723b8bb6a7a3b245c2e6212014c9b" alt="https://www.china-scratch.com/Uploads/timg/190820/112205J92-13.jpg"
6.连接配置
1)切换到“连接配置”,设置vendorID为:0x2A03(这个参数作用是筛选串口,这里uno的vendorID是0x2A03)
data:image/s3,"s3://crabby-images/9f7f9/9f7f9849024139366116860daccfd869305b6d8d" alt="https://www.china-scratch.com/Uploads/timg/190820/11220530D-14.jpg"
2)配置中间件,名称设为“arduino”
data:image/s3,"s3://crabby-images/ef863/ef863c33bab9a10f86277a258b32b0160c3c703e" alt="https://www.china-scratch.com/Uploads/timg/190820/11220BQ5-15.jpg"
data:image/s3,"s3://crabby-images/1d610/1d6103050d41f71c3f8bd1885ae58701fb16796a" alt="https://www.china-scratch.com/Uploads/timg/190820/11220623T-16.jpg"
3)切换到“上传代码驱动设置”,选择“stk500v1”,保存
data:image/s3,"s3://crabby-images/f5c43/f5c43b7afceea44c80831477d09dd632a491e4c2" alt="https://www.china-scratch.com/Uploads/timg/190820/11220M618-17.jpg"
7.上传转码给积木块
1) 回到“积木设置”,并切换到“上传转码”
data:image/s3,"s3://crabby-images/65eef/65eefffd695c5cfbb14f941b67b2e189aeb9da07" alt="https://www.china-scratch.com/Uploads/timg/190820/11220I402-18.jpg"
2)配置如下内容(注:双击编辑区就可以编写代码啦~)
setup:pinMode(/*{number_1}*/,OUTPUT); //这里/*{number_1}*/是变量的写法,里面的number_1为之前的数字口变量名code:digitalWrite(/*{number_1}*/,/*{fieldMenu_2}*/);data:image/s3,"s3://crabby-images/2d5c8/2d5c87fdf1c7c9e2660cc0f4eca6b76b8eb0c161" alt="https://www.china-scratch.com/Uploads/timg/190820/11220W526-19.jpg"
3)切换到“事件”分类,添加一个积木
data:image/s3,"s3://crabby-images/42026/420261d6e2a416799cebd7ed572f24952a364258" alt="https://www.china-scratch.com/Uploads/timg/190820/11220S316-20.jpg"
4)输入内容如下,注意设置积木类型为“事件”
data:image/s3,"s3://crabby-images/b70f4/b70f42b0ed31695b076eef4fe60b95855d04cb91" alt="https://www.china-scratch.com/Uploads/timg/190820/112210A63-21.jpg"
5)设置转码,点击“保存”
include:, , code: /*{$BRANCH}*/ // 这里 $BRANCH 指代的是与其拼接的积木的转码data:image/s3,"s3://crabby-images/11bc4/11bc44ff64041e677e2ba824c43bb1791e8bd9b9" alt="https://www.china-scratch.com/Uploads/timg/190820/1122105924-22.jpg"
8. 预览效果
1)点击页面右上角的“预览”
data:image/s3,"s3://crabby-images/321cd/321cd18462a8e524609e0bdaea78fee6b5d967e3" alt="https://www.china-scratch.com/Uploads/timg/190820/1122103D6-23.jpg"
2)连接串口
data:image/s3,"s3://crabby-images/ac55b/ac55b99b386eec7883875ac14cc23ca9fdd22733" alt="https://www.china-scratch.com/Uploads/timg/190820/1122116492-24.jpg"
3)编辑积木如图所示,然后点击慧编程页面左下角的“上传到设备”
data:image/s3,"s3://crabby-images/9d78b/9d78b12a9ca2e252b8edf894f0fe3f6efcd66968" alt="https://www.china-scratch.com/Uploads/timg/190820/112212K27-25.jpg"
data:image/s3,"s3://crabby-images/e35b9/e35b97aeb2ec5374ab9ef04dace839e76b47ab5b" alt="https://www.china-scratch.com/Uploads/timg/190820/112213D63-26.jpg"
4)至此,Uno黄灯会闪烁10下,说明代码已上传成功!我们为慧编程增加了一个新扩展啦~
我们再来探讨一下:为什么我们选择使用积木块来封装代码呢?
封装成积木块的代码看起来更简单,尤其对于想通过编程提高逻辑能力的小朋友来说,只要识字,通过认识积木块并加以练习,就可以用积木块实现想要的功能,进而创作出动画、游戏还有控制机器人!
声明:转载此文是出于传递更多信息之目的。若有来源标注错误或侵犯了您的合法权益,请作者持权属证明与本网联系,我们将及时更正、删除,谢谢。