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

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

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

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

【產(chǎn)品應(yīng)用】用 AWTK 和 AWPLC 快速開(kāi)發(fā)嵌入式應(yīng)用程序 (9)- 模塊化

AGk5_ZLG_zhiyua ? 來(lái)源:未知 ? 2022-12-07 11:40 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

AWPLC 為模塊化編程提供了良好支持,本文以簡(jiǎn)化版的紅綠燈為例,把狀態(tài)轉(zhuǎn)換邏輯封裝成獨(dú)立的功能塊,演示了AWPLC模塊化編程的基本方法。


背景

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

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

簡(jiǎn)介

模塊化思維是每個(gè)程序員必備的技能。模塊化說(shuō)起來(lái)也很簡(jiǎn)單,就是把一組相關(guān)的東西封裝起來(lái),使用者只能通過(guò)接口去訪(fǎng)問(wèn)模塊的功能。模塊是一個(gè)抽象的東西,可大可小,大模塊可以分成稍小的模塊,稍小的模塊可以繼續(xù)細(xì)分成更小的模塊,具體細(xì)分到什么程度,要看個(gè)人習(xí)慣和具體情況。

高內(nèi)聚低耦合是每個(gè)模塊必備的品質(zhì)。高內(nèi)聚是說(shuō),只把功能強(qiáng)相關(guān)的東西放到一個(gè)模塊內(nèi),不要把關(guān)系不大或者不相關(guān)的東西放在一起。低耦合是說(shuō),模塊之間的關(guān)系松散,各自獨(dú)立變化,而互相不影響。當(dāng)然這是理想的情況,是大多數(shù)情況下應(yīng)該遵循的基本原則,真實(shí)場(chǎng)景中可以根據(jù)具體情況做些取舍。

模塊化的主要目的有兩個(gè):

  • 降低系統(tǒng)復(fù)雜度。在進(jìn)行軟件架構(gòu)設(shè)計(jì)時(shí),我們需要對(duì)一個(gè)復(fù)雜的系統(tǒng)分解,把系統(tǒng)分解成一些大模塊,把大模塊分解成小模塊。如果拆分得當(dāng),模塊具有良好的封裝,理解了模塊的接口,就理解了整個(gè)模塊,這就降低了系統(tǒng)的復(fù)雜度。此時(shí)模塊化是一種自頂向下的行為。

  • 重用。在進(jìn)行軟件開(kāi)發(fā)時(shí),我們發(fā)現(xiàn)一個(gè)功能在多個(gè)地方用到,就它做成一個(gè)公共函數(shù),或者提取成一個(gè)類(lèi),這也是模塊化。此時(shí)模塊化是一種自底向上的行為。通過(guò)重用,可以減少重復(fù)開(kāi)發(fā)帶來(lái)的工作量,也可以減少重復(fù)代碼后期的維護(hù)工作。

AWPLC 是一個(gè)低代碼開(kāi)發(fā)環(huán)境,個(gè)人認(rèn)為低代碼開(kāi)發(fā)的核心要素有三個(gè),它們都與模塊化息息相關(guān):

  • 組件標(biāo)準(zhǔn)化。各種功能和算法都按照統(tǒng)一的方式封裝成組件(模塊)。

  • 重用可視化。通過(guò)拖拽把各個(gè)組件組合到一起,就可以實(shí)現(xiàn)需要的功能。

  • 應(yīng)用模版化。把一些常用的應(yīng)用程序做成模版,開(kāi)發(fā)者可以根據(jù)自己的需要進(jìn)行定制。

由此可見(jiàn),與傳統(tǒng)的嵌入式開(kāi)發(fā)相比,AWPLC 為模塊化提供了更好的支持。

紅綠燈示例

之前我們用以一個(gè)簡(jiǎn)化版的紅綠燈為例,演示在 AWPLC 中實(shí)現(xiàn)狀態(tài)機(jī)的方法。在這個(gè)例子的功能塊圖里,三個(gè)狀態(tài)的邏輯基本上是一樣的,同樣的邏輯重復(fù)兩次,我們還可以忍耐,如果重復(fù)十次,那就讓人抓狂了。本文我們還是用這個(gè)例子,把狀態(tài)轉(zhuǎn)換的邏輯封裝成一個(gè)功能塊,讓這個(gè)應(yīng)用更好理解和維護(hù)。

在采用狀態(tài)機(jī)模式設(shè)計(jì)時(shí),一般按照下列步驟進(jìn)行:

  • 確定系統(tǒng)存在的狀態(tài),并選取我們關(guān)注的狀態(tài)。比如,在本系統(tǒng)中,我們選取紅燈、黃燈、綠燈三個(gè)狀態(tài)。
  • 確定在各個(gè)狀態(tài)下系統(tǒng)的行為。比如,在本系統(tǒng)中,在紅燈狀態(tài)下,點(diǎn)亮紅色 LED 燈;在黃燈狀態(tài)下,點(diǎn)亮黃色 LED 燈;在綠燈狀態(tài)下,點(diǎn)亮綠色 LED 燈。
  • 確定各個(gè)狀態(tài)之間轉(zhuǎn)換的條件。比如,在本系統(tǒng)中,在紅燈狀態(tài)下,超時(shí)進(jìn)入黃燈狀態(tài)下;在黃燈狀態(tài)下,超時(shí)進(jìn)入綠燈狀態(tài)下;在綠燈狀態(tài)下,超時(shí)進(jìn)入紅燈狀態(tài)下。

狀態(tài)轉(zhuǎn)換如下圖所示:

1. 系統(tǒng)組成

該系統(tǒng)包括:
  • 3 個(gè) LED。
2.軟件模擬
  • LED 都用軟件模擬。

PLC程序

1.變量定義

1.1全局變量

通常是不提倡使用全局變量的,這會(huì)造成一些不必要的耦合。不過(guò)有時(shí)善用全局變量,可以減小開(kāi)發(fā)工作量,需要根據(jù)情況進(jìn)行取舍。

這里我們把狀態(tài)變量 STATE 定義成全局的,方便在主程序和狀態(tài)轉(zhuǎn)換的功能塊(STATE_TRANS)里共用。

1.2主程序的變量

在主程序中,需要定義幾個(gè)變量:

  • STATE_RED 表示紅色狀態(tài),是一個(gè)常量,取值為 1。

  • STATE_YELLOW 表示黃色狀態(tài),是一個(gè)常量,取值為 2。

  • STATE_GREEN 表示綠色狀態(tài),是一個(gè)常量,取值為 3。

  • STATE 表示系統(tǒng)當(dāng)前的狀態(tài)(引用全局變量)。

  • LED_RED 表示紅色 LED 燈,映射到第 1 個(gè)數(shù)字輸出。

  • LED_YELLOW 表示黃色 LED 燈,映射到第 2 個(gè)數(shù)字輸出。

  • LED_GREEN 表示綠色 LED 燈,映射到第 3 個(gè)數(shù)字輸出。

具體配置如下圖所示:
1.3功能塊(STATE_TRANS)的變量
在 IEC 61131-3 中,把功能塊的變量定義稱(chēng)為接口(interface),倒也是挺恰當(dāng)?shù)模鼈兇_實(shí)是與其它功能塊交互的接口。
在設(shè)計(jì)功能塊時(shí),首先要搞清楚哪些部分是變化的,哪些是不變的。不變的部分固化到功能塊內(nèi)部,變化的部分提取為輸入?yún)?shù)。

在這里我們需要定義幾個(gè)變量:

  • STATE 表示系統(tǒng)當(dāng)前的狀態(tài)(引用全局變量)。

  • CURRENT_STATE 當(dāng)前的狀態(tài)。

  • NEXT_STATE 下一個(gè)狀態(tài)。

  • TIMEOUT 超時(shí)的時(shí)間。

  • LED 是否點(diǎn)亮當(dāng)前狀態(tài)對(duì)應(yīng)的燈。

具體配置如下圖所示:

2.功能塊圖

基本工作原理

  • 如果系統(tǒng)當(dāng)前狀態(tài) STATE 等于 STATE_RED 時(shí),表明當(dāng)前處于紅燈狀態(tài):點(diǎn)亮紅色 LED 燈,定時(shí)器保持工作,當(dāng)定時(shí)器超時(shí),設(shè)置系統(tǒng)當(dāng)前狀態(tài)為黃燈狀態(tài)。

  • 如果系統(tǒng)當(dāng)前狀態(tài) STATE 等于 STATE_YELLOW 時(shí),表明當(dāng)前處于黃燈狀態(tài):點(diǎn)亮黃色 LED 燈,定時(shí)器保持工作,當(dāng)定時(shí)器超時(shí),設(shè)置系統(tǒng)當(dāng)前狀態(tài)為綠燈狀態(tài)。

  • 如果系統(tǒng)當(dāng)前狀態(tài) STATE 等于 STATE_GREEN 時(shí),表明當(dāng)前處于綠燈狀態(tài):點(diǎn)亮綠色 LED 燈,定時(shí)器保持工作,當(dāng)定時(shí)器超時(shí),設(shè)置系統(tǒng)當(dāng)前狀態(tài)為綠燈狀態(tài)。

主程序的具體實(shí)現(xiàn)如下圖所示:

功能塊(STATE_TRANS)的具體實(shí)現(xiàn)如下圖所示:
* 值得注意的是,這里使用了功能塊 MOVE 對(duì)變量進(jìn)行賦值。按道理來(lái)說(shuō),對(duì)變量進(jìn)行賦值,直接拉根線(xiàn)連接起來(lái)就可以了,為什么還要加個(gè) MOVE 呢?原因在于,這里是條件賦值,即在定時(shí)器超時(shí)的時(shí)候,才對(duì) STATE 進(jìn)行賦值。
* 這就需要利用功能的執(zhí)行控制(Execution Control),當(dāng)功能塊啟用執(zhí)行控制(Execution Control)時(shí),只有其輸入引腳 EN 為 TRUE 時(shí),其后續(xù)賦值才生效。

用戶(hù)界面

應(yīng)用程序不需要編程,用 AWTK Designer 設(shè)計(jì)好界面,將控件與模型進(jìn)行綁定即可。下面介紹一下控件與模型的綁定方法。這里用的是 AWTK-MVVM,數(shù)據(jù)綁定規(guī)則與 AWTK-MVVM 是完全一樣的。
模型可以用 io、plc 或者 io+plc。io 可以用來(lái)綁定 IO 變量,plc 可以用來(lái)綁定程序 PLC 內(nèi)部變量。
示例:

由于符號(hào)%在程序里具有特殊功能,所以在綁定 IO 變量時(shí),把%換成_。比如:將%QX0.0寫(xiě)作_QX0.0。

示例:

children_layout="default(r=3,c=1,s=10)">

程序界面如下所示(為了方便理解,我們把功能塊圖也放到了界面上):
運(yùn)行效果:系統(tǒng)啟動(dòng)后,三個(gè) LED 燈循環(huán)點(diǎn)亮,和跑馬燈不同的是,三個(gè) LED 點(diǎn)亮的時(shí)間并不完全相同。

*由此可見(jiàn),在 AWPLC 功能塊圖的幫助下,我們不要寫(xiě) C 代碼或腳本,即可完成應(yīng)用程序的開(kāi)發(fā)。AWPLC 用低代碼降低了開(kāi)發(fā)的門(mén)檻,提高了開(kāi)發(fā)的效率。AWPLC 等您來(lái)玩!

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

【版權(quán)聲明】本文為ZLG開(kāi)發(fā)者社區(qū)用戶(hù)原創(chuàng)內(nèi)容,未經(jīng)授權(quán)不得轉(zhuǎn)載。歡迎更多用戶(hù)到社區(qū)交流互動(dòng)、創(chuàng)作博文,一經(jīng)采用,可獲得百元京東E卡。


原文標(biāo)題:【產(chǎn)品應(yīng)用】用 AWTK 和 AWPLC 快速開(kāi)發(fā)嵌入式應(yīng)用程序 (9)- 模塊化

文章出處:【微信公眾號(hào):ZLG致遠(yuǎn)電子】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

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

    關(guān)注

    13

    文章

    411

    瀏覽量

    31908

原文標(biāo)題:【產(chǎn)品應(yīng)用】用 AWTK 和 AWPLC 快速開(kāi)發(fā)嵌入式應(yīng)用程序 (9)- 模塊化

文章出處:【微信號(hào):ZLG_zhiyuan,微信公眾號(hào):ZLG致遠(yuǎn)電子】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    新品推薦|模塊化集成高速連接器

    LRM連接器隨著電子技術(shù)的快速發(fā)展,在電力傳輸、工業(yè)自動(dòng)、航空航天等領(lǐng)域,對(duì)高效、穩(wěn)定、可靠的電氣連接解決方案的需求日益增長(zhǎng)。因此日晟萬(wàn)晟開(kāi)發(fā)了新一代模塊化集成
    的頭像 發(fā)表于 07-07 18:15 ?108次閱讀
    新品推薦|<b class='flag-5'>模塊化</b>集成<b class='flag-5'>式</b>高速連接器

    Linux嵌入式和單片機(jī)嵌入式的區(qū)別?

    新的應(yīng)用程序和驅(qū)動(dòng)程序來(lái)擴(kuò)展功能。 6. 開(kāi)發(fā)難度 : 單片機(jī)嵌入式開(kāi)發(fā)難度相對(duì)較低,適合初學(xué)者入門(mén)。 Linux
    發(fā)表于 06-20 09:46

    聚徽解碼——從嵌入式模塊化:國(guó)內(nèi)工控平板的柔性技術(shù)架構(gòu)設(shè)計(jì)

    在工業(yè) 4.0 與智能制造蓬勃發(fā)展的浪潮下,國(guó)內(nèi)工控平板作為工業(yè)自動(dòng)與智能的關(guān)鍵設(shè)備,其技術(shù)架構(gòu)設(shè)計(jì)正經(jīng)歷著從嵌入式模塊化的深刻變革。這一轉(zhuǎn)變旨在賦予工控平板更強(qiáng)的柔性,使其能夠
    的頭像 發(fā)表于 06-13 16:24 ?154次閱讀

    如何用模塊化儀器高效測(cè)試嵌入式微控制器?

    從冰箱到飛機(jī),嵌入式微控制器如何確保穩(wěn)定運(yùn)行?面對(duì)復(fù)雜的混合信號(hào)與串行協(xié)議,工程師如何快速驗(yàn)證與調(diào)試?本文揭秘模塊化儀器的全能測(cè)試方案——數(shù)字儀、任意波形發(fā)生器、數(shù)字I/O
    的頭像 發(fā)表于 05-13 15:06 ?172次閱讀
    如何用<b class='flag-5'>模塊化</b>儀器高效測(cè)試<b class='flag-5'>嵌入式</b>微控制器?

    AWTK-WEB 快速入門(mén)(6) - JS WebSocket 應(yīng)用程序

    WebSocket可以實(shí)現(xiàn)雙向通信,適合實(shí)時(shí)通信場(chǎng)景。本文介紹一下使用Javacript語(yǔ)言開(kāi)發(fā)AWTK-WEB應(yīng)用程序,并用WebSocket與服務(wù)器通訊。AWTKDesigner
    的頭像 發(fā)表于 02-26 11:42 ?349次閱讀
    <b class='flag-5'>AWTK</b>-WEB <b class='flag-5'>快速</b>入門(mén)(6) - JS WebSocket <b class='flag-5'>應(yīng)用程序</b>

    AWTK-WEB 快速入門(mén)(5) - C 語(yǔ)言 WebSocket 應(yīng)用程序

    導(dǎo)讀WebSocket可以實(shí)現(xiàn)雙向通信,適合實(shí)時(shí)通信場(chǎng)景。本文介紹一下使用C語(yǔ)言開(kāi)發(fā)AWTK-WEB應(yīng)用程序,并用WebSocket與服務(wù)器通訊。AWTKDesigner新建一個(gè)
    的頭像 發(fā)表于 02-19 11:49 ?446次閱讀
    <b class='flag-5'>AWTK</b>-WEB <b class='flag-5'>快速</b>入門(mén)(5) - C 語(yǔ)言 WebSocket <b class='flag-5'>應(yīng)用程序</b>

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

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

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

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

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

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

    AWTK使用經(jīng)驗(yàn)】如何使用系統(tǒng)輸入法與開(kāi)啟最大化窗口功能

    導(dǎo)讀AWTK是基于C語(yǔ)言開(kāi)發(fā)的跨平臺(tái)GUI框架。AWTK使用經(jīng)驗(yàn)系列文章將介紹開(kāi)發(fā)AWTK過(guò)程中一些常見(jiàn)問(wèn)題與解決方案。
    的頭像 發(fā)表于 11-14 01:05 ?653次閱讀
    【<b class='flag-5'>AWTK</b>使用經(jīng)驗(yàn)】如何使用系統(tǒng)輸入法與開(kāi)啟最大化窗口功能

    EsDA,一站嵌入式軟件

    ,旨在提高嵌入式軟件開(kāi)發(fā)的效率、性能和可擴(kuò)展性。EsDA全稱(chēng)是嵌入式系統(tǒng)設(shè)計(jì)自動(dòng),它是一個(gè)由AWorksLP、AWStudio、AXPI、AWTK
    的頭像 發(fā)表于 09-15 08:10 ?767次閱讀
    EsDA,一站<b class='flag-5'>式</b><b class='flag-5'>嵌入式</b>軟件

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

    特點(diǎn)是支持跨平臺(tái)同步開(kāi)發(fā),一次編程,到處編譯,跨平臺(tái)使用。 GUIX 是微軟的高級(jí)工業(yè)級(jí)GUI解決方案,專(zhuān)門(mén)針對(duì)深度嵌入式,實(shí)時(shí)和IoT應(yīng)用程序而設(shè)計(jì)。微軟還提供了名為GUIX Studio
    發(fā)表于 09-02 10:58

    嵌入式linux開(kāi)發(fā)的基本步驟有哪些?

    嵌入式Linux開(kāi)發(fā)是一個(gè)復(fù)雜的過(guò)程,涉及到硬件選擇、操作系統(tǒng)移植、驅(qū)動(dòng)開(kāi)發(fā)應(yīng)用程序開(kāi)發(fā)等多個(gè)方面。以下是
    的頭像 發(fā)表于 09-02 09:11 ?1224次閱讀

    AWTK最新動(dòng)態(tài)】AWTK 1.8版本發(fā)布

    是什么AWTK全稱(chēng)ToolkitAnyWhere,是ZLG開(kāi)發(fā)的開(kāi)源GUI引擎,旨在為嵌入式系統(tǒng)、WEB、各種小程序、手機(jī)和PC打造的通用GUI引擎,為用戶(hù)提供一
    的頭像 發(fā)表于 08-30 12:48 ?819次閱讀
    【<b class='flag-5'>AWTK</b>最新動(dòng)態(tài)】<b class='flag-5'>AWTK</b> 1.8版本發(fā)布

    嵌入式QT常見(jiàn)開(kāi)發(fā)方式有哪些?

    嵌入式QT常見(jiàn)開(kāi)發(fā)方式有哪些? 嵌入式工程師在學(xué)習(xí)和使用Qt進(jìn)行開(kāi)發(fā)時(shí),常見(jiàn)的幾種開(kāi)發(fā)方式包括: 1.Qt Widgets編程: 通過(guò)C
    發(fā)表于 08-12 10:05
    主站蜘蛛池模板: 亚洲成人三级电影 | 国产精品国产三级在线高清观看 | 手机看片福利盒子久久青 | 天堂社区在线观看 | 午夜精品久久久久久久 | 日日操日日爽 | 97天天做天天爱夜夜爽 | 久久人人澡| 黄www片| 欧美黑人性受xxxx精品 | 又色又污又爽又黄的网站 | 99久久国产免费中文无字幕 | 九九热在线精品视频 | 靠比久久| 99草在线观看| 日韩午夜r电影在线观看 | 一级片免费在线观看 | 六月丁香色婷婷 | 国产一级久久免费特黄 | 成人免费午间影院在线观看 | 天堂中文字幕在线 | 久久涩综合 | 天天色天天干天天射 | 午夜快播 | 美女扒开尿囗给男生桶爽 | 亚洲国产精品日韩专区avtube | 狠狠婷婷 | 亚洲视频一区网站 | 色综合久久天天综合绕观看 | 久草视频这里只有精品 | 日本黄色美女视频 | 午夜综合网 | 成人夜色视频网站在线观看 | 18性夜影院午夜寂寞影院免费 | 男女性高爱潮免费的国产 | xxx性欧美 | 日本黄色免费观看 | 亚洲一卡2卡3卡4卡5卡乱码 | 日本不卡一区二区三区在线观看 | 性欧美xxxx乳高跟 | 国产成人91青青草原精品 |