整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          Qt編寫自定義控件70-扁平化flatui

          、前言

          對于現在做前端開發人員來說,FlatUI肯定不陌生,最近幾年扁平化的設計越來越流行,大概由于現在PC端和移動端的設備的分辨率越來越高,扁平化反而看起來更讓人愉悅,而通過漸變色產生的質感色彩反而沒有扁平化來得親切。

          Flat UI是基于Bootstrap之上進行二次開發的扁平化前端框架,他提供了動感、時尚的風格色調搭配,簡潔、炫麗的功能組件,同時還提供了更為平滑的js交互動畫,可以稱得上前端扁平化設計框架的優秀代表之一。

          既然是扁平化設計框架的優秀代表,當然需要在自己項目中應用應用,本人最早使用VB開發,而后轉為C#開發,最后轉為Qt開發,都是因為公司項目需要,根據需要不斷學習新的編程框架,語言都是相通的,舉一反三,以前用C#寫的vista時鐘控件和vista日歷控件,稍微改改就轉移成了Qt寫的對應控件,非常方便,只要掌握了思想,熟練了一門語言和框架之后,其他的學起來特別快。

          Qt中的qss機制,和css極為相似,感覺就是脫胎于css,用qss來實現Qt界面樣式不是一般的方便,而是相當的爽,在看到FlatUI這樣的精美的扁平化設計樣式后,難以抑制手癢癢,就想用qss實現類似的風格。

          開源地址:[https://gitee.com/feiyangqingyun/QWidgetDemo](https://gitee.com/feiyangqingyun/QWidgetDemo) [https://github.com/feiyangqingyun/QWidgetDemo](https://github.com/feiyangqingyun/QWidgetDemo)

          二、實現的功能

          * 1:按鈕樣式設置

          * 2:文本框樣式設置

          * 3:進度條樣式

          * 4:滑塊條樣式

          * 5:單選框樣式

          * 6:滾動條樣式

          * 7:可自由設置對象的高度寬度大小等

          * 8:自帶默認參數值

          三、效果圖

          五、核心代碼

          #pragma execution_character_set("utf-8")
          #include "flatui.h"
          #include "qmutex.h"
          #include "qpushbutton.h"
          #include "qlineedit.h"
          #include "qprogressbar.h"
          #include "qslider.h"
          #include "qradiobutton.h"
          #include "qcheckbox.h"
          #include "qscrollbar.h"
          #include "qdebug.h"
          QScopedPointer<FlatUI> FlatUI::self;
          FlatUI *FlatUI::Instance()
          {
           if (self.isNull()) {
           static QMutex mutex;
           QMutexLocker locker(&mutex);
           if (self.isNull()) {
           self.reset(new FlatUI);
           }
           }
           return self.data();
          }
          FlatUI::FlatUI(QObject *parent) : QObject(parent)
          {
          }
          QString FlatUI::setPushButtonQss(QPushButton *btn, int radius, int padding,
           const QString &normalColor,
           const QString &normalTextColor,
           const QString &hoverColor,
           const QString &hoverTextColor,
           const QString &pressedColor,
           const QString &pressedTextColor)
          {
           QStringList list;
           list.append(QString("QPushButton{border-style:none;padding:%1px;border-radius:%2px;color:%3;background:%4;}")
           .arg(padding).arg(radius).arg(normalTextColor).arg(normalColor));
           list.append(QString("QPushButton:hover{color:%1;background:%2;}")
           .arg(hoverTextColor).arg(hoverColor));
           list.append(QString("QPushButton:pressed{color:%1;background:%2;}")
           .arg(pressedTextColor).arg(pressedColor));
           QString qss = list.join("");
           btn->setStyleSheet(qss);
           return qss;
          }
          QString FlatUI::setLineEditQss(QLineEdit *txt, int radius, int borderWidth,
           const QString &normalColor,
           const QString &focusColor)
          {
           QStringList list;
           list.append(QString("QLineEdit{border-style:none;padding:3px;border-radius:%1px;border:%2px solid %3;}")
           .arg(radius).arg(borderWidth).arg(normalColor));
           list.append(QString("QLineEdit:focus{border:%1px solid %2;}")
           .arg(borderWidth).arg(focusColor));
           QString qss = list.join("");
           txt->setStyleSheet(qss);
           return qss;
          }
          QString FlatUI::setProgressQss(QProgressBar *bar, int barHeight,
           int barRadius, int fontSize,
           const QString &normalColor,
           const QString &chunkColor)
          {
           QStringList list;
           list.append(QString("QProgressBar{font:%1pt;background:%2;max-height:%3px;border-radius:%4px;text-align:center;border:1px solid %2;}")
           .arg(fontSize).arg(normalColor).arg(barHeight).arg(barRadius));
           list.append(QString("QProgressBar:chunk{border-radius:%2px;background-color:%1;}")
           .arg(chunkColor).arg(barRadius));
           QString qss = list.join("");
           bar->setStyleSheet(qss);
           return qss;
          }
          QString FlatUI::setSliderQss(QSlider *slider, int sliderHeight,
           const QString &normalColor,
           const QString &grooveColor,
           const QString &handleBorderColor,
           const QString &handleColor)
          {
           int sliderRadius = sliderHeight / 2;
           int handleWidth = (sliderHeight * 3) / 2 + (sliderHeight / 5);
           int handleRadius = handleWidth / 2;
           int handleOffset = handleRadius / 2;
           QStringList list;
           list.append(QString("QSlider::horizontal{min-height:%1px;}").arg(sliderHeight * 2));
           list.append(QString("QSlider::groove:horizontal{background:%1;height:%2px;border-radius:%3px;}")
           .arg(normalColor).arg(sliderHeight).arg(sliderRadius));
           list.append(QString("QSlider::add-page:horizontal{background:%1;height:%2px;border-radius:%3px;}")
           .arg(normalColor).arg(sliderHeight).arg(sliderRadius));
           list.append(QString("QSlider::sub-page:horizontal{background:%1;height:%2px;border-radius:%3px;}")
           .arg(grooveColor).arg(sliderHeight).arg(sliderRadius));
           list.append(QString("QSlider::handle:horizontal{width:%3px;margin-top:-%4px;margin-bottom:-%4px;border-radius:%5px;"
           "background:qradialgradient(spread:pad,cx:0.5,cy:0.5,radius:0.5,fx:0.5,fy:0.5,stop:0.6 %1,stop:0.8 %2);}")
           .arg(handleColor).arg(handleBorderColor).arg(handleWidth).arg(handleOffset).arg(handleRadius));
           //偏移一個像素
           handleWidth = handleWidth + 1;
           list.append(QString("QSlider::vertical{min-width:%1px;}").arg(sliderHeight * 2));
           list.append(QString("QSlider::groove:vertical{background:%1;width:%2px;border-radius:%3px;}")
           .arg(normalColor).arg(sliderHeight).arg(sliderRadius));
           list.append(QString("QSlider::add-page:vertical{background:%1;width:%2px;border-radius:%3px;}")
           .arg(grooveColor).arg(sliderHeight).arg(sliderRadius));
           list.append(QString("QSlider::sub-page:vertical{background:%1;width:%2px;border-radius:%3px;}")
           .arg(normalColor).arg(sliderHeight).arg(sliderRadius));
           list.append(QString("QSlider::handle:vertical{height:%3px;margin-left:-%4px;margin-right:-%4px;border-radius:%5px;"
           "background:qradialgradient(spread:pad,cx:0.5,cy:0.5,radius:0.5,fx:0.5,fy:0.5,stop:0.6 %1,stop:0.8 %2);}")
           .arg(handleColor).arg(handleBorderColor).arg(handleWidth).arg(handleOffset).arg(handleRadius));
           QString qss = list.join("");
           slider->setStyleSheet(qss);
           return qss;
          }
          QString FlatUI::setRadioButtonQss(QRadioButton *rbtn, int indicatorRadius,
           const QString &normalColor,
           const QString &checkColor)
          {
           int indicatorWidth = indicatorRadius * 2;
           QStringList list;
           list.append(QString("QRadioButton::indicator{border-radius:%1px;width:%2px;height:%2px;}")
           .arg(indicatorRadius).arg(indicatorWidth));
           list.append(QString("QRadioButton::indicator::unchecked{background:qradialgradient(spread:pad,cx:0.5,cy:0.5,radius:0.5,fx:0.5,fy:0.5,"
           "stop:0.6 #FFFFFF,stop:0.7 %1);}").arg(normalColor));
           list.append(QString("QRadioButton::indicator::checked{background:qradialgradient(spread:pad,cx:0.5,cy:0.5,radius:0.5,fx:0.5,fy:0.5,"
           "stop:0 %1,stop:0.3 %1,stop:0.4 #FFFFFF,stop:0.6 #FFFFFF,stop:0.7 %1);}").arg(checkColor));
           QString qss = list.join("");
           rbtn->setStyleSheet(qss);
           return qss;
          }
          QString FlatUI::setScrollBarQss(QWidget *scroll, int radius, int min, int max,
           const QString &bgColor,
           const QString &handleNormalColor,
           const QString &handleHoverColor,
           const QString &handlePressedColor)
          {
           //滾動條離背景間隔
           int padding = 0;
           QStringList list;
           //handle:指示器,滾動條拉動部分 add-page:滾動條拉動時增加的部分 sub-page:滾動條拉動時減少的部分 add-line:遞增按鈕 sub-line:遞減按鈕
           //橫向滾動條部分
           list.append(QString("QScrollBar:horizontal{background:%1;padding:%2px;border-radius:%3px;min-height:%4px;max-height:%4px;}")
           .arg(bgColor).arg(padding).arg(radius).arg(max));
           list.append(QString("QScrollBar::handle:horizontal{background:%1;min-width:%2px;border-radius:%3px;}")
           .arg(handleNormalColor).arg(min).arg(radius));
           list.append(QString("QScrollBar::handle:horizontal:hover{background:%1;}")
           .arg(handleHoverColor));
           list.append(QString("QScrollBar::handle:horizontal:pressed{background:%1;}")
           .arg(handlePressedColor));
           list.append(QString("QScrollBar::add-page:horizontal{background:none;}"));
           list.append(QString("QScrollBar::sub-page:horizontal{background:none;}"));
           list.append(QString("QScrollBar::add-line:horizontal{background:none;}"));
           list.append(QString("QScrollBar::sub-line:horizontal{background:none;}"));
           //縱向滾動條部分
           list.append(QString("QScrollBar:vertical{background:%1;padding:%2px;border-radius:%3px;min-width:%4px;max-width:%4px;}")
           .arg(bgColor).arg(padding).arg(radius).arg(max));
           list.append(QString("QScrollBar::handle:vertical{background:%1;min-height:%2px;border-radius:%3px;}")
           .arg(handleNormalColor).arg(min).arg(radius));
           list.append(QString("QScrollBar::handle:vertical:hover{background:%1;}")
           .arg(handleHoverColor));
           list.append(QString("QScrollBar::handle:vertical:pressed{background:%1;}")
           .arg(handlePressedColor));
           list.append(QString("QScrollBar::add-page:vertical{background:none;}"));
           list.append(QString("QScrollBar::sub-page:vertical{background:none;}"));
           list.append(QString("QScrollBar::add-line:vertical{background:none;}"));
           list.append(QString("QScrollBar::sub-line:vertical{background:none;}"));
           QString qss = list.join("");
           scroll->setStyleSheet(qss);
           return qss;
          }
          
          

          六、控件介紹

          1. 超過160個精美控件,涵蓋了各種儀表盤、進度條、進度球、指南針、曲線圖、標尺、溫度計、導航條、導航欄,flatui、高亮按鈕、滑動選擇器、農歷等。遠超qwt集成的控件數量。

          2. 每個類都可以獨立成一個單獨的控件,零耦合,每個控件一個頭文件和一個實現文件,不依賴其他文件,方便單個控件以源碼形式集成到項目中,較少代碼量。qwt的控件類環環相扣,高度耦合,想要使用其中一個控件,必須包含所有的代碼。

          3. 全部純Qt編寫,QWidget+QPainter繪制,支持Qt4.6到Qt5.13的任何Qt版本,支持mingw、msvc、gcc等編譯器,支持任意操作系統比如windows+linux+mac+嵌入式linux等,不亂碼,可直接集成到Qt Creator中,和自帶的控件一樣使用,大部分效果只要設置幾個屬性即可,極為方便。

          4. 每個控件都有一個對應的單獨的包含該控件源碼的DEMO,方便參考使用。同時還提供一個所有控件使用的集成的DEMO。

          5. 每個控件的源代碼都有詳細中文注釋,都按照統一設計規范編寫,方便學習自定義控件的編寫。

          6. 每個控件默認配色和demo對應的配色都非常精美。

          7. 超過130個可見控件,6個不可見控件。

          8. 部分控件提供多種樣式風格選擇,多種指示器樣式選擇。

          9. 所有控件自適應窗體拉伸變化。

          10. 集成自定義控件屬性設計器,支持拖曳設計,所見即所得,支持導入導出xml格式。

          11. 自帶activex控件demo,所有控件可以直接運行在ie瀏覽器中。

          12. 集成fontawesome圖形字體+阿里巴巴iconfont收藏的幾百個圖形字體,享受圖形字體帶來的樂趣。

          13. 所有控件最后生成一個動態庫文件(dll或者so等),可以直接集成到qtcreator中拖曳設計使用。

          14. 目前已經有qml版本,后期會考慮出pyqt版本,如果用戶需求量很大的話。

          15. 自定義控件插件開放動態庫使用(永久免費),無任何后門和限制,請放心使用。

          16. 目前已提供32個版本的dll,其中qt_5_7_0_mingw530_32這個版本會一直保證最新的完整的。

          17. 不定期增加控件和完善控件,不定期更新SDK,歡迎各位提出建議,謝謝!

          18. Qt入門書籍推薦霍亞飛的《Qt Creator快速入門》《Qt5編程入門》,Qt進階書籍推薦官方的《C++ GUI Qt4編程》。

          19. 強烈推薦程序員自我修養和規劃系列書《大話程序員》《程序員的成長課》《解憂程序員》,受益匪淺,受益終生!

          20. SDK地址:[https://gitee.com/feiyangqingyun/QUCSDK](https://gitee.com/feiyangqingyun/QUCSDK) [https://github.com/feiyangqingyun/qucsdk](https://github.com/feiyangqingyun/qucsdk)

          多數PHP程序都使用HTML表單從用戶那里獲取數據并計算結果。

          HTML表單的一些基本原則

          • 選擇適合于收集的數據類型和提供交互方式的控件。
          • 清楚標記每一個控件,這樣用戶就可以理解其功能。
          • 盡可能將標簽對齊。將控件的左邊緣對齊。
          • 將相關的標簽分組,并且通過設計中使用空白將每一個分組分開。
          • 表單上的控件順序應該類似于用戶操作他們的順序。

          創建基本HTML表單

          首先創造一個基本的HTML大綱,包含表單控件;然后將控件進行合并(HTML表單必須包括一個提交按鈕,用戶單擊它可以將表單數據發送到服務器。)一個單獨的HTML頁面可以包含多個表單。

          • 創建HTML結構

          包含表單的HTML結構和和普通的HTML結構一樣。

          <HTML>
            <HEAD>
            <TITLE>標題放在這</TITLE>
            </HEAD>
          <BODY>
            表單頁面放在這
            </BODY>
            </HTML>

          在包含表單的HTML頁面中可以使用任何HTML標簽?;镜谋韱问褂肍ROM標簽來說明。該標簽中METHOD屬性接收GET或POST兩個值中的一個。ACTION屬性子明PHP腳本的url,該腳本可以收集通過表單收集的數據,可以是絕對路徑或者相對路徑。

          <FORM METHOD="method" ACTION="url"> 
            中間可以放置表單控件
            </FORM>
          • 合并控件

          兩個常用的基本控件:文本框和提交按鈕。

          文本框:允許用戶鍵入信息以發送給PHP腳本。NAME屬性為文本提供名稱,PHP腳本可以通過名稱準確訪問其內容,因此它應該是唯一的且符合PHP變量命名規則(但不需要$符號),單標簽。VALUE屬性指明出現在提交按鈕上面的標題。創建方式如下:

          <INPUT TYPE = "TEXT" NAME="text">

          提交按鈕:允許用戶將一個表單的內容發送到服務器,一個HTML表單對應應該有一個提交按鈕。

          示例:一個完整的HTML表單。

          <HTML>
            <HEAD>
            <TITLE>標題</TITLE>
            </HEAD>
          <BODY>
          <FORM METHOD="POST" ACTION="phpinfo.php">
          <INPUT TYPE="TEXT" NAME="user_name">
          <BR/>
          <BR/>
          <INPUT TYPE="TEXT" NAME="user_email">
          <BR/>
          <BR/>
          <INPUT TYPE="SUBMIT" VALUE="Send the Data">
          </FORM>
            </BODY>
            </HTML>


          • 使用多個表單

          可以在一個HTML頁面中包含多個表單,注意下一個表單的FORM開始之前需要結束前一個FORM表單。

          <HTML>
            <HEAD>
            <TITLE>標題</TITLE>
            </HEAD>
          <BODY>
            
          <FORM METHOD="POST" ACTION="phpinfo.php">
          <INPUT TYPE="TEXT" NAME="user_name">
          <BR/>
          <BR/>
          <INPUT TYPE="TEXT" NAME="user_email">
          <BR/>
          <BR/>
          <INPUT TYPE="SUBMIT" VALUE="Send the Data">
          <BR/>
          <BR/>
          </FORM>
          
          <FORM METHOD="POST" NAME="phpinfo.php">
          <INPUT TYPE="TEXT" NAME="user_name1">
          <BR/>
          <BR/>
          <INPUT TYPE="TEXT" NAME="user_email1">
          <BR/>
          <BR/>
          <INPUT TYPE="SUBMIT" VALUE="Send the Data1">
          </FORM>
          
            </BODY>
            </HTML>


          創建表單控件

          • 創建自定義的文本框

          文本框的屬性中,TYPE和NAME是必須的,其余是可選屬性。SIZE屬性用于設置文本框的可視大??;MAXLENGTH指明用戶鍵入字符的最大長度;VALUE給出了一個最初顯示在文本框中的值。

          <input type="text" name="" size="" maxlength="" value="">
          • 創建文本區域

          文本區域可以輸入多行文本。NAME和ROWS屬性是必須的。ROWS屬性表明了文本區域內可以看到的文本行數,充滿時會滾動。COLS屬性指明可見文本列數與行數類似。WRAP屬性指明文本區域內單詞換行的方式,可以指定如下值。該標簽為雙標簽。

          說明

          off

          禁止單詞換行但用戶可以輸入換行符強制換行

          virtual/soft

          各行顯示為換行,但是換行并沒有被發送到服務器

          physica/hard

          啟用了單詞換行

          <inputarea name="" rows="" cols="" wrap="">
          • 創建密碼框

          創建密碼框的語法與文本框相同,但要將TYPE屬性指定為PASSWORD而不是TYPE。

          <input type="password" name="" size="" maxlength="" value="">
          • 創建復選框

          取兩個值中的一個,即二選一。TYPE屬性是必須的,checked屬性出現,該復選框默認情況會被選定。value屬性指定復選框被選定情況下被發送到服務器的值,默認發送on值。法如下:

          <input type="checkbox" name="" checked value="">
          • 創建單選按鈕

          語法與復選框屬性含義相同,但是TYPE屬性的值必須是RADIO,NAME屬性是必須的。

          <input type="radio" name="" checked value="">
          • 創建列表框

          用戶可以選擇一個或者多個選項,它是一個滾動菜單。

          <select name="" multipile size="">options go here</select>

          name屬性是必須的,multipile屬性指明用戶可以通過按下crtl鍵并單擊多個選項來選擇它們

          列表框的單選行為可作為單選按鈕。

          <option selected value="text"></options>
          • 創建隱藏域
          <input type="hidden" name="text"value="">
          • 實現上傳文件的HTML表單
          <input type="FILE" name="name" accept="time" value="text">

          其中type屬性是必須的。格式通過使用MIME碼指定。常用的格式如下:


          超文本標記語言文本 .html,.html text/html

            普通文本 :txt text/plain

            word文檔:application/msword

            RTF文本 :rtf application/rtf

            GIF圖形 :gif image/gif

            JPEG圖形 :jpeg,

            jpg: image/jpeg

            au聲音文件:au audio/basic

            MIDI音樂文件 :mid,.midi audio/midi,audio/x-midi

            RealAudio音樂文件 .ra, .ram audio/x-pn-realaudio

            MPEG文件 .mpg,.mpeg video/mpeg

            AVI文件 .avi video/x-msvideo

            GZIP文件 .gz application/x-gzip

            壓縮文件.rar application/octet-stream

            壓縮文件.zip application/x-zip-compressed

            TAR文件 .tar application/x-tar


          更多提交表單的信息

          • 使用圖像提交數據
          <input type="image" src="url" name="text" align="align">
          • 創建重置按鈕
          <input type="reset" value="text">

          之前官方正式宣布Alert Control中支持HTML & CSS模板,正如上篇文章中所述,HTML 和 CSS 模板允許您輕松創建自定義/現代通知。在本文中,將分享更多與模板相關的更新,您可以期待DevExpress的v22.1版本了!

          DevExpress Universal Subscription官方最新版免費下載試用,歷史版本下載,在線文檔和幫助文件下載-慧都網

          ListBox控件

          在以前的版本中,技術團隊為WinForms ListBox控件引入了標準模板——一種類似于平鋪視圖中可用的設計器,使您可以輕松地在 ListBox 項目表面上排列元素。v22.1 中可用的 HTML 和 CSS 模板將這種自定義靈活性提升到一個全新的水平。

          上圖取自技術團隊更新的HTML Demo Center模塊,使用以下HTML標記來創建此示例UI。

          <div class="contact">
          <div class="contact-avatar">
          <img class="photo" src="${Photo}" />
          <div class="status" id="status"></div>
          </div>
          <div>
          <div class="contact-body">
          <div class="contact-info">
          <div class="name-info">
          <div class="name">${FirstName} {LastName}</div>
          <img class='info' src='Contact' id="info" />
          </div>
          <div class="phone">${HomePhone}</div>
          </div>
          </div>
          <div class='selection'></div>
          </div>
          </div>

          ComboBox編輯

          ComboBox編輯與 ListBox Edit 模板類似,您可以利用 ${FieldName} 語法來添加數據占位符。 在運行時,這些占位符將替換為來自數據源的實際值。 正如您在下面看到的,這使HTML 和 CSS 模板成為構建數據感知控件布局的完美工具。

          此示例 ComboBox Edit UI 的模板如下:

          <div class="contact">
          <div class="contact-avatar">
          <img class="photo" src="${Photo}" />
          </div>
          <div>
          <div class="contact-body">
          <div>
          <div class="name">${FirstName} {LastName}</div>
          <div class="label">${Department}</div>
          </div>
          </div>
          <div class='selection'></div>
          </div>
          </div>

          TileView模板的項目自動高度

          在 v21.2 發布周期中引入了對 TileView 的 HTML 和 CSS 模板支持,在官方即將發布的版本中,您將能夠根據內容大小調整圖塊。

          要啟用此功能,只需將 OptionsHtmlTemplate.ItemAutoHeight 屬性設置為 true。

          上面的圖像是使用以下 HTML 代碼創建的:

          <div class="container">
          <div class="card">
          <div class="stripe" id="stripe"></div>
          <div class="content">
          <div class="top-block">
          <div class="caption"><b>${Name}</b></div>
          </div>
          <div class="description">${Description}</div>
          <div class="bottom-block">
          <div class="bottom-block-near">
          <div><span style="color:@DisabledText">Due Date: </span>${DueDate}</div>
          <div><span style="color:@DisabledText">Employee: </span>${Employee}</div>
          </div>
          <div class="status">${Status}%</div>
          </div>
          </div>
          </div>
          </div>

          DevExpress WinForm

          DevExpress WinForm擁有180+組件和UI庫,能為Windows Forms平臺創建具有影響力的業務解決方案。DevExpress WinForms能完美構建流暢、美觀且易于使用的應用程序,無論是Office風格的界面,還是分析處理大批量的業務數據,它都能輕松勝任!


          主站蜘蛛池模板: 国产AV午夜精品一区二区入口| 国产视频一区在线播放| 国产一区二区三区乱码在线观看| 久久精品国产亚洲一区二区三区| 亚洲日本乱码一区二区在线二产线 | 精品国产福利第一区二区三区| 无码少妇丰满熟妇一区二区 | 精产国品一区二区三产区| 无码人妻精品一区二区三18禁| av在线亚洲欧洲日产一区二区| 国产精品亚洲一区二区三区在线观看| 国产91精品一区二区麻豆网站 | 色欲AV蜜臀一区二区三区| 国产品无码一区二区三区在线蜜桃| 制服美女视频一区| 日韩精品一区二区三区国语自制 | 波多野结衣精品一区二区三区| 亚洲AV无码一区二区三区鸳鸯影院 | 精品视频一区二区三区| 一区二区三区免费视频播放器| 国产综合无码一区二区色蜜蜜| 亚洲日韩AV一区二区三区中文| 在线|一区二区三区四区| 天天综合色一区二区三区| 亚洲AV无码一区二区三区鸳鸯影院 | 亚洲色大成网站www永久一区| 中文字幕一区二区三区免费视频 | 国产精品福利一区二区| 精品福利视频一区二区三区| 亚洲一区精品视频在线| 国产日韩一区二区三区在线播放| 蜜臀AV一区二区| 中文乱码人妻系列一区二区| 亚洲一区二区三区丝袜| 成人一区二区三区视频在线观看 | 亚欧免费视频一区二区三区| 国产情侣一区二区| 精品人妻一区二区三区毛片| 无码精品黑人一区二区三区| 亚洲日本va一区二区三区| 一区二区三区日本电影|