0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何在嵌入式設(shè)備拉起JavaScript應(yīng)用?

jf_NsPBt3VS ? 來源:風(fēng)火輪技術(shù)團隊 ? 2023-03-07 10:44 ? 次閱讀

概述

上一篇我們描述了為什么我們要使用膠水語言(JavaScript,PikaScript)來改變我們的嵌入式開發(fā)模式。并描述了如何在嵌入式設(shè)備拉起JavaScript應(yīng)用及JavaScript應(yīng)用在嵌入式設(shè)備的存在形式(字符串,文件)。

打破單片機開發(fā)模式--膠水語言(JavaScript)

膠水語言可以讓我們職責(zé)更加明確,可以類前后端開發(fā)模式,后端負(fù)責(zé)--硬件的適配,方法的導(dǎo)出;前端負(fù)責(zé)--業(yè)務(wù)邏輯的的開發(fā)。

本篇文章作者來介紹JS在嵌入式設(shè)備上的如何使用,我們通過一下幾點說明:

C端如何導(dǎo)出方法提供給到JS端;

C端如何導(dǎo)出參數(shù)提供給JS端;

通過C端導(dǎo)出方法,JS端控制LED燈;

在使用JerryScript引擎實現(xiàn)C端與JavaScript端交互時,許喲啊弄清楚幾個概念:

類型 說明
object 對象,JerryScript是基于對象編程的,所以我們導(dǎo)出的方法都是對象的基礎(chǔ)上的
property 特性,如導(dǎo)出的參數(shù),函數(shù)等,都屬于特性,歸屬于某個對象的特性
value 值,在JerryScript中,所有的對象,特性,參數(shù),方法,都會轉(zhuǎn)為一個32位的數(shù)值,然后我們通過這個數(shù)值便可以訪問對應(yīng)內(nèi)容

C端如何導(dǎo)出方法提供給到JS端

在JavaScript的引擎(JerryScript)中,提供了很多方法供我們實現(xiàn)C端與JS端的交互,C端導(dǎo)出模塊也是依賴這些方法的。

那么如何從C端導(dǎo)出方法呢???為了更好的演示,我們通過從C端導(dǎo)出一個日志打印方法提供給到JS應(yīng)用使用,并在JS應(yīng)用中驗證。

導(dǎo)出的方法我們需要遵從模板,其中我們要關(guān)注的參數(shù):

this_val:自身對象值。

args_p[]:JS調(diào)用導(dǎo)出方法接口時的參數(shù)列表。

args_count:JS調(diào)用導(dǎo)出方法接口時的參數(shù)個數(shù)。

typedefjerry_value_t(*jerry_external_handler_t)(constjerry_value_tfunction_obj,
constjerry_value_tthis_val,
constjerry_value_targs_p[],
constjerry_length_targs_count);

日志打印方法編寫(log_handle):

日志打印接口只需要一個輸入?yún)?shù),并且這個參數(shù)類型位字符串(string),所以我們只需要處理一個入?yún)ⅲ?/p>

前面我們已經(jīng)描述了:在JerryScript中,所有的對象,特性,參數(shù),方法,都會轉(zhuǎn)為一個32位的數(shù)值,所以我們需要將參數(shù)值解析出來;

通過jerry_value_to_string方法將args[0]轉(zhuǎn)為字符串?dāng)?shù)值(str_value);

通過jerry_string_to_utf8_char_buffer方法從字符串?dāng)?shù)值(str_value)獲取字符串內(nèi)容;

提取完數(shù)據(jù)之后,需要調(diào)用jerry_release_value方法,將字符串?dāng)?shù)值(str_value)資源釋放;

將提取的內(nèi)容打印出來;

staticjerry_value_tlog_handler(constjerry_value_tfunction_obj,
constjerry_value_tthis_val,
constjerry_value_targs[],
constjerry_length_targCount)
{
jerry_size_tlog_len=0;
jerry_value_tstr_value=jerry_value_to_string(args[0]);
log_len=jerry_string_to_utf8_char_buffer(str_value,log_buff,(LOG_BUFF_LEN-1));
log_buff[log_len]='?';
jerry_release_value(str_value);

rt_kprintf("%s
",(constchar*)log_buff);
returnjerry_create_undefined();
}

導(dǎo)出log_handle方法;

通過jerry_get_global_object方法獲取全局對象;

通過jerry_create_external_function創(chuàng)建外部函數(shù)(log_handle)對象;

我們提供給js應(yīng)用調(diào)用的方法,需要導(dǎo)出一個方法名(log),通過jerry_create_string_from_utf8方法創(chuàng)建一個字符串("log")對象;

通過jerry_set_property方法,導(dǎo)出一個名為log的方法;

導(dǎo)出完所有l(wèi)og方法之后,需要將其使用的對象值全部釋放;

staticvoidjs_func_init(void)
{
jerry_value_tglobal_object=jerry_get_global_object();

jerry_value_tfunc=jerry_create_external_function(log_handler);
jerry_value_tproperty_name_val=jerry_create_string_from_utf8((constjerry_char_t*)"log");
jerry_value_tresult_val=jerry_set_property(global_object,property_name_val,func);
jerry_release_value(property_name_val);
jerry_release_value(result_val);
jerry_release_value(func);
}

JS應(yīng)用,rice.js內(nèi)容如下:

varhello=123;

log("youyeetoo:"+hello);

運行結(jié)果:

7458f846-bc66-11ed-bfe3-dac502259ad0.png

C端如何導(dǎo)出參數(shù)提供給JS端

C語言開發(fā)中,我們往往會把一些固定不變的值采用宏去定義一些數(shù)值或者字符串,如:

#defineE_VALUE123
#defineE_STRING"youyeetoo"

對于JS應(yīng)用來說,實際也是需要一些固定不變的數(shù)值,所以我們可以通過C端導(dǎo)出一些固定數(shù)值到JS端,供JS應(yīng)用使用。

對于JerryScript來說,不管是數(shù)值還是字符串都是導(dǎo)出對應(yīng)特性,實例分別是導(dǎo)出:數(shù)值E_VALUE特性和字符串E_STRING:

通過jerry_get_global_object方法獲取全局對象;

通過jerry_create_number創(chuàng)建數(shù)值特性對象,通過jerry_create_string創(chuàng)建字符串特性對象;

我們提供給js應(yīng)用調(diào)用的方法,需要導(dǎo)出一個特性名字,通過jerry_create_string_from_utf8方法創(chuàng)建字符串對象(如:E_VALUE和E_STRING);

通過jerry_set_property方法,導(dǎo)出特性變量。

導(dǎo)出完特性變量之后,需要將其使用的對象值全部釋放。

staticvoidjs_num_param_init(void)
{
jerry_value_tglobal_object=jerry_get_global_object();

jerry_value_tnum_val=jerry_create_number(123);
jerry_value_tproperty_name_val=jerry_create_string_from_utf8((constjerry_char_t*)"E_VALUE");
jerry_value_tresult_val=jerry_set_property(global_object,property_name_val,num_val);
jerry_release_value(property_name_val);
jerry_release_value(result_val);
jerry_release_value(num_val);
}

staticvoidjs_str_param_init(void)
{
jerry_value_tglobal_object=jerry_get_global_object();

jerry_value_tstr_val=jerry_create_string("good");
jerry_value_tproperty_name_val=jerry_create_string_from_utf8((constjerry_char_t*)"E_STRING");
jerry_value_tresult_val=jerry_set_property(global_object,property_name_val,str_val);
jerry_release_value(property_name_val);
jerry_release_value(result_val);
jerry_release_value(str_val);
}

JS應(yīng)用,rice.js內(nèi)容如下:

log("youyeetoo:"+E_VALUE);
log("youyeetoo:"+E_STRING);

運行結(jié)果:

7496a6dc-bc66-11ed-bfe3-dac502259ad0.png

通過C端導(dǎo)出LED方法,JS端控制LED燈

我是用的板子有4個LED,分別接在PE3,PD7,PG3,PA5個引腳,我們需要對齊編號,如下:

#defineLED1_PINGET_PIN(E,3)
#defineLED2_PINGET_PIN(D,7)
#defineLED3_PINGET_PIN(G,3)
#defineLED4_PINGET_PIN(A,5)

staticuint16_tled_list[]={LED1_PIN,LED2_PIN,LED3_PIN,LED4_PIN};

led方法需要兩個參數(shù),第一個參數(shù)代表LED編號,第二個參數(shù)代表引腳電平,我們的導(dǎo)出接口名為:led,接口定義如下:

staticjerry_value_tled_handler(constjerry_value_tfunction_obj,
constjerry_value_tthis_val,
constjerry_value_targs[],
constjerry_length_targCount)
{
jerry_value_tled=jerry_get_number_value(args[0]);
jerry_value_tlevel=jerry_get_number_value(args[1]);

rt_pin_write(led_list[led],level);

returnjerry_create_undefined();
}

staticvoidjs_led_func_init(void)
{
jerry_value_tglobal_object=jerry_get_global_object();

jerry_value_tfunc=jerry_create_external_function(led_handler);
jerry_value_tproperty_name_val=jerry_create_string_from_utf8((constjerry_char_t*)"led");
jerry_value_tresult_val=jerry_set_property(global_object,property_name_val,func);
jerry_release_value(property_name_val);
jerry_release_value(result_val);
jerry_release_value(func);
}

JS應(yīng)用,將板子的四個LED點亮,rice.js內(nèi)容如下:

log("youyeetoo:"+E_VALUE);
log("youyeetoo:"+E_STRING);
led(0,1);
led(1,1);
led(2,1);
led(3,1);

運行結(jié)果:

74c9019a-bc66-11ed-bfe3-dac502259ad0.png

總結(jié)

C端導(dǎo)出方法之后,在JS端實際編寫程序是非常方便的,調(diào)用方式跟C語言編程一樣。

可以通過C導(dǎo)出固定參數(shù),使JS端調(diào)用起來像C端調(diào)用宏定義一樣。

我們可以通過C端導(dǎo)出硬件控制接口,使得JS應(yīng)用程序可以調(diào)用應(yīng)用接口。

當(dāng)C端的基礎(chǔ)能力編寫完畢之后,JS應(yīng)用程序?qū)嶋H跟C語言是基本一致的,而且JavaScript提供了很多方法,對于我們編寫業(yè)務(wù)邏輯更加友好。







審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5046

    文章

    18821

    瀏覽量

    298623
  • led燈
    +關(guān)注

    關(guān)注

    22

    文章

    1588

    瀏覽量

    107405
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7575

    瀏覽量

    134142
  • javascript
    +關(guān)注

    關(guān)注

    0

    文章

    515

    瀏覽量

    53658

原文標(biāo)題:嵌入式新開發(fā)模式(JavaScript)--C端與JS端方法調(diào)用

文章出處:【微信號:風(fēng)火輪技術(shù)團隊,微信公眾號:風(fēng)火輪技術(shù)團隊】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    何在嵌入式系統(tǒng)設(shè)計中使用UML技術(shù)

    嵌入式系統(tǒng)設(shè)計是一個軟、硬件結(jié)合的協(xié)同設(shè)計(Hardware/Software Co-design),需要不同技術(shù)背景的人共同開發(fā)。 本文將重點討論如何在嵌入式系統(tǒng)設(shè)計中使用 UML 技術(shù),并用車載 GPS 終端項目作為實例來具
    發(fā)表于 04-14 08:02 ?3796次閱讀
    如<b class='flag-5'>何在</b><b class='flag-5'>嵌入式</b>系統(tǒng)設(shè)計中使用UML技術(shù)

    嵌入式新開發(fā)模式(JavaScript)--C端與JS端方法調(diào)用

    ? 概述 上一篇我們描述了為什么我們要使用膠水語言(JavaScript,PikaScript)來改變我們的嵌入式開發(fā)模式。并描述了如何在嵌入式設(shè)備
    的頭像 發(fā)表于 04-06 15:39 ?770次閱讀

    嵌入式Linux下USB藍牙設(shè)備驅(qū)動

    技術(shù)的不斷發(fā)展,藍牙產(chǎn)品逐漸走入人們的生活。目前藍牙在PC端支持良好,應(yīng)用比較廣泛。但在嵌入式系統(tǒng)中,由于藍牙接口的兼容性問題,使其在嵌入式領(lǐng)域的應(yīng)用大打折扣。因此,如何在嵌入式系統(tǒng)中
    發(fā)表于 04-24 09:30

    WIFI網(wǎng)卡如何在嵌入式Linux中

    僅用于增加百度收錄權(quán)重,排版未優(yōu)化,日常不維護。請訪問: 查看、評論。本博文對應(yīng)地址: 嵌入式Linux——WIFI網(wǎng)卡/#more如何在嵌入式Linux中,使用WIFI無線網(wǎng)卡。嵌入式
    發(fā)表于 11-04 08:26

    嵌入式Linux設(shè)備何在運作

    點此進入原文鏈接,有視頻課程哦第一部分 嵌入式Linux簡介:首先,不知道大家知不知道嵌入式linux設(shè)備運行的話一般需要哪幾個組成模塊?一、嵌入式Linux
    發(fā)表于 11-05 09:26

    嵌入式設(shè)備中使用JavaScript

    只聽說過匯編,c做嵌入式,從不曾想JAVAScript也牛到涉入硬件領(lǐng)域了,原本對他的思維定格就是一個瀏覽器腳本??磥碚鎽?yīng)了那句話‘只有想不到,沒有做不到’話不多說看看這些大佬的帖子在嵌入式設(shè)
    發(fā)表于 11-08 06:14

    javascript嵌入式

    javascript嵌入式If expressions are single units of JavaScript that the engine can evaluate, statements
    發(fā)表于 12-15 07:36

    Caché嵌入式代碼分享

    文章目錄第十章 Caché 嵌入式代碼嵌入式HTML`&html`標(biāo)記語法嵌入式JavaScript嵌入式SQL第十章 Caché
    發(fā)表于 12-17 07:19

    何在嵌入式設(shè)備上運行高性能Java

    何在嵌入式設(shè)備上運行高性能Java
    發(fā)表于 03-28 09:43 ?16次下載

    嵌入式DHCP Server如何在vxWorks中

    嵌入式DHCP Server如何在vxWorks中的軟件實現(xiàn)
    發(fā)表于 03-29 12:27 ?23次下載

    何在嵌入式Linux中使用GPIO

    了解如何在嵌入式Linux中使用GPIO,特別強調(diào)Zynq-7000系列。 我們介紹了基本的用戶和內(nèi)核空間GPIO使用情況,以及GPIO,GPIO密鑰和GPIO LED上的bit-banged I / O.
    的頭像 發(fā)表于 11-26 07:02 ?3988次閱讀

    Facebook神經(jīng)網(wǎng)絡(luò)新研究將造福嵌入式設(shè)備

    人工智能風(fēng)暴襲來,機器人、自動駕駛汽車這樣的嵌入式設(shè)備也熱度漸長。毫無疑問,現(xiàn)在,嵌入式設(shè)備也需要高效的神經(jīng)網(wǎng)絡(luò)加持。但是,如何在
    發(fā)表于 08-07 11:27 ?690次閱讀
    Facebook神經(jīng)網(wǎng)絡(luò)新研究將造福<b class='flag-5'>嵌入式</b><b class='flag-5'>設(shè)備</b>

    未來之JavaScript嵌入式

    只聽說過匯編,c做嵌入式,從不曾想JAVAScript也牛到涉入硬件領(lǐng)域了,原本對他的思維定格就是一個瀏覽器腳本??磥碚鎽?yīng)了那句話‘只有想不到,沒有做不到’話不多說看看這些大佬的帖子在嵌入式設(shè)
    發(fā)表于 11-03 13:51 ?4次下載
    未來之<b class='flag-5'>JavaScript</b>做<b class='flag-5'>嵌入式</b>

    用于嵌入式設(shè)備JavaScript

      這些開發(fā)系統(tǒng)中的每一個都是在嵌入式設(shè)備上開始 JavaScript 開發(fā)的好工具。盡管 JavaScript 在近 20 年前首次引入,但它才剛剛開始用于
    的頭像 發(fā)表于 06-29 09:39 ?3404次閱讀
    用于<b class='flag-5'>嵌入式</b><b class='flag-5'>設(shè)備</b>的<b class='flag-5'>JavaScript</b>

    嵌入式javascript編譯器的設(shè)計與實現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《嵌入式javascript編譯器的設(shè)計與實現(xiàn).pdf》資料免費下載
    發(fā)表于 10-30 11:29 ?0次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>javascript</b>編譯器的設(shè)計與實現(xiàn)