精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Qt in Scala(JVM)開發梗概

移動開發 后端
本文將講述Qt in Scala(JVM)開發梗概.本篇文章涉及的開發環境如下:windows xp sp2,JDK6u21,Scala 2.8.0 final,Qt Jambi LGPL 4.5.2_01,IDE選NetBeans吧!

本文將講述Qt in Scala(JVM)開發梗概。

前言

一直有人問Qt的開發情況,希望有個感性的認識。一直也有整理這方面資料的沖動,但時間也很緊迫,所以長話短說。目前將目標鎖定Qt Jambi版本吧,熟悉了Qt以后,我對其C++版本的興趣也十分濃厚,所以,將來再慢慢整理吧。

本篇文章涉及的開發環境如下:windows xp sp2JDK6u21Scala 2.8.0 finalQt Jambi LGPL 4.5.2_01,IDE選NetBeans吧!

列出Qt的文檔中心的幾個重要資源的鏈接入口:

Qt Jambi 4.5.2_01的文檔索引

API Javadoc

CSS樣式說明(內容彼此交叉,十分詳盡,你只需要有一點點的CSS基礎就能明白)

官方實例

Qt Jambi 4.5.2_01Binary for Windows 32-bit(點擊將自動下載)

關于Qt的點滴,我會以注釋的形式寫在代碼里面,畢竟都是寫代碼的,對注釋會比較敏感。

Hello Qt in Scala

  1. package qt.demo  
  2.  
  3. import com.trolltech.qt.gui._  
  4.  
  5. object HelloQt {  
  6.  
  7.   def main(args: Array[String]): Unit = {  
  8.     QApplication.initialize(args)  
  9.     (new QLabel("Hello Qt")).show  
  10.     QApplication.exec  
  11.   }  
  12. }  
  13.  

可能上述代碼還能再度簡化一下,比如去掉new QLabel兩邊的括號(但可能會很怪異了)。這個很簡單吧,輸出結果如下圖:

去掉new QLabel兩邊的括號  

QApplication是Qt的一個全局單例類,就把他看作是一個總控制中心吧。他是一個static類,通過調用QApplication.instance()方法,可獲得當前運行過程中的app實例。

QApplication.instance是一個全局控制實例,這里所定義的內容(可以定義的東西,詳細請看手冊),除非在實例具體某個對象時有具體設置,否則全局都按照instance的設置進行。當然,其實多數時候,我會用他來控制全局的樣式定義。

好吧,上述的例子實在簡單的有些惡心了,我們來些實際一點的東西:

  1. package qt.demo  
  2.  
  3. import com.trolltech.qt.gui._  
  4. import com.trolltech.qt.core.Qt._  
  5.  
  6. object CustomWindow {  
  7.  
  8.   val globalStyle = """  
  9. * { font-family: Mircosoft Yahei; font-size: 12px; color: #333; }  
  10. #mainWindow { border: 40px solid #ccc; border-image: url(classpath:qt/demo/resource/window.png) 40 stretch; }  
  11. """  
  12.  
  13.   def main(args: Array[String]): Unit = {  
  14.     QApplication.initialize(args)  
  15.     QApplication.instance.setStyleSheet(globalStyle)  
  16.     val frame = new QFrame() {  
  17.       this.setObjectName("mainWindow")  
  18.       // 以下為窗體展現定制,應該在show之前調用  
  19.       // show以后再調用,會令窗體crash,你需要再次show  
  20.       this.setWindowFlags(WindowType.FramelessWindowHint)  
  21.       this.setAttribute(WidgetAttribute.WA_TranslucentBackground, true)  
  22.       // 由于設定了不使用windows窗體,所以,請手動結束多余的進程  
  23.     }  
  24.     frame.show()  
  25.     QApplication.exec  
  26.   }  
  27. }  

截圖效果如下:

 截圖效果

怎么樣,開始有點意思了吧?30行代碼連樣式,其實想做漂亮的界面,也不是那么難吧!

安裝Qt Jambi

回到最初點,首先還是要把環境搭建起來。先去上面的地址下載Qt Jambi 4.5.2_01Binary for Windows 32-bit,隨便解壓吧。解開目錄,里面有幾個值得一看的東西:

 

qtjambi.exe 這個僅僅是運行一個Demo示例,看看吧,里面很多東西都會給你帶來不錯的啟發。但不得不說,Qt原版的Demo,那叫一個炫啊,Java真受冷落。

designer.bat 這個是打開設計器的,實際設計器在這個目錄下的bin目錄里面。

qtjambi-4.5.2_01.jar

qtjambi-win32-msvc2005-4.5.2_01.jar 這兩個jar包是你在實際開發中需要使用的,你需要將這兩個庫引入到你的項目中。并且從文件名我們可以發現,他是使用vc2005(vc80),如果你沒安裝vs2005補丁,快去裝一個吧。

好了,準備功夫就這么點,我們可以開始進一步的工作了!

填充基礎界面

好了,我們該開始往這樣一個界面里面加東西了,首先,他要有個標題欄,中間是他的視圖展示部分,當然了,我們還可以加一個底部的狀態條。實際上,使用設計器和標準的QMainWidget,我們能做得很好。但一方面我是代碼控,而另一方面,我覺得通過代碼,能展示更多感性方面的東西(透過Qt Jambi的Eclipse的插件,一個界面設計完成,它會自動幫你轉換為一個Java的類,所以,你無需過分擔心后續實際開發的復雜度。)。而且說實在的,他的設計器和Vs比,就差很多很多了。

既然有那么多想法,我們可以考慮給它添加一個Layout,哦,忘記說了,Qt遵循較為嚴格的對象機制,所有界面構造元素都繼承自QWidget,而Layout,則繼承自QLayout,而QLayout和QWidget則都來自QObject,當然,細分還有很多,但Layout和QWidget畢竟是大頭。

剛才展示的兩個例子中,QFrame和QLabel都繼承自QWidget,所以你可以對他們對Show,而不用考慮窗口,父容器,你對哪個QWidget的實例調用了show方法,它就會是一個獨立窗體,邏輯十分清晰。

Layout有兩種聲明方式(當然,new實例只有一種方式),所謂聲明是指和QWidget產生關聯。new QHBoxLayout(anyQWidget),或者anyQWidget.setLayout(anyQLayout)。一個QWidget實例不能進行(關聯)兩次以上布局,當你第二次對它進行布局關聯時,系統會給你一個警告,但不會令程序或者窗體Crash。

  1. package qt.demo  
  2.  
  3. import com.trolltech.qt.gui._  
  4. import com.trolltech.qt.core.Qt._  
  5.  
  6. object CustomWindow {  
  7.  
  8.   //=======================// 全局樣式 //=======================//  
  9.  
  10.   val globalStyle = """  
  11. * { font-family: Microsoft Yahei; font-size: 12px; color: #333; }  
  12. #mainWindow { border: 32px solid #ccc; border-image: url(classpath:qt/demo/resource/window.png) 32 stretch; }  
  13. #title { font-size: 13px; font-weight: bold; color: #000; }  
  14. #body { border: 1px solid #ccc; }  
  15. """  
  16.  
  17.   //=======================// 主窗體 //=======================//  
  18.   //  
  19.   // 我們將frame變量轉移到這里  
  20.   // lazy關鍵字,表示調用時才實現該變量值  
  21.   lazy val frame = new QFrame() {  
  22.     this.setObjectName("mainWindow")  
  23.     // 以下為窗體展現定制,應該在show之前調用  
  24.     // show以后再調用,會令窗體crash,你需要再次show  
  25.     this.setWindowFlags(WindowType.FramelessWindowHint)  
  26.     this.setAttribute(WidgetAttribute.WA_TranslucentBackground, true)  
  27.     // 由于設定了不使用windows窗體,所以,請手動結束多余的進程  
  28.   }  
  29.  
  30.   // 為了進一步分工明確,我又把layout也挪出來了  
  31.   // 這里采用聲明關聯  
  32.   // 一個layout會默認撐滿整個容器  
  33.   lazy val frameLayout = new QVBoxLayout(frame) {  
  34.     this.setMargin(0)  // Layout四邊的margin,當然你也可以用setContentsMargin來設定四邊的具體值  
  35.     this.setSpacing(0) // 設定元件之間的間距  
  36.   }  
  37.  
  38.   //=======================// 標題欄 //=======================//  
  39.   //  
  40.   // 要構造界面,未必需要全部都是widget  
  41.   // layout也可以插入到layout中  
  42.   lazy val titleLayout = {  
  43.     val _layout = new QHBoxLayout // 這是一個內部變量,不在類變量中  
  44.     // 讓他垂直居中,左對齊  
  45.     _layout.setSpacing(5)  
  46.     _layout.setAlignment(new Alignment(AlignmentFlag.AlignLeft, AlignmentFlag.AlignVCenter))  
  47.     _layout.addWidget(titleIcon)  
  48.     _layout.addWidget(titleText)  
  49.     _layout // 這里等同于這個block return _layout  
  50.   }  
  51.  
  52.   // 標題的元素構成  
  53.   lazy val titleIcon = new QLabel {  
  54.     this.setPixmap(getIcon.pixmap(18))  
  55.     // 指定他的具體寬高  
  56.     this.setFixedSize(20, 20)  
  57.     // 讓該容器按照該寬高占位  
  58.     this.setSizePolicy(QSizePolicy.Policy.Fixed, QSizePolicy.Policy.Fixed)  
  59.   }  
  60.   lazy val titleText = new QLabel("這是一個標題欄") {  
  61.     this.setObjectName("title")  
  62.     // 只指定具體高度  
  63.     this.setFixedHeight(20)  
  64.     // 他的水平方向會100%的撐開,垂直方向按指定的高度占位  
  65.     this.setSizePolicy(QSizePolicy.Policy.Expanding, QSizePolicy.Policy.Fixed)  
  66.   }  
  67.  
  68.   //=======================// body部分 //=======================//  
  69.  
  70.   lazy val body = {  
  71.     val widget = new QWidget  
  72.     widget.setObjectName("body")  
  73.     widget.setSizePolicy(QSizePolicy.Policy.Expanding, QSizePolicy.Policy.Expanding)  
  74.     widget  
  75.   }  
  76.  
  77.   //=======================// foot部分 //=======================//  
  78.  
  79.   lazy val foot = new QLabel("狀態欄") {  
  80.     this.setSizePolicy(QSizePolicy.Policy.Expanding, QSizePolicy.Policy.Fixed)  
  81.     this.setAlignment(new Alignment(AlignmentFlag.AlignRight, AlignmentFlag.AlignBottom))  
  82.   }  
  83.  
  84.   //=======================// 快捷函數 //=======================//  
  85.  
  86.   def app = QApplication.instance  
  87.  
  88.   def getIcon = frame.style.standardIcon(QStyle.StandardPixmap.SP_MessageBoxInformation)  
  89.  
  90.   def main(args: Array[String]): Unit = {  
  91.     QApplication.initialize(args)  
  92.     app.setStyleSheet(globalStyle)  
  93.     frameLayout.addLayout(titleLayout)  
  94.     frameLayout.addWidget(body)  
  95.     frameLayout.addWidget(foot)  
  96.     frame.resize(370, 270) // 這里要計算樣式中border-width的寬度,實際上我們期望這個窗體的內容大小在300, 200  
  97.     frame.show()  
  98.     QApplication.exec  
  99.   }  
  100. }  
  101.  

效果截圖:

  效果截圖

從30行激增到100行,可能需要點耐性去讀。但整個窗體的初步效果已經看出來了,而且,很顯然,類似這樣的窗體,我們完全可以將他封裝成一個單獨的類。當然模擬一個完整的窗口,也許需要更多更多的代碼,但通過良性的封裝,能很好的解決代碼冗余的問題。

Qt的信號槽和事件

信號槽,是Qt中一個有趣的設定,這個也體現了Qt在Ui方面的一種經驗的積累。

首先給出最最簡單的信號槽的代碼樣例。

  1. class ClickEvent(widget: QWidget) {  
  2.    
  3.   def doClicked(checked: Int) {  
  4.     // 若干操作  
  5.   }  
  6. }  
  7.  
  8. val btn = new QPushButton()  
  9. btn.clicked.connect(anyInstance, "doClicked(int)")  

好了,當你點擊了btn以后,他會自動執行doClicked方法。也許你會說,切,這有什么了不起的呢?如果要細說,恐怕不是一時半會能說的清楚的,大家也許還焦急著進一步完善剛才做出來的窗口。OK,我長話短說。

在Qt所有類的上層,Event接口,是由QObject去定義的,而QWidget實際上是繼承自QObject的。QObject::installEventFilter(QObject),實際上是注冊事件的總入口。當然,在你每次實例一個QObject的時候,他已經默認的幫你為當前實例installEventFilter。這個方法實際上就是指派給具體哪個實例作為該對象的事件觀察者。

從installEventFileter以后,事件首先經過evnetFilter進行分發,event應該是同級的事件分發。在這兩個方法里,需要指定返回Boolean類型,實際上是對事件的攔截。

再其次,到各種種類繁多,因應具體類而產生的event入口,比如showEvent等等。在這個層面,事件經由上層的分發,已經不會再等待你返回結果(他是返回無類型的),雖然對于QEvent實例,有accept或者igroe,但實際上這個過程里,你已無法保證絕對控制事件的整體了,你只能控制經由上層分到你這一級以后的事情,可是上層做了什么,你不知道,也管不了。

在這個事件機制的基礎之下,信號槽似乎是處于整個事件機制的***端,但信號槽機制又有其主要特點。他是單向的,不管理該實例的全局狀態,他只關心他最關心(當然也是指派給他)的對象,這個(或若干個)對象往往是整個事件機制中最關鍵的一個狀態,他提供給你一個既不用單獨注冊一個QObject以從頭接管實例的全部事件,也不用利用override的方式重載事件聲明,即可利用信號槽,去做其他關聯操作的觸發。而無論他有或者無,不會對實例本身的狀態進行改變,所以他是一個松耦合、無歧義的接口。

而且,Qt提供給你自己擴展信號槽的機會,除了常規的Qt類可獲得信號槽以外,在你自定義的類中,也可以通過繼承自QSignalEmitter,來獲得信號槽機制的使用。

好了廢話一大堆,讓我們繼續干活,這次,我們添加一個關閉按鈕,并且,讓這個窗口可以被自由的拖動,而這也將是***將要完成的工作:

  1. package qt.demo  
  2.  
  3. import com.trolltech.qt.gui._  
  4. import com.trolltech.qt.core._  
  5. import com.trolltech.qt.core.Qt._  
  6.  
  7. object CustomWindow {  
  8.  
  9.   //=======================// 全局樣式 //=======================//  
  10.  
  11.   val globalStyle = """  
  12. * { font-family: Microsoft Yahei; font-size: 12px; color: #333; }  
  13. #mainWindow { border: 32px solid #ccc; border-image: url(classpath:qt/demo/resource/window.png) 32 stretch; }  
  14. #title { font-size: 13px; font-weight: bold; color: #000; }  
  15. #body { border: 1px solid #ccc; }  
  16. #closeBtn { border: 0; background: none; font-weight: bold; color: red; }  
  17. """  
  18.  
  19.   //=======================// 主窗體 //=======================//  
  20.   // 其實我們可以將這個Frame作為一個單獨類封裝一下  
  21.   class DemoFrame extends QFrame {  
  22.  
  23.     this.setObjectName("mainWindow")  
  24.     // 以下為窗體展現定制,應該在show之前調用  
  25.     // show以后再調用,會令窗體crash,你需要再次show  
  26.     this.setWindowFlags(WindowType.FramelessWindowHint)  
  27.     this.setAttribute(WidgetAttribute.WA_TranslucentBackground, true)  
  28.  
  29.     val frameLayout = new QVBoxLayout(this) {  
  30.       this.setMargin(0)  // Layout四邊的margin,當然你也可以用setContentsMargin來設定四邊的具體值  
  31.       this.setSpacing(0) // 設定元件之間的間距  
  32.     }  
  33.  
  34.     private def frame = this 
  35.  
  36.     //=======================// 標題欄 //=======================//  
  37.  
  38.     val titleLayout = new QHBoxLayout {  
  39.       setSpacing(5)  
  40.       setAlignment(new Alignment(AlignmentFlag.AlignLeft, AlignmentFlag.AlignVCenter))  
  41.     }  
  42.  
  43.     // 標題的元素構成  
  44.     val titleIcon = new QLabel {  
  45.       this.setPixmap(getIcon.pixmap(18))  
  46.       // 指定他的具體寬高  
  47.       this.setFixedSize(20, 20)  
  48.       // 讓該容器按照該寬高占位  
  49.       this.setSizePolicy(QSizePolicy.Policy.Fixed, QSizePolicy.Policy.Fixed)  
  50.     }  
  51.     val titleText = new QLabel("這是一個標題欄") {  
  52.       this.setObjectName("title")  
  53.       // 只指定具體高度  
  54.       this.setFixedHeight(20)  
  55.       // 他的水平方向會100%的撐開,垂直方向按指定的高度占位  
  56.       this.setSizePolicy(QSizePolicy.Policy.Expanding, QSizePolicy.Policy.Fixed)  
  57.       // 我們從這里注冊title拖動  
  58.       // 其實***是title首先是個QWidget,那么我們可以對整個title進行拖動,請原諒我的懶惰  
  59.       val dragPosition = new QPoint()  
  60.       // 鼠標單擊放下  
  61.       override def mousePressEvent(event: QMouseEvent) {  
  62.         if (event.button() == MouseButton.LeftButton) {  
  63.           val topLeft = frame.frameGeometry.topLeft  
  64.           dragPosition.setX(event.globalPos.x - topLeft.x)  
  65.           dragPosition.setY(event.globalPos.y - topLeft.y)  
  66.           event.accept  
  67.         }  
  68.       }  
  69.  
  70.       override def mouseMoveEvent(event: QMouseEvent) {  
  71.         if (event.buttons().isSet(MouseButton.LeftButton)) {  
  72.           val topLeft = frame.frameGeometry.topLeft  
  73.           val p = new QPoint(event.globalPos().x() - dragPosition.x,  
  74.                              event.globalPos().y() - dragPosition.y)  
  75.           frame.move(p)  
  76.           event.accept  
  77.         }  
  78.       }  
  79.     }  
  80.  
  81.     val closeBtn = new QPushButton("X")  
  82.     closeBtn.setObjectName("closeBtn")  
  83.     closeBtn.setFixedSize(15, 15)  
  84.     // 其實這里可以寫成 this.clicked.connect(QApplication.instance, "quit()")  
  85.     // close表示關閉frame窗口,quit則是整個程序退出  
  86.     // qt內部會做調整,當你close窗口,又沒有其他窗口在show或者準備show,他也會自動進行quit  
  87.     closeBtn.clicked.connect(this, "close()")  
  88.  
  89.     override def showEvent(event: QShowEvent) {  
  90.       val g = this.frameGeometry  
  91.       val (w, h) = (g.width + 70, g.height + 70)  
  92.       this.setFixedSize(w, h) // 根據樣式重設大小  
  93.       closeBtn.move(w - 45, 30)  
  94.     }  
  95.  
  96.     //=======================// body部分 //=======================//  
  97.  
  98.     val body = {  
  99.       val widget = new QWidget  
  100.       widget.setObjectName("body")  
  101.       widget.setSizePolicy(QSizePolicy.Policy.Expanding, QSizePolicy.Policy.Expanding)  
  102.       widget  
  103.     }  
  104.  
  105.     //=======================// foot部分 //=======================//  
  106.  
  107.     val foot = new QLabel("狀態欄") {  
  108.       this.setSizePolicy(QSizePolicy.Policy.Expanding, QSizePolicy.Policy.Fixed)  
  109.       this.setAlignment(new Alignment(AlignmentFlag.AlignRight, AlignmentFlag.AlignBottom))  
  110.     }  
  111.  
  112.     this.init()  
  113.  
  114.     def init() {  
  115.       titleLayout.addWidget(titleIcon)  
  116.       titleLayout.addWidget(titleText)  
  117.       frameLayout.addLayout(titleLayout)  
  118.       frameLayout.addWidget(body)  
  119.       frameLayout.addWidget(foot)  
  120.       closeBtn.setParent(this) // closeBtn***填充,因為他不在布局模式中。  
  121.     }  
  122.  
  123.     def getIcon = frame.style.standardIcon(QStyle.StandardPixmap.SP_MessageBoxInformation)  
  124.   }  
  125.  
  126.   def app = QApplication.instance  
  127.  
  128.   lazy val frame = new DemoFrame  
  129.  
  130.   def main(args: Array[String]): Unit = {  
  131.     QApplication.initialize(args)  
  132.     app.setStyleSheet(globalStyle)  
  133.     frame.resize(300, 200) // 我們可以自由的設定這個部件的大小了,調整元件的大小被我們送去showEvent里面去了  
  134.     frame.show()  
  135.     QApplication.exec  
  136.   }  
  137. }  

好了,弄了這么半天,這個窗口也終于算是做成了,這是最終的效果,雖然和之前的版本沒有什么差別,可是能拖動,效果卻很不一樣了。***來個留影合照哈!

 

后記

Qt由于是基于C++的,所以除了UI界面方面,在很多細節都進行封裝,比如有QString,QDevice,QByteArray等。而在HTTP、圖形渲染、opengl、數據庫驅動等方面類庫,Qt也都一絲不茍的移植到了Qt Jambi上。事實上,Qt似乎包攬了作為客戶端開放的方方面面,當然,其實Java自身也包含了JDBC、Swing等,權當是做一個比較吧。

【編輯推薦】

  1. 用Scala實現Qt QWidget對象的Eventable接口
  2. 用Qt實現類似QQ截圖的工具
  3. Qt 4使用MySQL的中文問題解決方法
  4. QML教程:構建和安裝QtComponents
  5. QML教程:Qt-Quick六大開源組件
責任編輯:佚名 來源: oschina
相關推薦

2018-04-17 14:41:41

Java堆內存溢出

2014-05-20 16:27:35

JVMScala

2011-06-28 11:05:19

Qt QWidget Eventable

2011-03-18 19:37:38

Eventable接口QtWidget

2011-06-13 14:29:40

Qt Designer

2009-09-07 18:14:55

Scala開發環境

2009-10-30 10:45:45

ScalaEclipseAndroid

2010-04-13 14:20:32

2011-06-20 13:05:53

Qt 4.7 Qt Quick

2012-06-08 09:28:15

EclipseScalaAndroid

2014-01-07 10:12:15

Spark

2011-06-16 16:21:06

Qt Symbian FAQ

2011-06-14 11:48:38

Webkit QT

2011-06-15 18:38:17

Linux Qt Symbian

2011-06-15 17:28:23

Qt 多視圖 架構

2011-06-08 14:24:20

JVM Qt QtJambi

2009-07-08 12:43:59

Scala ServlScala語言

2011-08-30 16:08:24

Qt4.7Qt Quick

2009-08-27 12:00:40

ibmdwJava

2020-11-24 09:50:22

大數據語言go
點贊
收藏

51CTO技術棧公眾號

欧美丰满老妇| 日韩福利影视| 中文字幕乱码亚洲精品一区| 91在线免费观看网站| 欧美黄色免费在线观看| 性人久久久久| 欧美挠脚心视频网站| 99国产精品白浆在线观看免费| 亚洲av片在线观看| 久久国产精品久久w女人spa| 另类专区欧美制服同性| 色天使在线视频| www.欧美| 日本电影亚洲天堂一区| 少妇大叫太大太粗太爽了a片小说| 欧美日韩国产中文字幕在线| 国精产品一区一区三区mba视频| 91国自产精品中文字幕亚洲| 婷婷社区五月天| 丝袜av一区| 日韩精品一区国产麻豆| 少妇激情一区二区三区| 波多一区二区| 亚洲天堂精品在线观看| 日本一区二区三区免费看| 国内精品久久久久久久久久久| 久久精品毛片| 国色天香2019中文字幕在线观看| 国产激情av在线| 色狠狠久久av综合| 日韩精品一区二区三区视频播放| 一区二区成人网| 最新欧美色图| 亚洲成av人片一区二区三区 | av在线免费在线观看| 美女爽到呻吟久久久久| 久久久久九九九九| 国产成人综合在线视频| 日韩在线中文| 伊人久久久久久久久久| 99久久久无码国产精品性| 国产香蕉精品| 精品国产免费一区二区三区四区| 91丝袜超薄交口足| 91麻豆精品| 9191成人精品久久| 天堂av在线8| 国产精品无码久久久久| 在线观看日产精品| 亚欧在线免费观看| 成人国产精品入口免费视频| 在线精品国精品国产尤物884a| 成人免费在线小视频| 国产不卡123| 精品久久久久久中文字幕一区奶水 | 国产精品视频内| 亚洲av综合一区| 日韩**一区毛片| 国产精品露脸av在线| 五月激情丁香网| 六月丁香婷婷色狠狠久久| 国产综合久久久久久| 91久久精品无码一区二区| 久久国产成人午夜av影院| 91九色国产社区在线观看| www.com在线观看| 成人毛片视频在线观看| 极品日韩久久| 国产高清在线| 亚洲三级电影全部在线观看高清| 精品嫩模一区二区三区| 97人人在线视频| 色先锋资源久久综合| 手机视频在线观看| 欧美日韩中出| 亚洲精品美女网站| 亚洲欧美va天堂人熟伦 | 国产日韩影视精品| 亚洲一区二区自拍偷拍| 91中文在线| 欧美日韩国产丝袜美女| 亚洲 欧美 日韩系列| 欧洲大片精品免费永久看nba| 日韩欧美中文字幕精品| 久久亚洲AV成人无码国产野外| 精品黄色一级片| 少妇久久久久久| 久草视频在线资源| 老司机精品福利视频| 成人国产精品免费视频| 高h震动喷水双性1v1| 久久久久久一级片| 国产午夜精品视频一区二区三区| 激情国产在线| 欧美人与z0zoxxxx视频| 污污免费在线观看| 成人精品电影| 国内精品伊人久久| 中文字幕+乱码+中文字幕明步| 国产剧情一区二区| 蜜桃麻豆91| 日本无删减在线| 在线免费精品视频| 日本wwwwwww| 97在线精品| 亲子乱一区二区三区电影| 99久久精品日本一区二区免费| 91美女在线视频| 经典三级在线视频| 亚洲综合在线电影| 亚洲成人av片| 岛国毛片在线观看| 蜜臀精品一区二区三区在线观看 | 精品1卡二卡三卡四卡老狼| 国内精品久久久久久久久电影网| 欧美日韩第一页| 一区二区视频播放| 久久综合久久鬼色中文字| 日本大胆人体视频| 深夜福利亚洲| 国产亚洲视频在线| 日日骚av一区二区| 97久久久精品综合88久久| 400部精品国偷自产在线观看| av免费在线一区| 亚洲嫩模很污视频| 亚洲一区欧美在线| 国产999精品久久久久久绿帽| 亚洲三区四区| 色婷婷综合久久久中字幕精品久久| 精品国产第一区二区三区观看体验| 成人免费视频入口| 日韩一区精品字幕| 久久久亚洲综合网站| 国产在线拍揄自揄拍视频 | jjzz黄色片| 小处雏高清一区二区三区| 国产精品久久久久久久av电影| 亚洲aaa在线观看| 亚洲444eee在线观看| 蜜桃色一区二区三区| 欧美日韩国产高清| 亚洲精品欧美日韩| 97caopron在线视频| 91精品婷婷国产综合久久竹菊| 五月天婷婷丁香网| 青青草国产精品亚洲专区无| 日韩高清av| 久久天堂av| 在线观看日韩欧美| 亚洲视频在线观看免费视频| 中文字幕国产一区| 在线观看岛国av| 国产精品二区不卡| 999精品视频一区二区三区| 人人超在线公开视频| 日韩欧美在线一区二区三区| 青娱乐免费在线视频| 成人黄色在线看| 国产亚洲欧美在线视频| 亚洲人亚洲人色久| 国产精品亚洲美女av网站| 九七电影韩国女主播在线观看| 欧美一区永久视频免费观看| 国产在线精品一区二区| 在线一区二区三区四区| 在哪里可以看毛片| 青青草国产成人av片免费| 亚洲第一精品区| 日本在线成人| 欧美极品少妇全裸体| 少妇喷水在线观看| 色系网站成人免费| www.av免费| bt欧美亚洲午夜电影天堂| 国产1区2区在线| 久久在线视频| 国产成人精品日本亚洲11 | 天天躁日日躁狠狠躁免费麻豆| 在线国产日韩| 日本亚洲自拍| 欧美国产中文高清| 91av在线精品| 日本在线免费播放| 亚洲精品一区二区三区在线观看 | 欧美日本在线播放| 黄色一级免费视频| 久久色在线视频| 在线免费看污网站| 一区二区三区高清视频在线观看| 亚洲春色在线| 国产亚洲成av人片在线观黄桃| 国产精品久久电影观看| 三级福利片在线观看| 亚洲久久久久久久久久久| 国产又黄又爽视频| 欧美丝袜美女中出在线| tube国产麻豆| 日本一区免费视频| 亚洲成人激情小说| 蜜桃久久av一区| 国产97在线 | 亚洲| 国产精品99久久| 裸模一区二区三区免费| 久久gogo国模啪啪裸体| 国产成人精品在线观看| missav|免费高清av在线看| 日韩最新av在线| 欧美孕妇孕交xxⅹ孕妇交| 欧美一区二区三区四区高清| 久久久久在线视频| 亚洲成人精品一区二区| 色老板免费视频| 亚洲国产精品精华液2区45| 国产精品久久久久久久无码| 国产乱码精品一区二区三区忘忧草| 一本大道熟女人妻中文字幕在线 | 久久高清免费| 久久久综合亚洲91久久98| 亚洲综合影院| 成人免费在线网址| 97成人超碰| 欧洲中文字幕国产精品| av资源在线| 久久久免费观看视频| 综合图区亚洲| 精品国产欧美一区二区三区成人| 黄色在线小视频| 日韩av在线免费播放| 成 人 黄 色 片 在线播放| 欧美人牲a欧美精品| 亚洲免费视频二区| 在线看国产日韩| 伊人久久中文字幕| 色综合咪咪久久| 国产视频1区2区| 日韩欧美第一页| 久久久精品免费看| 欧美性xxxxxxx| 二区视频在线观看| 色综合久久99| 日韩精品成人免费观看视频| 好吊成人免视频| 亚洲日本视频在线观看| 精品日本高清在线播放| 可以免费看的av毛片| 婷婷开心激情综合| 久久夜靖品2区| 疯狂做受xxxx欧美肥白少妇| 日本va欧美va国产激情| 粉嫩av一区二区三区免费野| 国产精品国产三级国产专区52| 欧美日韩精品在线| 日韩人妻精品中文字幕| 在线免费不卡电影| 88av在线视频| 欧美www视频| 午夜小视频在线播放| 亚洲女成人图区| 色三级在线观看| 欧美插天视频在线播放| 韩国成人免费视频| 欧美中文字幕在线视频| 无人区在线高清完整免费版 一区二 | 一区二区三区欧美成人| 手机亚洲手机国产手机日韩| 一级全黄肉体裸体全过程| 国产一区二区三区四区三区四| 日韩一级性生活片| 丝袜美腿一区二区三区| 福利视频999| 成人免费视频视频| 自拍偷拍视频亚洲| 亚洲人成伊人成综合网小说| 日本亚洲欧美在线| 欧美性生活久久| 亚洲精品一区二区三区不卡| 亚洲男人天天操| av在线看片| 欧美亚洲国产精品| 日韩城人网站| 精品国产一区二区三| 成人vr资源| 拔插拔插海外华人免费| 日韩精品乱码免费| 在线播放国产视频| 国产三区在线成人av| 国产97免费视频| 日本久久一区二区三区| 国产三区在线播放| 亚洲色图色老头| 人妖欧美1区| 国产精品网站大全| 国产色噜噜噜91在线精品| 在线一区高清| 亚洲女人av| 极品白嫩的小少妇| 国产欧美日韩在线| 免费一级特黄特色大片| 欧美日韩成人一区| 三级视频在线| 欧美精品18videos性欧美| 国产69精品久久久久按摩| 精品国产区在线| 综合五月婷婷| 91极品尤物在线播放国产| 国产一区三区三区| 日本人亚洲人jjzzjjz| 午夜亚洲福利老司机| 97人妻精品一区二区三区动漫| 亚洲美女动态图120秒| 毛片大全在线观看| 成人在线精品视频| 红桃视频在线观看一区二区| av在线播放亚洲| 国产寡妇亲子伦一区二区| 久久久久久久久福利| 欧美日韩国产在线播放| 俄罗斯嫩小性bbwbbw| 欧美精品一本久久男人的天堂| 草莓视频成人appios| 精品毛片久久久久久| 综合天天久久| 男生和女生一起差差差视频| 国产精品视频免费看| 黄色污污网站在线观看| 日韩国产精品一区| h片在线观看视频免费| av日韩免费电影| 亚洲欧洲美洲一区二区三区| 男人的天堂最新网址| 亚洲国产精品精华液ab| 中文在线免费观看| 夜夜嗨av一区二区三区四区 | 99热在线精品观看| 国产a级片视频| 亚洲精品久久久蜜桃| 国产毛片在线视频| 久久亚洲精品一区二区| 日韩黄色三级| 免费在线观看污污视频| 国内精品伊人久久久久影院对白| 亚洲欧美日韩第一页| 欧美日韩一区二区在线观看视频| 91caoporn在线| 国产欧美韩国高清| 91麻豆精品国产91久久久平台| 一女二男3p波多野结衣| 亚洲欧美综合色| 国产aⅴ爽av久久久久成人| 欧美理论电影在线播放| 一区二区日韩| 欧美牲交a欧美牲交| 久久青草欧美一区二区三区| 免费黄色片视频| 在线播放亚洲激情| 91久久青草| 女人帮男人橹视频播放| av网站一区二区三区| www.日本精品| 国产午夜一区二区| www欧美在线观看| 无码粉嫩虎白一线天在线观看 | 国产v综合v| 永久免费精品视频网站| 国产99久久久国产精品潘金网站| 国产精品第9页| 亚洲人成自拍网站| 四虎在线精品| 老太脱裤让老头玩ⅹxxxx| 91蝌蚪porny| 在线观看免费视频一区| 欧美成人精品三级在线观看| 动漫av一区| www.亚洲天堂网| 综合中文字幕亚洲| 殴美一级特黄aaaaaa| 国产精品高清在线| 欧美在线观看天堂一区二区三区| 在线天堂www在线国语对白| 在线观看亚洲专区| 欧美理论电影| 日韩欧美精品一区二区| 国产成人av电影在线| 日本熟女毛茸茸| 欧美成人免费播放| 国产成人3p视频免费观看| 人妻换人妻仑乱| 色综合天天做天天爱| 亚洲制服国产| 日韩欧美精品一区二区| 国产91精品入口| 中文字幕日日夜夜| 午夜精品久久17c| 天天综合久久| 中文字幕免费高清| 精品国产电影一区二区| 欧美一级做a| av观看免费在线| 亚洲国产精品一区二区久久|