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

Silverlight中實現(xiàn)強壯的、可復用的拖放行為

原創(chuàng)
開發(fā) 后端
富互聯(lián)網(wǎng)應用程序通過Silverlight、Ajax和Flash技術繼續(xù)保持增長,在這些應用程序中采用普通桌面用戶界面(UI)的例子也在不斷增加,最明顯的例子也許要算拖放行為了。本文將為大家講解如何在Silverlight中實現(xiàn)強壯的、可復用的拖放行為。

【51CTO獨家特稿】簡單的Silverlight拖放行為可以通過某些Silverlight控制實現(xiàn),但Silverlight的總 體表現(xiàn)卻沒有WPF中對行為控制得那么好,不過可以使用附加的行為操作元素的RenderTransform,這樣可以 大大增加Silverlight中拖放實現(xiàn)的強壯性和可復用性。

新型實現(xiàn)

默認情況下Silverlight通過System.Windows.Controls.Primitives中的Thumb控制讓拖放支持變得更容易 ,實現(xiàn)拖放最簡單的方法是使用Thumb控制和為應用程序外觀應用合適的ControlTemplate(控制模板)。但 在某些情況下,使用Thumb不太實際,在XAML中要“模板”化一個Thumb控制是很笨重的,你必須在你使用的 每個單獨的區(qū)域中為應用程序邏輯重復一次這個行為,隨著應用程序的增長,這種需求將會使應用程序的維 護變得異常困難。

不過有兩個新方法讓你可以在任何UI元素上開啟拖放操作,下面是***個方法:

MouseMove="DragDelta" MouseLeftButtonDown="DragStart" MouseLeftButtonUp="DragComplete"

VerticalAlignment="Top" Fill="#FFC20707" Stroke="#FF000000"/>

這個實現(xiàn)最重要的就是具體開啟拖放操作的事件:MouseMove、MouseLeftButtonDown和 MouseLeftButtonUp,通過在這些事件上增加處理程序,你就可以執(zhí)行一些簡單的拖放操作了。

第二個方法是:

private bool isDragging = false;

private void DragStart(object sender, MouseButtonEventArgs args)

{

   Shape draggable = sender as Shape;

   if (draggable != null)

   {

      isDragging = true;

      draggable.CaptureMouse();

   }

}

private void DragDelta(object sender, MouseEventArgs args)

{

   Shape draggable = sender as Shape;

   if (draggable != null && isDragging)

   {

      Point currentPosition = args.GetPosition(null);

      TranslateTransform transform = draggable.RenderTransform

         as TranslateTransform;

      if (transform == null)

      {

         transform = new TranslateTransform();

         draggable.RenderTransform = transform;

      }

 

      transform.X = (currentPosition.X - draggable.Width / 2);

      transform.Y = (currentPosition.Y - draggable.Height / 2);

   }

}

 

private void DragComplete(object sender, MouseButtonEventArgs args)

{

   Shape draggable = sender as Shape;

   if (draggable != null)

   {

      isDragging = false;

      draggable.ReleaseMouseCapture();

   }

}

正如你所看到的,通過影響控制RenderTransform而不是特定面板布局參數(shù),如Canvas.Top和Canvas.Left 等附加屬性,或是Grid邊緣空白,你可以將一個元素移動到任何一個容器中,而且這種方法對任何一個UI元 素都是可復用的,它不允許你橫跨不同的控制重新使用應用程序邏輯,為此,你需要一個具有附加行為的實 現(xiàn)。

使用附加行為

WPF和.NET 3.0引入了依賴屬性概念,也就是說當屬性發(fā)生變化后,它會通知所有者(它必須是一個 DependencyObject[依賴對象]),允許所有者執(zhí)行一塊應用程序邏輯。

有兩種類型的依賴屬性,最常用的是依賴屬性自身,建立和使用DependencyProperty.Register進行設置 都是相同的依賴對象。第二種類型是附加屬性,使用DependencyProperty.RegisterAttached進行設置,附加 屬性被設置為它所有者不同的類型。

看一下下么的附加屬性例子:

public static readonly DependencyProperty HoverProperty = 

   DependencyProperty.RegisterAttached(

   "Hover",

   typeof(Brush),

   typeof(Hover),

   new PropertyMetadata(null, OnHoverChanged));

通過事件處理程序OnHoverChanged,當你在XAML中設置那個屬性時,你可以提供一些應用程序邏輯:

private static void OnHoverChanged(DependencyObject obj,   

   DependencyPropertyChangedEventArgs args)

{

   Border border = obj as Border;

   if (border != null)

   {

      if(args.OldValue == null && args.NewValue != null)

      {

         border.MouseEnter += SetHoverBackground;

         border.MouseLeave += SetNotHoverBackground;

      }

      else if(args.OldValue != null && args.NewValue == null)

      {

         border.MouseEnter -= SetHoverBackground;

         border.MouseLeave -= SetNotHoverBackground;

      }

   }

}

OnHoverChanged代碼僅僅簡單地增加了事件處理程序,在觸發(fā)MouseEnter事件時修改對象的背景顏色,觸 發(fā)MouseLeave事件時還原到對象的原始顏色,這段簡短的代碼功能叫做附加行為,附加行為是后面章節(jié)講述 的拖放實現(xiàn)的核心概念,下么來看一個附加行為IsEnabled:

public static readonly DependencyProperty IsEnabledProperty
=

   DependencyProperty.RegisterAttached(

   "IsEnabled",

   typeof(bool),

   typeof(SimpleDragDropBehavior),

   new PropertyMetadata(false, OnIsEnabledChanged));

通過注冊OnIsEnabledChanged作為改變事件處理程序的屬性,你可以訂閱你前面使用的事件處理程序:

private static void OnIsEnabledChanged(DependencyObject obj, 

   DependencyPropertyChangedEventArgs args)

{

   UIElement dragSource = obj as UIElement;

 

   bool wasEnabled = (args.OldValue != null) ? (bool)args.OldValue : false;

   bool isEnabled = (args.NewValue != null) ? (bool)args.NewValue : false;

//如果行為被禁用,移除這個事件處理程序

   if (wasEnabled && !isEnabled)

   {

      dragSource.MouseLeftButtonDown -= DragStart;

   }

//如果行為被附加,添加這個事件處理程序

   if (!wasEnabled && isEnabled)

   {

      dragSource.MouseLeftButtonDown += DragStart;

   }

}

改變事件處理程序的屬性IsEnabled使用前面談到的新型實現(xiàn)向事件添加處理程序,因此,只需要在你的 應用程序中任何或是有UI元素上重復使用這個行為,但這種新型實現(xiàn)有其自身的設置限制,還不能立即顯現(xiàn) 出來。

調(diào)用args.GetPosition(null)跟蹤絕對位置不能適應一個允許嵌套拖放的行為,更好的解決辦法是反復計 算拖動的變量,為了解決這個限制,你可以轉向私有附加屬性,在思考私有附加行為的范圍時,私有附加屬 性和私有成員變量或屬性類似,公共附加行為和公共附加屬性類似。因為你只需要跟蹤你所選元素的x和y坐 標值,因此需要兩個私有附加屬性:

public static readonly DependencyProperty XProperty = 

   DependencyProperty.RegisterAttached(

   "X",

   typeof(double),

   typeof(DragDropBehavior),

   new PropertyMetadata(double.NaN));

 

public static readonly DependencyProperty YProperty =

   DependencyProperty.RegisterAttached(

   "Y",

   typeof(double),

   typeof(DragDropBehavior),

   new PropertyMetadata(double.NaN));

這些屬性的默認值都是double.NAN,表明對象當前沒有拖放位置,這對于后面拖放元素時重置元素是很重 要的,此外這些私有附加屬性,你還需要知道哪些容器是用于參照的,也就是說你需要指定原始的坐標值, (X,Y) = (0,0),你只需要簡單地位你的宿主指定另一個附加屬性:

public static readonly DependencyProperty IsHostProperty 

= 

   DependencyProperty.RegisterAttached(

   "IsHost",

   typeof(bool),

   typeof(DragDropBehavior),

   new PropertyMetadata (false));

現(xiàn)在你已經(jīng)為你反復跟蹤拖放行為建立起了必要的數(shù)據(jù),你需要做的全部內(nèi)容是實現(xiàn)前面定義的相同的三 個處理程序:DragStart,DragDelta,DragComplete。在DragStart中,你可以增加更多的功能,在你的行為 類中改成使用靜態(tài)函數(shù):

private static void DragStart(object sender, MouseButtonEventArgs args)

{

   UIElement dragSource = sender as UIElement;

//創(chuàng)建執(zhí)行拖動操作的TranslateTransform

   TranslateTransform dragTransform = new TranslateTransform();

   dragTransform.X = 0;

   dragTransform.Y = 0;

//如果是首次使用拖放,先要設置TranslateTransform

   dragSource.RenderTransform = (

      dragSource.RenderTransform is TranslateTransform) ?

      dragSource.RenderTransform : dragTransform;

//分別為MouseMove和MouseLeftButtonUp添加事件處理程序

   dragSource.MouseMove += OnDragDelta;

   dragSource.MouseLeftButtonUp += OnDragComplete;

//捕獲鼠標

   dragSource.CaptureMouse();

}

這和你最初的實現(xiàn)相差不多,你獲得了一個拖動項目,設置它的RenderTransform,附加適當?shù)氖录幚?程序,并捕獲鼠標。但DragDelta實現(xiàn)完全不同,因為你現(xiàn)在跟蹤的是鼠標動作了,你需要:

1、找到你的宿主容器;

2、相對這個容器計算當前位置;

3、比較前一次記錄的位置和現(xiàn)在的位置,計算出拖動變量;

4、更新RenderTransform和你的私有附加屬性,x和y。

private static void DragDelta(object sender, MouseEventArgs args)

{

   FrameworkElement dragSource = sender as FrameworkElement;

//計算dragSource的偏移量,更新TranslateTransform

   FrameworkElement dragDropHost = FindDragDropHost(dragSource);

   Point relativeLocationInHost = args.GetPosition(dragDropHost);

   Point relativeLocationInSource = args.GetPosition(dragSource);

//獲得當前位置

   double xPosition = GetX(dragSource);

   double yPosition = GetY(dragSource);

//從前一次位置計算變數(shù)

   double xChange = relativeLocationInHost.X - xPosition;

   double yChange = relativeLocationInHost.Y - yPosition;

//如果這不是首次鼠標移動,更新位置

   if (!double.IsNaN(xPosition))

   {

      ((TranslateTransform)dragSource.RenderTransform).X += xChange;

   }

 

   if (!double.IsNaN(yPosition))

   {

      ((TranslateTransform)dragSource.RenderTransform).Y += yChange;

   }

//更新你的私有附加屬性跟蹤拖動位置

   SetX(dragSource, relativeLocationInHost.X);

   SetY(dragSource, relativeLocationInHost.Y);

}

需要特別指出的是找出參照宿主非常重要,不過說來也很簡單,只需要在可視化樹結構中搜索IsHost = true即可。

DragComplete新的實現(xiàn)

現(xiàn)在,DragStart和DragDelta中的部件算是全部弄好了,現(xiàn)在只剩下DragComplete了,和DragStart一樣 ,DragComplete實現(xiàn)和你的新型實現(xiàn)不是完全一樣,值得注意的是它移除了事件處理程序,并釋放了鼠標捕 獲,你也必須重置你的私有附加屬性x和y,指出拖動項目不再進行拖動了。

private static void DragComplete(object sender, 

   MouseButtonEventArgs args)

{

   UIElement dragSource = sender as UIElement;

   dragSource.MouseMove -= DragDelta;

   dragSource.MouseLeftButtonUp -= DragComplete;

//設置x和y的值,以便下一次MouseDown時好重置

   SetX(dragSource, double.NaN);

   SetY(dragSource, double.NaN);

//釋放鼠標捕獲

   dragSource.ReleaseMouseCapture();

}

這個新的迭代實現(xiàn)克服了前面描述的限制,它也允許流暢跟蹤鼠標,在新的實現(xiàn)中,你只需要把鼠標放在 拖動項目的中心,在前面的實現(xiàn)中,鼠標需要保持放在容器里面。

public static FrameworkElement FindDragDropHost(

   UIElement element)

{

   DependencyObject parent = VisualTreeHelper.GetParent(element);

   while (parent != null && !GetIsHost(parent))

   {

      parent = VisualTreeHelper.GetParent(parent);

   }

   return parent as FrameworkElement;

}

限制和擴展

值得注意的是本文講述的拖放行為也有一些限制,這將成為未來的改進方向。首先,即使這種方法能夠在 一個容器中實現(xiàn)簡單的拖放,但在拖放的不同階段不能接受更強壯的應用程序邏輯,但在WPF中卻可以實現(xiàn), 如DragEnter、DragLeave和Drop在Silverlight中就還不能實現(xiàn),但你可以通過自定義附加事件實現(xiàn)來增加這 些功能。

在設置IsEnabled后,行為也不能執(zhí)行自定義拖放邏輯,如果在拖放實現(xiàn)中使用了Canvas.Top和 Canvas.Left,意味著你需要使用獨立的附加行為,而不是使用自定義事件。這是因為Silverlight缺乏附加 事件引起的,在Silverlight 3.0這將可能會有這些特性,但你可以通過復雜的行為實現(xiàn)來克服這些限制,這 個內(nèi)容已經(jīng)超出了本文的范疇,這里概述的方法傾向為一個起點,更好的實現(xiàn)希望通過開源Silverlight庫 Quasar來實現(xiàn)。

您正在閱讀的是51CTO獨家特稿《Silverlight中實現(xiàn)強壯的、可復用的拖放行為

【編輯推薦】

  1. VS 2010 Beta1和Silverlight不得不說的事
  2. Flash與Silverlight多領域實測對比
  3. 詳解 Silverlight和WPF互相擴展
責任編輯:彭凡 來源: 51CTO
相關推薦

2009-09-02 18:28:55

.NET框架ESBasic

2009-12-30 10:25:03

Silverlight

2009-03-16 09:16:13

行為擴展WCF.NET

2022-03-11 11:51:16

自動駕駛智能技術

2023-08-26 20:51:25

Python函數(shù)代碼

2009-02-20 08:54:20

DownloaderSilverlight對象

2009-06-03 10:24:11

LoadMaskSilverlight

2024-12-20 19:38:01

ToB業(yè)務狀態(tài)轉換

2017-10-26 21:08:15

Tomcat可插拔SCI

2009-09-27 13:38:03

Silverlight

2009-09-28 10:35:45

Silverlight

2009-11-06 13:40:30

Silverlight

2021-02-02 11:02:20

React任務饑餓行為優(yōu)先級任務

2010-06-02 09:25:29

Silverlight

2009-11-26 13:12:16

Silverlight

2010-04-23 13:23:42

Silverlight

2017-11-08 12:51:12

2023-12-15 16:07:40

物聯(lián)網(wǎng)

2009-06-29 18:09:12

多路復用Oracle

2009-02-09 08:55:12

ArcGIS API發(fā)布Silverlight
點贊
收藏

51CTO技術棧公眾號

99麻豆久久久国产精品免费| 欧美~级网站不卡| 日本韩国欧美三级| 神马一区二区影院| 国产黄a三级三级看三级| 亚洲午夜激情在线| 伊人久久免费视频| 欧美熟妇精品一区二区| 网友自拍亚洲| 一区二区在线观看视频在线观看| 久久精品女人的天堂av| 亚洲在线免费观看视频| 在线观看的日韩av| 精品国产一区二区三区久久| 亚洲精品乱码久久| 中文字幕成人| 色婷婷av久久久久久久| 国产尤物av一区二区三区| 嫩草研究院在线观看| 韩国av一区二区三区在线观看| 97视频在线播放| 国产精品精品软件男同| 亚洲美女久久| 精品免费日韩av| 网站一区二区三区| 新版的欧美在线视频| 一区二区在线观看视频| 亚洲欧美99| 你懂得网站在线| av电影在线观看不卡| 91沈先生作品| 亚洲综合精品视频| 久久婷婷一区| 欧美性做爰毛片| 日本午夜小视频| 午夜精品免费| 久久亚洲精品国产亚洲老地址| 中文幕无线码中文字蜜桃| 91九色鹿精品国产综合久久香蕉| 欧美日韩高清一区二区三区| 欧美成人免费高清视频| 国产一二三在线| 亚洲一区二区av电影| 热久久最新网址| 国产婷婷视频在线| 国产精品毛片a∨一区二区三区| 欧美国产综合视频| 天堂影院在线| 2欧美一区二区三区在线观看视频| av一区二区在线看| 午夜精品无码一区二区三区| 国产精一区二区三区| 91免费福利视频| 一区二区日韩视频| 精品一区二区三区av| 国产日韩欧美91| 97超碰中文字幕| 精品一区二区三区蜜桃| 91日本在线视频| 国产偷拍一区二区| 国产乱码精品一品二品| 成人自拍爱视频| 日本高清视频在线| 99亚偷拍自图区亚洲| 精品乱子伦一区二区三区| 日韩专区第一页| 92精品国产成人观看免费| 六月婷婷久久| 欧美日本韩国一区二区| 国产视频一区二区在线| 亚洲欧美综合一区| 在线中文字幕第一页| 亚洲午夜在线电影| 国内性生活视频| 日韩理论在线观看| 久精品免费视频| 久久免费小视频| 亚洲日韩视频| 日本乱人伦a精品| 成人午夜精品视频| 国产在线一区观看| 国产超碰91| 天堂中文字幕在线| 国产精品久久久久久户外露出| 亚洲欧美精品在线观看| 农村末发育av片一区二区| 日韩视频中文字幕在线观看| 国产一区二区在线| 久久国产一区二区三区| 九九九免费视频| 99在线精品视频在线观看| 国产成人97精品免费看片| 91成品人影院| 不卡一区二区三区四区| 四虎影院一区二区三区| av免费在线免费观看| 亚洲18女电影在线观看| 人人干人人视频| a级日韩大片| 亚洲天堂日韩电影| 日本老熟俱乐部h0930| 国产一区导航| 91久久夜色精品国产网站| 性插视频在线观看| 亚洲天堂福利av| 日韩在线综合网| 中文字幕综合| 亚洲欧洲一区二区三区久久| 日本少妇高清视频| 视频一区二区中文字幕| 99re热精品| av资源在线观看免费高清| 亚洲在线视频一区| 麻豆一区二区三区视频| 久久porn| 欧美老女人性视频| 亚洲在线精品视频| 久久久精品免费免费| 日韩a级黄色片| 日韩黄色碟片| 亚洲视频资源在线| 日韩成人久久久| 欧美特黄一区二区三区| 欧美日韩精品免费观看视频完整| 国产成人精品一区| 人妻偷人精品一区二区三区| 亚洲三级免费观看| 999精品视频在线| 亚洲国产欧美日韩在线观看第一区| 久久在精品线影院精品国产| 免费看日批视频| youjizz国产精品| 亚洲激情免费视频| 日日狠狠久久| 神马久久桃色视频| 激情五月婷婷网| 91色在线porny| 97视频在线免费| 亚洲高清在线一区| 欧美大胆在线视频| 91久久国语露脸精品国产高跟| 91老师国产黑色丝袜在线| 国产日韩av网站| 波多野结衣欧美| 欧美美女操人视频| 国产精品久久久国产盗摄| 亚洲国产精品黑人久久久| 日本在线视频www| 免费久久精品| 国产精品91一区| 国产精品久久久久一区二区国产| 国产一区二区三区在线观看| 国产91综合网| 成人在线视频一区二区三区| 亚洲**毛片| 欧美激情国产精品| 国产按摩一区二区三区| 亚洲精品亚洲人成人网在线播放| 亚洲一区二区三区四区五区| 久久精品国内一区二区三区水蜜桃| 成人有码在线播放| 18网站在线观看| 亚洲二区中文字幕| 国产精品乱子伦| 国产精品午夜在线观看| 亚洲一区二区三区观看| 欧美国产综合| 国产在线精品一区二区三区》| 深夜av在线| 在线播放亚洲激情| 国产露脸国语对白在线| 亚洲黄色在线视频| www.日本高清| 日韩经典一区二区| 美女黄色片网站| 国产乱人伦精品一区| 日本欧美在线视频| 日本三级在线播放完整版| 日韩欧美专区在线| 国产性猛交╳xxx乱大交| 国产精品欧美久久久久无广告| 午夜免费福利视频在线观看| 欧美日韩爆操| 蜜桃av噜噜一区二区三| 伊人久久精品| 高清一区二区三区日本久| 精品成人一区二区三区免费视频| 欧美三区免费完整视频在线观看| 男人操女人的视频网站| 91在线视频网址| 亚洲一区精品视频在线观看| 亚洲第一伊人| 亚洲自拍偷拍二区| 国产成人精品亚洲线观看| 国产精品美女网站| 国产亚av手机在线观看| 亚洲最新在线视频| 亚洲爆乳无码一区二区三区| 91国偷自产一区二区三区成为亚洲经典 | 成人写真福利网| 99thz桃花论族在线播放| 伊人男人综合视频网| 国内精品国产成人国产三级| 欧美性猛交xxxx乱大交蜜桃| 91porn在线视频| 国产亚洲欧美日韩俺去了| 成人免费播放视频| 首页欧美精品中文字幕| 国产精品日韩三级| 久久国产中文字幕| 久久精品国产综合精品| 国产在线一区不卡| 国产盗摄xxxx视频xxx69| 污视频网站在线免费| 中文字幕日韩精品在线| 亚洲区小说区图片区| 日韩一区二区三区观看| 中文人妻熟女乱又乱精品| 亚洲va欧美va国产va天堂影院| 蜜桃av.com| 国产视频911| 免费成人蒂法网站| 国产二区国产一区在线观看| 一级片视频免费观看| 免费在线亚洲欧美| 日本a在线免费观看| 综合久久婷婷| 国产免费一区二区三区四在线播放| 国产成人av| 免费亚洲精品视频| 日韩欧美ww| 精品日本一区二区三区| 国产成人精品福利| 成人动漫在线观看视频| 91麻豆精品国产综合久久久 | 粗暴蹂躏中文一区二区三区| 国产日产精品久久久久久婷婷| 亚洲二区在线播放视频| 黄色av网址在线| 欧美成人vps| 国产成人毛毛毛片| 欧美一区二区成人| 国产精品视频第一页| 欧美日本一区二区| 国产精品xxxxxx| 日本久久一区二区| 亚洲精品成人在线视频| 五月天欧美精品| 日产电影一区二区三区| 亚洲国产视频在线| 成人免费看片98| 亚洲国产成人tv| 欧美精品亚洲精品日韩精品| 精品久久久免费| 亚洲va在线观看| 91精品1区2区| 一区二区视频免费观看| 欧美狂野另类xxxxoooo| 国产精品一区二区av白丝下载| 6080日韩午夜伦伦午夜伦| 国产女人高潮的av毛片| 精品精品国产高清一毛片一天堂| 国产香蕉在线观看| 亚洲精品黄网在线观看| 女人偷人在线视频| 日韩在线观看你懂的| 国产黄a三级三级三级av在线看| 欧美成年人网站| 岛国毛片av在线| 欧洲精品毛片网站| 中文.日本.精品| 91久久国产婷婷一区二区| 欧美久久一区二区三区| 国产一区在线观| 欧美人与牛zoz0性行为| 性欧美videosex高清少妇| 羞羞答答成人影院www| 香港三级日本三级a视频| 亚洲永久字幕| 羞羞的视频在线| 国产91高潮流白浆在线麻豆 | 国产va免费精品观看精品视频| 三级三级久久三级久久18| 亚洲中无吗在线| a在线视频观看| 美女视频黄 久久| 日本人dh亚洲人ⅹxx| 久久蜜臀精品av| 欧美激情图片小说| 欧美日韩在线视频一区| 一级特黄aaa大片在线观看| 精品对白一区国产伦| 国产色在线 com| 欧美日韩ab片| 黄色成人免费网| 99精彩视频| 精品一区二区三区中文字幕老牛| 女女百合国产免费网站| 天堂影院一区二区| 麻豆av免费看| 国产精品美女久久久久高潮| 日本在线视频免费观看| 欧美日韩视频在线一区二区| 蜜臀av免费在线观看| 日韩亚洲国产中文字幕| 一个人www视频在线免费观看| 91人成网站www| 国产影视精品一区二区三区| 国产 欧美 日韩 一区| 麻豆91在线播放免费| 黄色性生活一级片| 亚洲精品写真福利| 少妇无套内谢久久久久| 亚洲国产日韩欧美在线动漫| 黄色在线免费网站| 国产精品va在线播放| 欧美激情影院| 91精品国产毛片武则天| 麻豆freexxxx性91精品| 国产三级av在线播放| 午夜精品国产更新| 性一交一乱一伧老太| 日韩三级影视基地| 素人一区二区三区| 欧美日韩亚洲一区二区三区在线观看| 欧美午夜视频| 日韩不卡的av| 18欧美乱大交hd1984| 中文天堂在线播放| 国产小视频国产精品| 最新中文字幕在线播放| 精品伊人久久大线蕉色首页| 国产专区一区| 色欲欲www成人网站| 一区二区三区在线视频免费观看| 一区二区三区精彩视频| 中文字幕视频在线免费欧美日韩综合在线看| 色多多在线观看| 精品国产乱码久久久久久久软件| 一区在线观看| wwwxx日本| 午夜精品aaa| 色婷婷av一区二区三区之红樱桃 | 久草国产在线观看| 91精品国产91久久久久久最新毛片 | 永久555www成人免费| 台湾佬成人网| 日韩电影免费观看在| 日韩成人午夜电影| 天天舔天天操天天干| 欧美视频中文字幕| h网站视频在线观看| 国产精品久久久久久久久久三级| 国产99久久久国产精品成人免费 | 国产1区2区3区精品美女| 欧美片一区二区| 亚洲电影天堂av| 中文在线аv在线| 欧美精品一区三区在线观看| 日韩精品成人一区二区三区| 黄色激情小视频| 91精品国产麻豆国产自产在线| 深夜国产在线播放| 国产综合 伊人色| 日韩国产一区二| 亚洲欧美另类日本| 日韩视频在线你懂得| 国产精品电影| 日韩免费三级| 国内成人免费视频| 免费一级特黄特色大片| 日韩av在线网页| 国语自产精品视频在线看抢先版结局| 中文字幕欧美日韩一区二区| 国产成人av一区二区三区在线| 日本天堂网在线观看| 国产香蕉97碰碰久久人人| 91精品国产一区二区在线观看| 波多野结衣av一区二区全免费观看 | av在线免费一区| 91传媒视频免费| 国产精品久久久一区二区| 亚洲色图第四色| 日韩欧美国产系列| 老司机2019福利精品视频导航| 中文字幕中文字幕99| www.激情成人| 91女人18毛片水多国产| 久久久欧美一区二区| 欧美精品久久久久久| 91精品国产高清91久久久久久| 日韩欧美第一页| 高清全集视频免费在线| 精品欧美一区二区久久久伦| 久久精品国产成人一区二区三区 | 国产乱码精品一区二区三区卡| 久久一区激情| 69精品久久久| 精品国产欧美一区二区三区成人| 日韩极品少妇|