找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 6863|回復(fù): 4
打印 上一主題 下一主題
收起左側(cè)

和嵌入式關(guān)聯(lián)的谷歌blockly圖形化編程的資料

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
工作需要編寫了一份谷歌的blockly圖形化編程的資料,內(nèi)附一份筆記,需要的可以參考一下,有疑問可以問我!


全部資料51hei下載地址(含清晰圖片與資料):
谷歌blockly圖形化編程資料內(nèi)附一份文檔.rar (1.06 MB, 下載次數(shù): 49)


工作驗(yàn)收中提到的問題:
(1)如何編寫blocky自定義塊(對應(yīng)自定義塊在blocky里面js的位置以及用法)。
(2)blocky自定義快如何跟pythonAPI里面的函數(shù)聯(lián)系起來。(3)如何編寫pythonAPI。(4)blocky塊生成的python文件是怎么樣一種機(jī)制(Browser.java這個(gè)類有什么作用)。(5)點(diǎn)擊執(zhí)行按鈕的時(shí)候,后臺做了什么操作(6)項(xiàng)目中Java是如何去調(diào)用python的,需要注意什么?(7)項(xiàng)目中pythonDemo.py有什么作用?個(gè)人總結(jié)對以上問題的回答:
前言
:以下內(nèi)容是我針對與上面驗(yàn)收問題的總結(jié)和回答,因某些地方文字描述可能不好表達(dá)出本意,所以會(huì)以截圖加上文字說明進(jìn)行概括,希望大家能將我所描述的以及圖中標(biāo)記的內(nèi)容或者文字仔細(xì)查看,避免漏掉一些細(xì)節(jié)以免造成困擾!
另外,因?yàn)閷Υa部分,個(gè)人理解有所不同,如果有說的不對的地方,或者理解錯(cuò)誤的地方,請指出并說明,萬分感謝!

(1)如何編寫blocky自定義塊(對應(yīng)自定義塊在blocky里面js的位置以及用法)。

編寫自定義塊,通常編寫一個(gè)自定義塊,首先是看BrobotAPI里面的分類里面是否需要定制一個(gè)自定義塊,根據(jù)給出的分類里面塊的描述,找到對應(yīng)的嵌入式端的接口,根據(jù)接口了解這個(gè)里面需要傳入哪些參數(shù),以及這個(gè)塊的作用,這樣就決定了這個(gè)塊長什么樣,需要傳幾個(gè)參數(shù),以及是手動(dòng)輸入值還是可以選擇值,或者兩者并存!   當(dāng)有了接口之后,我需要在E:\eclipse\workplace\BRobotAPP\pythonFile\blocklyAPI.py中將接口通過python語言進(jìn)行封裝, 例如下圖是對門型運(yùn)動(dòng)的接口的封裝

這個(gè)就是根據(jù)接口封裝的pythonAPI.py文件,當(dāng)中的每個(gè)語句我都有加以說明, 當(dāng)然其他的方法也都跟這類似,只是有的方法因?yàn)榭紤]到安全因素,需要在方法前面加上一系列的判斷,確保判斷條件通過后才能執(zhí)行方法

     有了pythonAPI.py封裝了方法,那么就可以編寫Blockly自定義塊了,編寫自定義塊是個(gè)比教麻煩的步驟,因?yàn)?/strong>Blockly是谷歌的一個(gè)插件,所以編輯Blockly塊就要用到谷歌封裝的工具了,這個(gè)工具是用谷歌瀏覽器打開E:\eclipse\workplace\BRobotAPP\blockly\googleDemo\blockly-master\demos\blockfactory\index.html這個(gè)頁面,通過這個(gè)頁面就可以編寫Blockly塊了!

上圖就是編輯一個(gè)自定義塊的頁面了,而塊就是這樣定義出來的,至于你希望塊長成什么樣,就完全靠圖中左側(cè)的代碼進(jìn)行調(diào)整, BrobotAPI中的每一個(gè)塊就是這樣定義出來的!
    而Blockly所對應(yīng)的js就是 E:\eclipse\workplace\BRobotAPP\blockly\googleDemo\blockly-master\tests\generators目錄下面的myBlockly.js 和myBlocklyPython.js文件了,  myBlockly.js中的文件是不需要改動(dòng)的,直接復(fù)制上圖中的右邊中間的那地方的代碼就行了, 就是這個(gè)圖片里的內(nèi)容

而myblocklyPython.js中的代碼就要改動(dòng)了,如圖

在所有的步驟完成后,還需要在index.html中添加上對應(yīng)的<Blockly>標(biāo)簽

這樣 一個(gè)完整的Blockly塊就編寫完成了!

(2)blocky自定義快如何跟pythonAPI里面的函數(shù)聯(lián)系起來。

這個(gè)Blockly塊跟pythonAPI里面函數(shù)的聯(lián)系就是在定義塊的時(shí)候

這個(gè)圖右下角對應(yīng)的就是myblocklyPython.js文件這個(gè)文件中的紅框里面就是對應(yīng)pythonAPI里面的方法了

對應(yīng)的通過Blockly頁面中的js方法會(huì)拼接成這樣的一個(gè)語句,也就是調(diào)用PythonAPI里面方法的語句,并且里面有參數(shù),你可以用這個(gè)語句和pythonAPI中的方法進(jìn)行對比!

(3)如何編寫pythonAPI。

編寫PythonAPI,是需要對照著為知筆記中的Brobot函數(shù)接口.md來進(jìn)行編寫,舉個(gè)例子就拿 向嵌入式端發(fā)送激光雕刻的圖片的路徑數(shù)據(jù) 這個(gè)接口來說吧 它的接口是

int SendEngravePathData(unsigned char laserlevel, unsigned char pathtype, float goalcoor[3])  

首先 int 是這個(gè)方法的返回值,

SendEngravePathData  這個(gè)是方法名

括號里面的是參數(shù) laserlevel 是表示激光功率的等級,它是char型,所以在pythonAPI中需要將它轉(zhuǎn)為char型

Pathtype  參數(shù)表示的是路徑的類型,也是char型,所以也需要將它轉(zhuǎn)為char型

goalcoor[3] 參數(shù)分別對應(yīng)的就是傳進(jìn)去的坐標(biāo)點(diǎn)X,Y,Z 因?yàn)樗且粋(gè)數(shù)組,所以我們寫pythonAPI時(shí)候需要將它轉(zhuǎn)成python語言的數(shù)組格式
下面就是pythonAPI中封裝的截圖

(4)blocky塊生成的python文件是怎么樣一種機(jī)制(Browser.java這個(gè)類有什么作用)。

event.js就是相關(guān)事件,這里面有很多事件,這個(gè)也是動(dòng)態(tài)產(chǎn)生python代碼和xml代碼的文件,其中alert()事件中時(shí)python代碼,confirm中時(shí)xml代碼confirm()事件,

Field_textinput.js中,鍵盤按下事件中,動(dòng)態(tài)生成python代碼和xml代碼。

這個(gè)是谷歌里面封裝的生成python文件的機(jī)制! 在工作頁面中我們選擇blockly塊生成python代碼,這里我們用到的是Browser.Java這個(gè)類里面定義的方法.

在這個(gè)類里面我們首先是需要通過絕對路徑獲得用戶目錄里面路徑


有了路徑之后我們需要拼接路徑加載index.html地址


下面是通過拼接生成python的頭文件


頭文件拼接完成后動(dòng)態(tài)獲取python的代碼,并創(chuàng)建python文件


這樣python文件就生成了.

Browser.java這個(gè)類有什么作用

這個(gè)類的作用. 主要作用就是上面介紹的通過io的讀取路徑,定義方法創(chuàng)建出python文件,然后定義里面的一些js響應(yīng)事件,生成項(xiàng)目的xml文件以及做一些關(guān)于用戶操作界面的彈窗和響應(yīng)

(5)點(diǎn)擊執(zhí)行按鈕的時(shí)候,后臺做了什么操作

點(diǎn)擊執(zhí)行按鈕時(shí)候,后臺先會(huì)判斷你是否連接機(jī)械臂,如果沒有連接,會(huì)提示請先連接機(jī)械臂,如果已經(jīng)連接則會(huì)判斷你當(dāng)前是否選擇了要運(yùn)行的demo,有了demo就可以加載到demo對應(yīng)的python腳本文件,并逐條運(yùn)行腳本中的python語句,在語句的前面因?yàn)槊織l都添加了一個(gè)判斷dll是否正確的判斷,如果BrobotCheck()中的腳本有問題的話則也會(huì)終止機(jī)械臂的操作,如果語句沒有錯(cuò)誤,則機(jī)械臂會(huì)按照腳本上的坐標(biāo)或者其他指令進(jìn)行運(yùn)動(dòng),直至完成最后一條指令,或者有人點(diǎn)擊了終止按鈕!

(6)項(xiàng)目中Java是如何去調(diào)用python的,需要注意什么?

Java中調(diào)用python,主要是通過在JavaCallPython.java類中調(diào)用cmd然后通過cmd執(zhí)行python代碼,所以如果想要執(zhí)行python代碼必須要安裝python環(huán)境


這其中需要注意的是首先需要配置好python的環(huán)境,其次就是Process pr = Runtime.getRuntime().exec("python " + url3); 這個(gè)當(dāng)中括號里面的python后面必須要加上一個(gè)空格, 其三就是url的路徑是要保證正確的,如果路徑錯(cuò)誤,或者找不到python文件的話那么肯定運(yùn)行會(huì)出現(xiàn)問題的

(7)項(xiàng)目中pythonDemo.py有什么作用?

我們項(xiàng)目中生成的文件為python.py文件,而pythonDemo.py文件是修改串口之后的pythonDemo文件,這個(gè)文件是我們Java調(diào)用cmd進(jìn)行加載的python腳本文件.


評分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:466111 發(fā)表于 2019-1-10 20:31 | 只看該作者
很好的例子
回復(fù)

使用道具 舉報(bào)

板凳
ID:572223 發(fā)表于 2019-6-25 23:39 | 只看該作者
真厲害,最近也在開始研究這個(gè),請問如何更換塊的ui外表的樣子?謝謝,還有附件能否發(fā)送一下給我?謝謝積分不夠無法下載學(xué)習(xí)3101331275@qq.com
回復(fù)

使用道具 舉報(bào)

地板
ID:689368 發(fā)表于 2020-2-11 20:48 | 只看該作者
最近想研究一下,謝謝分享
回復(fù)

使用道具 舉報(bào)

5#
ID:720913 發(fā)表于 2020-4-2 14:00 | 只看該作者
謝謝分享!
回復(fù)

使用道具 舉報(bào)

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表