揭秘:慧编程的积木块是怎么来的?
第一次接触慧编程的时候,你是不是和我一样,有过这样的疑惑:
为什么在慧编程里,我们不需要像专业的开发者那样敲代码,只要拖动积木块就可以实现想要的功能?
其实,这里涉及到编程中所谈及的“封装”的概念。
所谓封装,就是把可以实现一段功能的算法写在一个子程序里(在一些主流的编程语言中也叫函数或者方法),然后给这个子程序起一个名字,我们想要实现这个功能的时候直接调用这个子程序就可以了,而这个子程序就是我们在慧编程里看到的各种积木块。
今天,我们特别邀请了慧编程的开发小哥,一起来看看他是怎么为慧编程创作积木块的吧~
注:本文将使用扩展设计器为慧编程添加新设备的积木块。扩展设计器是专门提供给用户快速开发扩展的一个工具,使用它,你只要略懂代码就可以支持想要的新设备/传感器/新功能啦~
data:image/s3,"s3://crabby-images/b4249/b424975be9694368138d1bf619988709439104bb" alt="https://cdn.china-scratch.com/timg/190820/1121544257-1.jpg"
1.登录慧编程扩展设计器
打开慧编程扩展设计器登录界面 https://ext.makeblock.com,输入邮箱和密码进入设计器主页。(若还没有帐号,可直接免费注册)
data:image/s3,"s3://crabby-images/76287/762878c700108beb5f0f2b393b2c5c8d3bc2f9f3" alt="https://cdn.china-scratch.com/timg/190820/11215411Z-2.jpg"
2.新建设备
在设计器主页的左侧点击“我的插件”,选择“新建设备”
data:image/s3,"s3://crabby-images/ab638/ab6383745ced6c3e8a9f15f03f6383c684e50997" alt="https://cdn.china-scratch.com/timg/190820/11215B934-3.jpg"
3. 填写设备基本信息
填写“标识 ID ,版本号,名称”,上传设备图片,并勾选支持的平台,点击“确定”完成填写。
注:红框信息为必填,其他信息已默认设置好,除特殊情况外,一般不需要更改。
data:image/s3,"s3://crabby-images/0cc88/0cc884602e1cbcc909161ab9f6aefbc61bc7571e" alt="https://cdn.china-scratch.com/timg/190820/1121563396-4.jpg"
4. 为设备添加积木块
1)点击设备名称进入积木编辑页
data:image/s3,"s3://crabby-images/3073c/3073c462cfb39911033a1dbcda9d482a2153e853" alt="https://cdn.china-scratch.com/timg/190820/11215SN9-5.jpg"
2)点击“新增分类”
data:image/s3,"s3://crabby-images/43439/43439211dbb8ed2a75a26e510b6af6ba4c161094" alt="https://cdn.china-scratch.com/timg/190820/112159E39-6.jpg"
3) 输入分类名,点击“确定”完成积木分类的新建
data:image/s3,"s3://crabby-images/f9c82/f9c827684badff075a0c6347c4a987389eebc5da" alt="https://cdn.china-scratch.com/timg/190820/1122013I2-7.jpg"
4)现在,我们要为这个积木类型添加一个积木,点击积木列表最下面的“+”
data:image/s3,"s3://crabby-images/ef3a4/ef3a4e5a3184a591bdb6f135285700b684d2b2d8" alt="https://cdn.china-scratch.com/timg/190820/112201I21-8.jpg"
5)为积木设置内容
注:空格+@即可添加参数
data:image/s3,"s3://crabby-images/479de/479de72c0b74710f2ffb4ad0c277a57a69245dec" alt="https://cdn.china-scratch.com/timg/190820/11220215Y-9.jpg"
6)在 “下拉框”添加“高电平、低电平”选项
data:image/s3,"s3://crabby-images/36858/368585de76172ce67e12a8280b29d72eeea285bf" alt="https://cdn.china-scratch.com/timg/190820/112202O31-10.jpg"
7)勾选支持的平台,点击“保存”
data:image/s3,"s3://crabby-images/16e54/16e54e8f762c674a89263ef43cc9d76456cd9fe2" alt="https://cdn.china-scratch.com/timg/190820/1122033323-11.jpg"
5.转码Arduino C
切换到“转码设置”,选择ArduinoC,点击“保存”
data:image/s3,"s3://crabby-images/c0798/c0798abdadd94fa1ea50d811bf04bd35ee3d6dbb" alt="https://cdn.china-scratch.com/timg/190820/1122044044-12.jpg"
代码如下:
// generated by mBlock5 for// 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/53abe/53abe32af406fbc1f831d7aa75c03ad965fdcdfb" alt="https://cdn.china-scratch.com/timg/190820/112205J92-13.jpg"
6.连接配置
1)切换到“连接配置”,设置vendorID为:0x2A03(这个参数作用是筛选串口,这里uno的vendorID是0x2A03)
data:image/s3,"s3://crabby-images/ca1db/ca1db40109c0a7c729198e3497ee87de8a0607a5" alt="https://cdn.china-scratch.com/timg/190820/11220530D-14.jpg"
2)配置中间件,名称设为“arduino”
data:image/s3,"s3://crabby-images/b1362/b1362b4b0905628423c94a4778ab214f6a98ad42" alt="https://cdn.china-scratch.com/timg/190820/11220BQ5-15.jpg"
data:image/s3,"s3://crabby-images/9611d/9611d16f026e3a04d1851f589a7342753c4ff77f" alt="https://cdn.china-scratch.com/timg/190820/11220623T-16.jpg"
3)切换到“上传代码驱动设置”,选择“stk500v1”,保存
data:image/s3,"s3://crabby-images/07db1/07db122f7fe12c0a83b6cee85c44b267074a9065" alt="https://cdn.china-scratch.com/timg/190820/11220M618-17.jpg"
7.上传转码给积木块
1) 回到“积木设置”,并切换到“上传转码”
data:image/s3,"s3://crabby-images/edcb0/edcb03e1c1c1134130d58193a2764c1bb39d641f" alt="https://cdn.china-scratch.com/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/d8780/d8780530926e7867e51a5b4f5d2990a0916c1fcc" alt="https://cdn.china-scratch.com/timg/190820/11220W526-19.jpg"
3)切换到“事件”分类,添加一个积木
data:image/s3,"s3://crabby-images/bbe45/bbe456aefa152eaeb0d83f842ea8a2547f572631" alt="https://cdn.china-scratch.com/timg/190820/11220S316-20.jpg"
4)输入内容如下,注意设置积木类型为“事件”
data:image/s3,"s3://crabby-images/21978/21978b7c6b61aea456ab6204203a9c67a6039de6" alt="https://cdn.china-scratch.com/timg/190820/112210A63-21.jpg"
5)设置转码,点击“保存”
include: , , code: /*{$BRANCH}*/ // 这里 $BRANCH 指代的是与其拼接的积木的转码data:image/s3,"s3://crabby-images/21978/21978b7c6b61aea456ab6204203a9c67a6039de6" alt="https://cdn.china-scratch.com/timg/190820/1122105924-22.jpg"
8. 预览效果
1)点击页面右上角的“预览”
data:image/s3,"s3://crabby-images/21978/21978b7c6b61aea456ab6204203a9c67a6039de6" alt="https://cdn.china-scratch.com/timg/190820/1122103D6-23.jpg"
2)连接串口
data:image/s3,"s3://crabby-images/21978/21978b7c6b61aea456ab6204203a9c67a6039de6" alt="https://cdn.china-scratch.com/timg/190820/1122116492-24.jpg"
3)编辑积木如图所示,然后点击慧编程页面左下角的“上传到设备”
data:image/s3,"s3://crabby-images/21978/21978b7c6b61aea456ab6204203a9c67a6039de6" alt="https://cdn.china-scratch.com/timg/190820/112212K27-25.jpg"
data:image/s3,"s3://crabby-images/21978/21978b7c6b61aea456ab6204203a9c67a6039de6" alt="https://cdn.china-scratch.com/timg/190820/112213D63-26.jpg"
4)至此,Uno黄灯会闪烁10下,说明代码已上传成功!我们为慧编程增加了一个新扩展啦~
我们再来探讨一下:为什么我们选择使用积木块来封装代码呢?
封装成积木块的代码看起来更简单,尤其对于想通过编程提高逻辑能力的小朋友来说,只要识字,通过认识积木块并加以练习,就可以用积木块实现想要的功能,进而创作出动画、游戏还有控制机器人!
--end--
声明:本文章由网友投稿作为教育分享用途,如有侵权原作者可通过邮件及时和我们联系删除:freemanzk@qq.com