在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

【產(chǎn)品應(yīng)用】用 AWTK 和 AWPLC 快速開發(fā)嵌入式應(yīng)用程序 (4)- 自定義功能塊(上)

ZLG致遠(yuǎn)電子 ? 2022-11-02 09:56 ? 次閱讀

AWPLC 是 ZLG 自主研發(fā)的 PLC 系統(tǒng)(兼容 IEC61131-3),本文用定時(shí)器為例介紹一下如何擴(kuò)展自定義功能塊。

d64143d8-578f-11ed-b116-dac502259ad0.jpg 背景

AWTK 全稱 Toolkit AnyWhere,是 ZLG 開發(fā)的開源 GUI 引擎,旨在為嵌入式系統(tǒng)、WEB、各種小程序、手機(jī)和 PC 打造的通用 GUI 引擎,為用戶提供一個(gè)功能強(qiáng)大、高效可靠、簡單易用、可輕松做出炫酷效果的 GUI 引擎。

AWPLC 是 ZLG 自主研發(fā)的 PLC 系統(tǒng)(兼容 IEC61131-3),其中 AWPLC 的運(yùn)行時(shí)庫(Runtime)基于 ZLG TKC 開發(fā),可以移植到到任何主流 RTOS嵌入式系統(tǒng)。AWPLC 的集成開發(fā)環(huán)境(IDE)基于 AWTK 開發(fā),可以運(yùn)行在 Windows、MacOS 和 Linux 系統(tǒng)之上。AWPLC 的主要目標(biāo)之一是把 PLC 中低代碼開發(fā)方法引入到嵌入式軟件,從而提高嵌入式軟件的開發(fā)效率和可靠性。

d64143d8-578f-11ed-b116-dac502259ad0.jpg 簡介

在前一篇文章中,我們說過,AWPLC 的重要特色之一就是高度可擴(kuò)展,而且會內(nèi)置 ZLG 多年在嵌入式系統(tǒng)開發(fā)中積累的功能塊,包括各種算法、協(xié)議和實(shí)用功能,這將大大簡化嵌入式軟件的開發(fā)。

那怎么去開發(fā)自定義的功能塊呢?本文以 ZTIMER 為例介紹一下開發(fā)自定義功能塊的方法。ZTIMER 是一個(gè)帶計(jì)數(shù)功能的定時(shí)器,在前一篇文章中,我們用它實(shí)現(xiàn)了一個(gè)走馬燈的演示,其使用方法如下:

d64dfbe6-578f-11ed-b116-dac502259ad0.png

在 AWPLC 中,自定義功能塊和內(nèi)置功能塊具有同等待遇,因?yàn)樗鼈兌际前赐瑯拥姆绞郊尤脒M(jìn)來的。在進(jìn)入正題前,我們先聊一下,系統(tǒng)的可擴(kuò)展性以及實(shí)現(xiàn)方法。1.可擴(kuò)展性的好處在設(shè)計(jì)一個(gè)復(fù)雜軟件的架構(gòu)時(shí),可擴(kuò)展性是必須考慮的因素。可擴(kuò)展性至少帶來以下幾個(gè)好處:

  • 可擴(kuò)展性將軟件的框架與具體的實(shí)現(xiàn)分離開來,有助于降低系統(tǒng)的復(fù)雜度。系統(tǒng)的復(fù)雜性太高,會帶來一系列的問題,比如讓可理解性、可維護(hù)性和可靠性的降低,很多項(xiàng)目因此陷入無法掙脫的焦油坑里,最后士氣低落,人員流失,項(xiàng)目取消,公司蒙受巨大損失。在設(shè)計(jì)復(fù)雜軟件時(shí),一定要存有敬畏之心;
  • 可擴(kuò)展性將軟件變化的部分隔離開來,不但可以讓擴(kuò)展的功能獨(dú)立變化,也可以方便的擴(kuò)展新功能。在 AWPLC 中,以后會擴(kuò)展各種協(xié)議和算法的功能塊,必須保證 AWPLC 框架和這些擴(kuò)展的功能塊是獨(dú)立的,才能讓開發(fā)工作順利進(jìn)行;
  • 可擴(kuò)展性有利于團(tuán)隊(duì)的協(xié)作。不同的通訊協(xié)議和算法,需要不同團(tuán)隊(duì)的專家去開發(fā),可擴(kuò)展性讓大家只要按相應(yīng)的接口去實(shí)現(xiàn),就可以方便的集成起來,不需要太多跨團(tuán)隊(duì)的交互。

2.如何保證可擴(kuò)展性

讓軟件系統(tǒng)具有可擴(kuò)展性,通常并不是什么難事,只要做到下面兩點(diǎn)就可以了:

  • 針對接口編程。這個(gè)是大家都知道的,在《軟件設(shè)計(jì)模式》等書里,都反復(fù)強(qiáng)調(diào)了,這里不再贅述;
  • 利用工廠模式隔離組件的創(chuàng)建。工廠模式也是人人都知道的,而且大家都覺得很"簡單"。但是能把工廠模式用好的程序員其實(shí)并不多見,一個(gè)主要原因就是很多人只會套用《軟件設(shè)計(jì)模式》的工廠模式,而《軟件設(shè)計(jì)模式》里幾個(gè)工廠模式在現(xiàn)實(shí)中并不實(shí)用。利用這些這些工廠模式,無法滿足 SOLID 原則中的開放封閉原則,增加一個(gè)新的擴(kuò)展時(shí),仍然需要修改對應(yīng)的工廠。

d64143d8-578f-11ed-b116-dac502259ad0.jpg AWPLC功能塊的接口

要讓 AWPLC 支持?jǐn)U展各種自定義的功能塊,首要條件條件是定義好功能塊的接口。

1.功能塊的基類在面向?qū)ο蟮?C 語言編程中,我們用結(jié)構(gòu)(struct)來模擬類和接口。這里所說的接口是廣義的接口,而不是 C++或其它語言中只包含純虛函數(shù)的 interface,因?yàn)槌颂摵瘮?shù)指針外,這里還有一些數(shù)據(jù)成員。

/**
*@classaw_plc_fb_t
* AWPLC 功能塊接口。
*/
struct_aw_plc_fb_t{
/**
*@property{bool_t}en
*是否啟用。
*/
uint8_ten:1;
/**
*@property{bool_t}eno
*是否啟用輸出。
*/
uint8_teno:1;

/*private*/
constaw_plc_fb_vtable_t*vt;

};

2.功能塊的虛函數(shù)

在功能塊的虛函數(shù)表中,還定義了一些描述性的常量,讓對象具有一點(diǎn)反射的能力,方便在運(yùn)行時(shí)查詢它的一些狀態(tài)。順便說一下,在定義接口的虛函數(shù)時(shí),通常不會有創(chuàng)建函數(shù),因?yàn)閯?chuàng)建之前對象之前,是拿不到這個(gè)虛表對象的。但也不是絕對的,有時(shí)為了方便 clone,也可能提供一個(gè) clone 函數(shù)或者 create 函數(shù)。

任何接口都要定義析構(gòu)函數(shù)(destroy),在對象需要銷毀時(shí),框架可以以統(tǒng)一的方式銷毀它。

typedefstruct_aw_plc_fb_vtable_t{
/*功能塊的類型名*/
constchar*type;
/*輸入參數(shù)名稱列表,以NULL結(jié)束的字符串?dāng)?shù)組*/
constchar*const*ins;
/*輸出參數(shù)名稱列表,以NULL結(jié)束的字符串?dāng)?shù)組*/
constchar*const*outs;
/*輸入輸出參數(shù)名稱列表,以NULL結(jié)束的字符串?dāng)?shù)組*/
constchar*const*in_outs;
/*執(zhí)行函數(shù)*/
aw_plc_fb_exec_texec;
/*執(zhí)行函數(shù)(帶參數(shù))*/
aw_plc_fb_exec_ex_texec_ex;
/*獲取屬性(輸入輸出參數(shù))的值*/
aw_plc_fb_get_prop_tget_prop;
/*獲取輸出的值*/
aw_plc_fb_get_output_tget_output;
/*設(shè)置輸出的值*/
aw_plc_fb_set_input_tset_input;
/*析構(gòu)函數(shù)*/
aw_plc_fb_destroy_tdestroy;

}aw_plc_fb_vtable_t;

* 這個(gè)虛函數(shù)表和 AWTK/TKC 中的 object 虛函數(shù)表很相似,考慮到 object 為了做得通用,有點(diǎn)臃腫了,所以決定重新定義一套。


d64143d8-578f-11ed-b116-dac502259ad0.jpg AWPLC功能塊的工廠

前面我們說過,可擴(kuò)展性除了針對接口編程外,離不開工廠模式的支持。功能塊的工廠其任務(wù)當(dāng)然是創(chuàng)建功能塊了,所以提供了一個(gè)創(chuàng)建功能塊的函數(shù)。參數(shù) type 指定功能塊的類型,函數(shù)返回對應(yīng)類型的功能塊:

/**
*@methodaw_plc_fb_factory_create_fb
*創(chuàng)建 fb。
*@param {const char*} type 類型。
*
*@return {aw_plc_fb_t*}返回 fb 對象。
*/

aw_plc_fb_t*aw_plc_fb_factory_create_fb(constchar*type);

有了這個(gè)創(chuàng)建函數(shù),確實(shí)把創(chuàng)建任務(wù)與功能塊的實(shí)現(xiàn)分開了。但是請想一下,如果每次增加新的功能塊,都要修改這個(gè)創(chuàng)建函數(shù),而這個(gè)函數(shù)又屬于框架的一部分,框架是不是還是依賴于具體實(shí)現(xiàn)了呢?為了解決這個(gè)問題,我們需要提供一種注冊機(jī)制來實(shí)現(xiàn)依賴倒置,讓功能塊的實(shí)現(xiàn)者主動將創(chuàng)建函數(shù)注冊進(jìn)來:

/**
*@methodaw_plc_fb_factory_register
*注冊創(chuàng)建函數(shù)。
*@param {const char*} type 類型。
*@param {aw_plc_fb_create_t} create 創(chuàng)建函數(shù)。
*
*@return {ret_t}返回 RET_OK 表示成功,否則表示失敗。
*/

ret_taw_plc_fb_factory_register(constchar*type,aw_plc_fb_create_tcreate);

這種機(jī)制非常好用,真正滿足了 SOLID 原則中的開放封閉原則(OCP):擴(kuò)展新的功能無需修改框架代碼。在 ZLG 開源 GUI 引擎中,也大量使用了這種帶注冊功能的工廠模式,有興趣的朋友可以去看看 AWTK 的代碼。


d64143d8-578f-11ed-b116-dac502259ad0.jpg ZTIMER

前面我們說過,可擴(kuò)展性除了針對接口編程外,離不開工廠模式的支持。功能塊的工廠其任務(wù)當(dāng)然是創(chuàng)建功能塊了,所以提供了一個(gè)創(chuàng)建功能塊的函數(shù)。參數(shù) type 指定功能塊的類型,函數(shù)返回對應(yīng)類型的功能塊:

1.ZTIMER的結(jié)構(gòu)

在 C 語言中,一般用結(jié)構(gòu)來模擬類,把基類作為結(jié)構(gòu)的第一個(gè)成員來模擬繼承。這里必須讓 aw_plc_fb_t 作為 aw_plc_fb_ztimer_t 的第一個(gè)成員。

/**
*@classaw_plc_fb_ztimer_t
*@parentaw_plc_fb_t
*@annotation["fb"]
*循環(huán)定時(shí)器。
*
*>當(dāng)輸入 IN 為 TRUE 時(shí),開始計(jì)時(shí),輸出 Q 為 FALSE,ET 開始記錄過去的時(shí)間。
*>定時(shí)時(shí)間到時(shí),COUNT 增加 1,輸出 Q 在本次循環(huán)為 TRUE,ET 重置為0。
*>輸入 IN 為 FALSE 時(shí)重置定時(shí)器。
*/
typedefstruct_aw_plc_fb_ztimer_t{
aw_plc_fb_tfb;

/**
*@property{bool_t}in
*@annotation["in"]
*為 TRUE 開始計(jì)時(shí),為 FALSE 時(shí)重置定時(shí)器。
*/
bool_tin:1;

/**
*@property{iec_time_t}pt
*@annotation["in"]
*預(yù)設(shè)時(shí)間(ms)。
*/
iec_time_tpt;

...

}aw_plc_fb_ztimer_t;

這里的 API 注釋采用了 AWTK 中定義的格式,但是對 annotation 做了一點(diǎn)擴(kuò)展,增加了 3 個(gè)新的取值:

fb 表示這是一個(gè)功能塊;

in 表示這是一個(gè)輸入?yún)?shù);

out 表示這是一個(gè)輸出參數(shù)。

2.ZTIMER的實(shí)現(xiàn)

每個(gè)功能塊必須提供虛函數(shù)表中定義的函數(shù),不過主要代碼集中 exec 函數(shù)里(其它函數(shù)可以自動生成出來):

staticret_taw_plc_fb_ztimer_exec(aw_plc_fb_t*fb){
aw_plc_fb_ztimer_t*ztimer=AW_PLC_FB_ZTIMER(fb);

if(aw_plc_fb_before_exec(fb)==RET_OK){
ztimer->current_time=aw_plc_now_ms();
if(ztimer->state==0&&!ztimer->prev_in&&ztimer->in){
ztimer->state=1;
ztimer->q=FALSE;

ztimer->et=0;
ztimer->count=0;
ztimer->start_time=ztimer->current_time;
}else{
if(!ztimer->in){
ztimer->q=FALSE;
ztimer->state=0;

ztimer->et=0;
ztimer->count=0;
ztimer->start_time=ztimer->current_time;
}elseif(ztimer->state==1){
if((ztimer->start_time+ztimer->pt)<=?ztimer->current_time){
ztimer->q=TRUE;

ztimer->et=0;
ztimer->count++;
ztimer->start_time=ztimer->current_time;
}else{
ztimer->q=FALSE;
ztimer->et=ztimer->current_time-ztimer->start_time;
}
}
}
ztimer->prev_in=ztimer->in;
}

returnRET_OK;

}

3.注冊ZTIMER

功能塊需要注冊到前面介紹的功能塊工廠:

aw_plc_fb_factory_register(AW_PLC_FB_TYPE_ZTIMER,aw_plc_fb_ztimer_create);

坦白的講,本文只是介紹了實(shí)現(xiàn)自定義功能塊的關(guān)鍵步驟,實(shí)際工作要麻煩很多。如果手工去做這些工作,開發(fā)一個(gè)功能塊還覺得好玩,而開發(fā)幾十個(gè)甚至幾百個(gè)功能塊,人不會變瘋就會變傻。下一篇文章會我們介紹一下,如何用代碼生成器來完成這些單調(diào)的工作,讓開發(fā)自定義功能塊成為一項(xiàng)快樂的工作。

AWPLC 目前還處于開發(fā)階段的早期,寫這個(gè)系列文章的目的,除了用來驗(yàn)證目前所做的工作外,還希望得到大家的指點(diǎn)和反饋。如果您有任何疑問和建議,請?jiān)谠u論區(qū)留言。

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

    關(guān)注

    5094

    文章

    19178

    瀏覽量

    307733
收藏 人收藏

    評論

    相關(guān)推薦

    AWTK-WEB 快速入門(4) - JS Http 應(yīng)用程序

    導(dǎo)讀XMLHttpRequest改變了Web應(yīng)用程序與服務(wù)器交換數(shù)據(jù)的方式,fetch是其繼任者。本文介紹一下如何使用JS語言開發(fā)AWTK-WEB應(yīng)用程序,并用fetch訪問遠(yuǎn)程數(shù)據(jù)。
    的頭像 發(fā)表于 01-22 11:31 ?127次閱讀
    <b class='flag-5'>AWTK</b>-WEB <b class='flag-5'>快速</b>入門(<b class='flag-5'>4</b>) - JS Http <b class='flag-5'>應(yīng)用程序</b>

    自定義Modbus通信指令的搭建教程

    和歐姆龍E5EZ的智能溫控儀表作為從站為例,為大家分享如何使用自定義的Modbus RTU的通信程序,來實(shí)現(xiàn)快速高效的Modbus通信程序
    的頭像 發(fā)表于 01-20 10:37 ?384次閱讀
    <b class='flag-5'>自定義</b>Modbus通信<b class='flag-5'>塊</b>指令的搭建教程

    AWTK-WEB 快速入門(2) - JS 應(yīng)用程序

    導(dǎo)讀AWTK可以使用相同的技術(shù)棧開發(fā)各種平臺的應(yīng)用程序。有時(shí)我們需要使用Web界面與設(shè)備進(jìn)行交互,本文介紹一下如何使用JS語言開發(fā)AWTK-
    的頭像 發(fā)表于 12-05 01:04 ?155次閱讀
    <b class='flag-5'>AWTK</b>-WEB <b class='flag-5'>快速</b>入門(2) - JS <b class='flag-5'>應(yīng)用程序</b>

    AWTK-WEB 快速入門(1) - C 語言應(yīng)用程序

    導(dǎo)讀AWTK可以使用相同的技術(shù)棧開發(fā)各種平臺的應(yīng)用程序。有時(shí)我們需要使用Web界面與設(shè)備進(jìn)行交互,本文介紹一下如何使用C語言開發(fā)AWTK-W
    的頭像 發(fā)表于 11-27 11:46 ?294次閱讀
    <b class='flag-5'>AWTK</b>-WEB <b class='flag-5'>快速</b>入門(1) - C 語言<b class='flag-5'>應(yīng)用程序</b>

    TPS659xx應(yīng)用程序自定義工具

    電子發(fā)燒友網(wǎng)站提供《TPS659xx應(yīng)用程序自定義工具.pdf》資料免費(fèi)下載
    發(fā)表于 11-06 10:02 ?0次下載
    TPS659xx<b class='flag-5'>應(yīng)用程序</b><b class='flag-5'>自定義</b>工具

    創(chuàng)建自定義的基于閃存的引導(dǎo)加載程序(BSL)

    電子發(fā)燒友網(wǎng)站提供《創(chuàng)建自定義的基于閃存的引導(dǎo)加載程序(BSL).pdf》資料免費(fèi)下載
    發(fā)表于 09-19 10:50 ?0次下載
    創(chuàng)建<b class='flag-5'>自定義</b>的基于閃存的引導(dǎo)加載<b class='flag-5'>程序</b>(BSL)

    七大嵌入式GUI盤點(diǎn)

    采用純C語言開發(fā)。它的作者是來自匈牙利的Gabor Kiss-Vamosikisvegabor,LVGLC語言編寫,以實(shí)現(xiàn)最大的兼容性(與C++兼容),模擬器可在沒有嵌入式硬件的PC
    發(fā)表于 09-02 10:58

    AWTK使用經(jīng)驗(yàn)】如何響應(yīng)物理按鍵

    AWTK是基于C語言開發(fā)的跨平臺GUI框架。《AWTK使用經(jīng)驗(yàn)》系列文章將介紹開發(fā)AWTK過程中一些常見問題與解決方案,例如:如何加載外部資
    的頭像 發(fā)表于 06-06 08:25 ?860次閱讀
    【<b class='flag-5'>AWTK</b>使用經(jīng)驗(yàn)】如何響應(yīng)物理按鍵

    AWTK使用經(jīng)驗(yàn)】如何自定義combo_box下拉框樣式

    AWTK是基于C語言開發(fā)的跨平臺GUI框架。《AWTK使用經(jīng)驗(yàn)》系列文章將介紹開發(fā)AWTK過程中一些常見問題與解決方案,例如:如何加載外部資
    的頭像 發(fā)表于 05-23 08:25 ?525次閱讀
    【<b class='flag-5'>AWTK</b>使用經(jīng)驗(yàn)】如何<b class='flag-5'>自定義</b>combo_box下拉框樣式

    HarmonyOS開發(fā)案例:【 自定義彈窗】

    基于ArkTS的聲明開發(fā)范式實(shí)現(xiàn)了三種不同的彈窗,第一種直接使用公共組件,后兩種使用CustomDialogController實(shí)現(xiàn)自定義彈窗
    的頭像 發(fā)表于 05-16 18:18 ?1460次閱讀
    HarmonyOS<b class='flag-5'>開發(fā)</b>案例:【 <b class='flag-5'>自定義</b>彈窗】

    AWTK 開源串口屏開發(fā)(18) - C 語言自定義命令

    如果AWTK-HMI內(nèi)置模型無法滿足需求,可以使用C語言來擴(kuò)展默認(rèn)模型。本文通過一個(gè)簡單的例子,介紹一下C語言擴(kuò)展默認(rèn)模型的方法。AWTK-HMI內(nèi)置了不少模型,利用這些模型開發(fā)
    的頭像 發(fā)表于 05-11 08:24 ?488次閱讀
    <b class='flag-5'>AWTK</b> 開源串口屏<b class='flag-5'>開發(fā)</b>(18) - <b class='flag-5'>用</b> C 語言<b class='flag-5'>自定義</b>命令

    HarmonyOS實(shí)戰(zhàn)開發(fā)-深度探索與打造個(gè)性化自定義組件

    ,容器組件,媒體組件,繪制組件,畫布組件組件等,如Button、Text 是基礎(chǔ)組件。 由開發(fā)者在基礎(chǔ)組件基礎(chǔ) 添加一些封裝和修飾 定義的組件稱為自定義組件。
    發(fā)表于 05-08 16:30

    HarmonyOS開發(fā)實(shí)例:【自定義Emitter】

    使用[Emitter]實(shí)現(xiàn)事件的訂閱和發(fā)布,使用[自定義彈窗]設(shè)置廣告信息。
    的頭像 發(fā)表于 04-14 11:37 ?1061次閱讀
    HarmonyOS<b class='flag-5'>開發(fā)</b>實(shí)例:【<b class='flag-5'>自定義</b>Emitter】

    鴻蒙ArkUI實(shí)例:【自定義組件】

    組件是 OpenHarmony 頁面最小顯示單元,一個(gè)頁面可由多個(gè)組件組合而成,也可只由一個(gè)組件組合而成,這些組件可以是ArkUI開發(fā)框架自帶系統(tǒng)組件,比如?`Text`?、?`Button`?等,也可以是自定義組件,本節(jié)筆者簡單介紹一下
    的頭像 發(fā)表于 04-08 10:17 ?710次閱讀

    【從0開始創(chuàng)建AWTK應(yīng)用程序】編譯應(yīng)用到RTOS平臺

    AWTK是基于C語言開發(fā)的跨平臺GUI框架。本系列文章介紹如何從0開始創(chuàng)建AWTK應(yīng)用程序,包括搭建開發(fā)調(diào)試環(huán)境、使用
    的頭像 發(fā)表于 03-21 08:23 ?677次閱讀
    【從0開始創(chuàng)建<b class='flag-5'>AWTK</b><b class='flag-5'>應(yīng)用程序</b>】編譯應(yīng)用到RTOS平臺
    主站蜘蛛池模板: 热re99久久国产精品 | 变态重口极致另类在线 | 免费国产网站 | 午夜老湿影院 | 快乐你懂的在线视频免费观看 | 天天玩夜夜操 | 中文天堂最新版在线精品 | 欧美午夜在线播放 | 欧美地区一二三区 | 亚洲狠狠婷婷综合久久久久图片 | 第四色激情网 | 欧美mv日韩mv国产mv网站 | 黄网站播放 | 91国内在线观看 | 亚洲夂夂婷婷色拍ww47 | 2021国产成人午夜精品 | 男人的视频网站 | 国产精品毛片久久久久久久 | 一级黄色毛毛片 | 国产精品久久永久免费 | 成人a毛片免费全部播放 | www.夜夜爽 | 99热精品久久只有精品30 | 国产精品久久久久久影院 | 国产专区青青草原亚洲 | 久久天天躁综合夜夜黑人鲁色 | 久久国产色 | 国产精品va一区二区三区 | 一级黄色片在线看 | 亚洲成a人片在线观看88 | 免费看色视频 | 亚洲一区二区免费看 | 色综合五月婷婷 | 亚洲资源在线视频 | 亚洲天天操 | 特级aaa片毛片免费观看 | 你懂的视频在线观看资源 | 久久久久亚洲香蕉网 | 日韩福利一区 | 射久久 | 一级欧美一级日韩 |