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

Android源碼進(jìn)階之ViewDragHelper原理機(jī)制解析

移動(dòng)開發(fā) Android
tryCaptureView(View child, int pointerId) 這是一個(gè)抽象類,必須去實(shí)現(xiàn),也只有在這個(gè)方法返回true的時(shí)候下面的方法才會(huì)生效。

[[422791]]

本文轉(zhuǎn)載自微信公眾號(hào)「Android開發(fā)編程」,作者Android開發(fā)編程 。轉(zhuǎn)載本文請(qǐng)聯(lián)系A(chǔ)ndroid開發(fā)編程公眾號(hào)。

前言

ViewDragHelper類,是用來處理View邊界拖動(dòng)相關(guān)的類;

主要功能處理在View上的觸摸事件,記錄觸摸點(diǎn)、計(jì)算距離、滾動(dòng)動(dòng)畫、狀態(tài)回調(diào)等,如果我們自己手動(dòng)實(shí)現(xiàn)自然會(huì)很麻煩還可能出錯(cuò),而這個(gè)類會(huì)幫助我們大大簡化工作量;

今天我們就來分析一波;

一、ViewDragHelper的中主要API介紹

1、ViewDragHelper create(ViewGroup forParent, Callback cb)

一個(gè)靜態(tài)的創(chuàng)建方法;

  • 參數(shù)1:出入的是相應(yīng)的ViewGroup;
  • 參數(shù)2:是一個(gè)回掉,需要自己實(shí)現(xiàn);

2、shouldInterceptTouchEvent(MotionEvent ev)

處理事件分發(fā)的(怎么說這個(gè)方法呢?主要是將ViewGroup的事件分發(fā),委托給ViewDragHelper進(jìn)行處理);

  • 參數(shù)1:MotionEvent ev 主要是ViewGroup的事件;

3、processTouchEvent(MotionEvent event)

處理相應(yīng)TouchEvent的方法,這里要注意一個(gè)問題,處理相應(yīng)的TouchEvent的時(shí)候要將結(jié)果返回為true,消費(fèi)本次事件,否則將無法使用ViewDragHelper處理相應(yīng)的拖拽事件;

4、ViewDragHelper.Callback的API

tryCaptureView(View child, int pointerId) 這是一個(gè)抽象類,必須去實(shí)現(xiàn),也只有在這個(gè)方法返回true的時(shí)候下面的方法才會(huì)生效;

onViewDragStateChanged(int state) 當(dāng)狀態(tài)改變的時(shí)候回調(diào),返回相應(yīng)的狀態(tài)(這里有三種狀態(tài));

  • STATE_IDLE 閑置狀態(tài);
  • STATE_DRAGGING 正在拖動(dòng);
  • STATE_SETTLING 放置到某個(gè)位置;

onViewPositionChanged(View changedView, int left, int top, int dx, int dy) 當(dāng)你拖動(dòng)的View位置發(fā)生改變的時(shí)候回調(diào);

  • 參數(shù)1:你當(dāng)前拖動(dòng)的這個(gè)View
  • 參數(shù)2:距離左邊的距離
  • 參數(shù)3:距離右邊的距離
  • 參數(shù)4:x軸的變化量
  • 參數(shù)5:y軸的變化量

onViewCaptured(View capturedChild, int activePointerId)捕獲View的時(shí)候調(diào)用的方法

  • 參數(shù)1:捕獲的View(也就是你拖動(dòng)的這個(gè)View);
  • 參數(shù)2:這個(gè)參數(shù)我也不知道什么意思API中寫的一個(gè)什么指針,這里沒有到也沒有注意;

onViewReleased(View releasedChild, float xvel, float yvel) 當(dāng)View停止拖拽的時(shí)候調(diào)用的方法

  • 參數(shù)1:你拖拽的這個(gè)View
  • 參數(shù)2:x軸的速率
  • 參數(shù)3:y軸的速率

clampViewPositionVertical(View child, int top, int dy) 豎直拖拽的時(shí)候回調(diào)的方法

  • 參數(shù)1:拖拽的View
  • 參數(shù)2:距離頂部的距離
  • 參數(shù)3:變化量

clampViewPositionHorizontal(View child, int left, int dx) 水平拖拽的時(shí)候回調(diào)的方法

  • 參數(shù)1:拖拽的View
  • 參數(shù)2:距離左邊的距離
  • 參數(shù)3:變化量

二、實(shí)現(xiàn)原理介紹

1、初始化

  1. private ViewDragHelper(Context context, ViewGroup forParent, Callback cb) { 
  2.         ... 
  3.         mParentView = forParent;//BaseView 
  4.         mCallback = cb;//callback 
  5.         final ViewConfiguration vc = ViewConfiguration.get(context); 
  6.         final float density = context.getResources().getDisplayMetrics().density; 
  7.         mEdgeSize = (int) (EDGE_SIZE * density + 0.5f);//邊界拖動(dòng)距離范圍 
  8.         mTouchSlop = vc.getScaledTouchSlop();//拖動(dòng)距離閾值 
  9.         mScroller = new OverScroller(context, sInterpolator);//滾動(dòng)器 
  10.     } 
  • mParentView是指基于哪個(gè)View進(jìn)行觸摸處理;
  • mCallback是觸摸處理的各個(gè)階段的回調(diào);
  • mEdgeSize是指在邊界多少距離內(nèi)算作拖動(dòng),默認(rèn)為20dp;
  • mTouchSlop指滑動(dòng)多少距離算作拖動(dòng),用的系統(tǒng)默認(rèn)值;
  • mScroller是View滾動(dòng)的Scroller對(duì)象,用于處理釋觸摸放后,View的滾動(dòng)行為,比如滾動(dòng)回原始位置或者滾動(dòng)出屏幕;

2.攔截事件處理

該類提供了boolean shouldInterceptTouchEvent(MotionEvent)方法:

  1. override fun onInterceptTouchEvent(ev: MotionEvent?) = 
  2.             dragHelper?.shouldInterceptTouchEvent(ev) ?: super.onInterceptTouchEvent(ev) 

該方法用于處理mParentView是否攔截此次事件

  1. public boolean shouldInterceptTouchEvent(MotionEvent ev) { 
  2.         ... 
  3.         switch (action) { 
  4.             ... 
  5.             case MotionEvent.ACTION_MOVE: { 
  6.                 if (mInitialMotionX == null || mInitialMotionY == null) break; 
  7.                 // First to cross a touch slop over a draggable view wins. Also report edge drags. 
  8.                 final int pointerCount = ev.getPointerCount(); 
  9.                 for (int i = 0; i < pointerCount; i++) { 
  10.                     final int pointerId = ev.getPointerId(i); 
  11.                     // If pointer is invalid then skip the ACTION_MOVE. 
  12.                     if (!isValidPointerForActionMove(pointerId)) continue
  13.                     final float x = ev.getX(i); 
  14.                     final float y = ev.getY(i); 
  15.                     final float dx = x - mInitialMotionX[pointerId]; 
  16.                     final float dy = y - mInitialMotionY[pointerId]; 
  17.                     final View toCapture = findTopChildUnder((int) x, (int) y); 
  18.                     final boolean pastSlop = toCapture != null && checkTouchSlop(toCapture, dx, dy); 
  19.                     ... 
  20.                     //判斷pointer的拖動(dòng)邊界 
  21.                     reportNewEdgeDrags(dx, dy, pointerId); 
  22.                     ... 
  23.                 } 
  24.                 saveLastMotion(ev); 
  25.                 break; 
  26.             } 
  27.             ... 
  28.         } 
  29.         return mDragState == STATE_DRAGGING; 

攔截事件的前提是mDragState為STATE_DRAGGING,也就是正在拖動(dòng)狀態(tài)下才會(huì)攔截,那么什么時(shí)候會(huì)變?yōu)橥蟿?dòng)狀態(tài)呢?當(dāng)ACTION_MOVE時(shí),調(diào)用reportNewEdgeDrags方法:

  1. private void reportNewEdgeDrags(float dx, float dy, int pointerId) { 
  2.         int dragsStarted = 0; 
  3.   //判斷是否在Left邊緣進(jìn)行滑動(dòng) 
  4.         if (checkNewEdgeDrag(dx, dy, pointerId, EDGE_LEFT)) { 
  5.             dragsStarted |= EDGE_LEFT; 
  6.         } 
  7.         if (checkNewEdgeDrag(dy, dx, pointerId, EDGE_TOP)) { 
  8.             dragsStarted |= EDGE_TOP; 
  9.         } 
  10.         ... 
  11.         if (dragsStarted != 0) { 
  12.             mEdgeDragsInProgress[pointerId] |= dragsStarted; 
  13.           //回調(diào)拖動(dòng)的邊 
  14.             mCallback.onEdgeDragStarted(dragsStarted, pointerId); 
  15.         } 
  16. private boolean checkNewEdgeDrag(float delta, float odelta, int pointerId, int edge) { 
  17.         final float absDelta = Math.abs(delta); 
  18.         final float absODelta = Math.abs(odelta); 
  19. //是否支持edge的拖動(dòng)以及是否滿足拖動(dòng)距離的閾值 
  20.         if ((mInitialEdgesTouched[pointerId] & edge) != edge  || (mTrackingEdges & edge) == 0 
  21.                 || (mEdgeDragsLocked[pointerId] & edge) == edge 
  22.                 || (mEdgeDragsInProgress[pointerId] & edge) == edge 
  23.                 || (absDelta <= mTouchSlop && absODelta <= mTouchSlop)) { 
  24.             return false
  25.         } 
  26.         if (absDelta < absODelta * 0.5f && mCallback.onEdgeLock(edge)) { 
  27.             mEdgeDragsLocked[pointerId] |= edge; 
  28.             return false
  29.         } 
  30.         return (mEdgeDragsInProgress[pointerId] & edge) == 0 && absDelta > mTouchSlop; 

可以看到,當(dāng)ACTION_MOVE時(shí),會(huì)嘗試找到pointer對(duì)應(yīng)的拖動(dòng)邊界,這個(gè)邊界可以由我們來制定,比如側(cè)滑關(guān)閉頁面是從左側(cè)開始的,所以我們可以調(diào)用setEdgeTrackingEnabled(ViewDragHelper.EDGE_LEFT)來設(shè)置只支持左側(cè)滑動(dòng)。而一旦有滾動(dòng)發(fā)生,就會(huì)回調(diào)callback的onEdgeDragStarted方法,交由我們做如下操作:

  1. override fun onEdgeDragStarted(edgeFlags: Int, pointerId: Int) { 
  2.                 super.onEdgeDragStarted(edgeFlags, pointerId) 
  3.                 dragHelper?.captureChildView(getChildAt(0), pointerId) 
  4.             } 
  5. 我們調(diào)用了ViewDragHelper的captureChildView方法: 
  6. public void captureChildView(View childView, int activePointerId) { 
  7.         mCapturedView = childView;//記錄拖動(dòng)view 
  8.         mActivePointerId = activePointerId; 
  9.         mCallback.onViewCaptured(childView, activePointerId); 
  10.         setDragState(STATE_DRAGGING);//設(shè)置狀態(tài)為開始拖動(dòng) 

此時(shí),就記錄了拖動(dòng)的View,并將狀態(tài)置為拖動(dòng),那么在下次ACTION_MOVE的時(shí)候,該mParentView就會(huì)攔截事件,交由自己的onTouchEvent方法處理拖動(dòng)了;

3.拖動(dòng)事件處理

該類提供了void processTouchEvent(MotionEvent)方法,通常我們需要這么寫:

  1. override fun onTouchEvent(event: MotionEvent?): Boolean { 
  2.         dragHelper?.processTouchEvent(event)//交由ViewDragHelper處理 
  3.         return true 

該方法用于處理mParentView攔截事件后的拖動(dòng)處理:

  1. public void processTouchEvent(MotionEvent ev) { 
  2.         ... 
  3.         switch (action) { 
  4.             ... 
  5.             case MotionEvent.ACTION_MOVE: { 
  6.                 if (mDragState == STATE_DRAGGING) { 
  7.                     // If pointer is invalid then skip the ACTION_MOVE. 
  8.                     if (!isValidPointerForActionMove(mActivePointerId)) break; 
  9.                     final int index = ev.findPointerIndex(mActivePointerId); 
  10.                     final float x = ev.getX(index); 
  11.                     final float y = ev.getY(index); 
  12.                     //計(jì)算距離上次的拖動(dòng)距離 
  13.                     final int idx = (int) (x - mLastMotionX[mActivePointerId]); 
  14.                     final int idy = (int) (y - mLastMotionY[mActivePointerId]); 
  15.                     dragTo(mCapturedView.getLeft() + idx, mCapturedView.getTop() + idy, idx, idy);//處理拖動(dòng) 
  16.                     saveLastMotion(ev);//記錄當(dāng)前觸摸點(diǎn) 
  17.                 }... 
  18.                 break; 
  19.             } 
  20.             ... 
  21.             case MotionEvent.ACTION_UP: { 
  22.                 if (mDragState == STATE_DRAGGING) { 
  23.                     releaseViewForPointerUp();//釋放拖動(dòng)view 
  24.                 } 
  25.                 cancel(); 
  26.                 break; 
  27.             }... 
  28.         } 

(1)拖動(dòng)

ACTION_MOVE時(shí),會(huì)計(jì)算出pointer距離上次的位移,然后計(jì)算出capturedView的目標(biāo)位置,進(jìn)行拖動(dòng)處理;

  1. private void dragTo(int leftint topint dx, int dy) { 
  2.         int clampedX = left
  3.         int clampedY = top
  4.         final int oldLeft = mCapturedView.getLeft(); 
  5.         final int oldTop = mCapturedView.getTop(); 
  6.         if (dx != 0) { 
  7.             clampedX = mCallback.clampViewPositionHorizontal(mCapturedView, left, dx);//通過callback獲取真正的移動(dòng)值 
  8.             ViewCompat.offsetLeftAndRight(mCapturedView, clampedX - oldLeft);//進(jìn)行位移 
  9.         } 
  10.         if (dy != 0) { 
  11.             clampedY = mCallback.clampViewPositionVertical(mCapturedView, top, dy); 
  12.             ViewCompat.offsetTopAndBottom(mCapturedView, clampedY - oldTop); 
  13.         } 
  14.         if (dx != 0 || dy != 0) { 
  15.             final int clampedDx = clampedX - oldLeft; 
  16.             final int clampedDy = clampedY - oldTop; 
  17.             mCallback.onViewPositionChanged(mCapturedView, clampedX, clampedY, 
  18.                     clampedDx, clampedDy);//callback回調(diào)移動(dòng)后的位置 
  19.         } 

通過callback的clampViewPositionHorizontal方法決定實(shí)際移動(dòng)的水平距離,通常都是返回left值,即拖動(dòng)了多少就移動(dòng)多少;

通過callback的onViewPositionChanged方法,可以對(duì)View拖動(dòng)后的新位置做一些處理,如;

  1. override fun onViewPositionChanged(changedView: View?, leftInttopInt, dx: Int, dy: Int) { 
  2.   super.onViewPositionChanged(changedView, lefttop, dx, dy) 
  3.     //當(dāng)新的left位置到達(dá)width時(shí),即滑動(dòng)除了界面,關(guān)閉頁面 
  4.     if (left >= width && context is Activity && !context.isFinishing) { 
  5.       context.finish() 
  6.     } 

(2)釋放

而ACTION_UP動(dòng)作時(shí),要釋放拖動(dòng)View

  1. private void releaseViewForPointerUp() { 
  2.         ... 
  3.         dispatchViewReleased(xvel, yvel); 
  4. private void dispatchViewReleased(float xvel, float yvel) { 
  5.         mReleaseInProgress = true
  6.         mCallback.onViewReleased(mCapturedView, xvel, yvel);//callback回調(diào)釋放 
  7.         mReleaseInProgress = false
  8.         if (mDragState == STATE_DRAGGING) { 
  9.             // onViewReleased didn't call a method that would have changed this. Go idle. 
  10.             setDragState(STATE_IDLE);//重置狀態(tài) 
  11.         } 

通常在callback的onViewReleased方法中,我們可以判斷當(dāng)前釋放點(diǎn)的位置,從而決定是要回彈頁面還是滑出屏幕

  1. override fun onViewReleased(releasedChild: View?, xvel: Float, yvel: Float) { 
  2.   super.onViewReleased(releasedChild, xvel, yvel) 
  3.     //滑動(dòng)速度到達(dá)一定值時(shí)直接關(guān)閉 
  4.     if (xvel >= 300) {//滑動(dòng)頁面到屏幕外,關(guān)閉頁面 
  5.       dragHelper?.settleCapturedViewAt(width, 0) 
  6.     } else {//回彈頁面 
  7.       dragHelper?.settleCapturedViewAt(0, 0) 
  8.     } 
  9.   //刷新,開始關(guān)閉或重置動(dòng)畫 
  10.   invalidate() 

如滑動(dòng)速度大于300時(shí),我們調(diào)用settleCapturedViewAt方法將頁面滾動(dòng)出屏幕,否則調(diào)用該方法進(jìn)行回彈

(3)滾動(dòng)

  1. public boolean settleCapturedViewAt(int finalLeft, int finalTop) { 
  2.   return forceSettleCapturedViewAt(finalLeft, finalTop, 
  3.                                    (int) mVelocityTracker.getXVelocity(mActivePointerId), 
  4.                                    (int) mVelocityTracker.getYVelocity(mActivePointerId)); 
  5. private boolean forceSettleCapturedViewAt(int finalLeft, int finalTop, int xvel, int yvel) { 
  6.   //當(dāng)前位置 
  7.   final int startLeft = mCapturedView.getLeft(); 
  8.   final int startTop = mCapturedView.getTop(); 
  9.   //偏移量 
  10.   final int dx = finalLeft - startLeft; 
  11.   final int dy = finalTop - startTop; 
  12.   ... 
  13.   final int duration = computeSettleDuration(mCapturedView, dx, dy, xvel, yvel); 
  14.   //使用Scroller對(duì)象開始滾動(dòng) 
  15.   mScroller.startScroll(startLeft, startTop, dx, dy, duration); 
  16. //重置狀態(tài)為滾動(dòng) 
  17.   setDragState(STATE_SETTLING); 
  18.   return true
  • 其內(nèi)部使用的是Scroller對(duì)象:是View的滾動(dòng)機(jī)制,其回調(diào)是View的computeScroll()方法,在其內(nèi)部通過Scroller對(duì)象的computeScrollOffset方法判斷是否滾動(dòng)完畢,如仍需滾動(dòng),需要調(diào)用invalidate方法進(jìn)行刷新;
  • ViewDragHelper據(jù)此提供了一個(gè)類似的方法continueSettling,需要在computeScroll中調(diào)用,判斷是否需要invalidate;
  1. public boolean continueSettling(boolean deferCallbacks) { 
  2.   if (mDragState == STATE_SETTLING) { 
  3.     //是否滾動(dòng)結(jié)束 
  4.     boolean keepGoing = mScroller.computeScrollOffset(); 
  5.     //當(dāng)前滾動(dòng)值 
  6.     final int x = mScroller.getCurrX(); 
  7.     final int y = mScroller.getCurrY(); 
  8.     //偏移量 
  9.     final int dx = x - mCapturedView.getLeft(); 
  10.     final int dy = y - mCapturedView.getTop(); 
  11. //便宜操作 
  12.     if (dx != 0) { 
  13.       ViewCompat.offsetLeftAndRight(mCapturedView, dx); 
  14.     } 
  15.     if (dy != 0) { 
  16.       ViewCompat.offsetTopAndBottom(mCapturedView, dy); 
  17.     } 
  18. //回調(diào) 
  19.     if (dx != 0 || dy != 0) { 
  20.       mCallback.onViewPositionChanged(mCapturedView, x, y, dx, dy); 
  21.     } 
  22.     //滾動(dòng)結(jié)束狀態(tài) 
  23.     if (!keepGoing) { 
  24.       if (deferCallbacks) { 
  25.         mParentView.post(mSetIdleRunnable); 
  26.       } else { 
  27.         setDragState(STATE_IDLE); 
  28.       } 
  29.     } 
  30.   } 
  31.   return mDragState == STATE_SETTLING; 

在我們的View中

  1. override fun computeScroll() { 
  2.   super.computeScroll() 
  3.     if (dragHelper?.continueSettling(true) == true) { 
  4.       invalidate() 
  5.     } 
  6. 以上,就是ViewDragHelper的實(shí)現(xiàn)原理和使用方式 
  7. override fun computeScroll() { 
  8.   super.computeScroll() 
  9.     if (dragHelper?.continueSettling(true) == true) { 
  10.       invalidate() 
  11.     } 

以上,就是ViewDragHelper的實(shí)現(xiàn)原理和使用方式

總結(jié)

ViewDragHelper本質(zhì)上是對(duì)MotionEvent的分析及處理,并提供了一系列的監(jiān)聽回調(diào)方法,來幫助我們減輕開發(fā)負(fù)擔(dān),更為方便地處理控件的滑動(dòng)拖拽邏輯;

 

是不是覺得很簡單,一起加油,各位老鐵們;

 

責(zé)任編輯:武曉燕 來源: Android開發(fā)編程
相關(guān)推薦

2021-09-01 06:48:16

AndroidGlide緩存

2021-10-15 09:19:17

AndroidSharedPrefe分析源碼

2021-09-07 06:40:25

AndroidLiveData原理

2021-09-04 07:29:57

Android

2021-08-17 13:41:11

AndroidView事件

2021-08-12 16:28:10

AndroidHandleLooper

2021-09-05 07:35:58

lifecycleAndroid組件原理

2021-09-08 06:51:52

AndroidRetrofit原理

2021-09-14 07:06:12

Android磁盤緩存

2021-09-29 09:42:32

AndroidViewDragHel拖動(dòng)上下滑卡片

2021-09-03 07:27:38

AndroidGlide管理

2021-09-06 13:12:05

前端JavaScript編程

2021-09-30 07:36:51

AndroidViewDraw

2011-06-23 14:05:32

Qt 事件機(jī)制

2021-12-30 22:50:32

KafkaConsumer 源碼

2021-08-05 20:39:34

AndroidKotlinStandard.kt

2021-09-02 07:00:01

Glide流程Android

2021-09-11 07:32:15

Java線程線程池

2017-02-21 12:20:20

Android事件分發(fā)機(jī)制實(shí)例解析

2021-08-10 20:41:33

AndroidApp流程
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

亚洲国产日韩美| 国产成人精品亚洲精品| 午夜不卡久久精品无码免费| 亚洲啊v在线| 中文字幕一区二区三区不卡| 国产九色精品| 亚洲一区二区三区高清视频| 激情一区二区| xxxx性欧美| 特大黑人巨人吊xxxx| 99久久亚洲国产日韩美女| 一区二区三区久久| 天堂精品一区二区三区| 乱精品一区字幕二区| 日韩主播视频在线| 久久久久久久成人| 北条麻妃在线观看视频| 亚洲人成精品久久久| 欧美一区二区三区男人的天堂| 青青草原av在线播放| 午夜伦理在线视频| 中文字幕精品三区| 久久久精彩视频| 超碰免费在线97| 久久99国内精品| 日韩美女视频在线观看| 国产一级性生活| 久久精品免费一区二区三区| 国产亚洲精品久久久| 国产又粗又猛又色| 亚洲伊人影院| 欧美一级视频精品观看| 日本激情综合网| 中韩乱幕日产无线码一区| 午夜精品久久一牛影视| av 日韩 人妻 黑人 综合 无码| h网站在线免费观看| www激情久久| 精品产品国产在线不卡| 黄色片一区二区| 国产美女在线精品| 91中文在线视频| av在线资源观看| 精彩视频一区二区三区| 国产欧美在线看| 中文字幕一区二区三区四区免费看 | 欧美xingq一区二区| 国产美女18xxxx免费视频| 姬川优奈av一区二区在线电影| 午夜精品福利一区二区三区av| 国产精品无码免费专区午夜| 欧美人与牲禽动交com| 亚洲精品va在线观看| 2021国产视频| 丁香花在线观看完整版电影| 一区二区三区久久| 青青青青在线视频| 国产不卡人人| 好吊成人免视频| 国产免费人做人爱午夜视频| 欧美黑人巨大xxxxx| 欧洲精品在线观看| 国模私拍视频在线观看| 999色成人| 日韩欧美国产1| 中文字幕 亚洲一区| 国产精品入口久久| 中文字幕亚洲第一| 一区二区成人免费视频| 午夜日韩av| 韩国19禁主播vip福利视频| 日韩精品一区二区不卡| 久久久蜜桃一区二区人| 国产精品扒开腿做爽爽爽视频| 伊人网综合在线| 国产精品一区一区三区| 国产欧美一区二区在线播放| 欧美日韩免费做爰大片| 国产精品剧情在线亚洲| 91嫩草国产丨精品入口麻豆| 91九色porn在线资源| 色婷婷综合视频在线观看| www.超碰97.com| 精品在线网站观看| 国产性色av一区二区| 亚洲一二三在线观看| 五月激情久久久| 国模gogo一区二区大胆私拍 | 制服丝袜日韩国产| 精品人妻在线视频| 国产永久精品大片wwwapp| 久久天天躁狠狠躁夜夜爽蜜月| 精品无码av在线| 青青草原综合久久大伊人精品优势| 91精品久久久久久久久久入口| 亚洲国产欧美另类| 国产欧美精品在线观看| 青青草综合在线| 日本精品不卡| 精品美女被调教视频大全网站| 91国模少妇一区二区三区| 亚洲一区二区三区无吗| 全球成人中文在线| 性生活视频软件| 国产精品无码永久免费888| 亚洲色成人www永久在线观看| 国产精品videossex撒尿| 欧美不卡一二三| 国产成人在线网址| 亚洲免费网址| 国产精品区二区三区日本| 在线看av的网址| 黑人巨大精品欧美一区免费视频 | 久久久久久久久中文字幕| 人妻中文字幕一区二区三区| av一区二区不卡| 黑人巨茎大战欧美白妇| 国产精品美女午夜爽爽| 亚洲精品日韩在线| 久久亚洲AV无码| 国产综合色产在线精品| 欧美一区二区三区在线播放| 岛国毛片av在线| 欧美电影在线免费观看| 免费成人深夜天涯网站| 久久激情综合| 国产私拍一区| gogo高清在线播放免费| 91精品在线免费| 成人黄色短视频| 日本aⅴ亚洲精品中文乱码| 美日韩免费视频| 99在线视频影院| 日韩精品在线一区| 老妇女50岁三级| 黄色日韩网站视频| 在线免费一区| 欧洲亚洲精品久久久久| 视频直播国产精品| 中文字幕a级片| 国产片一区二区| 国产a级一级片| 一个色免费成人影院| 18一19gay欧美视频网站| 日本黄色大片视频| 精品国产精品三级精品av网址| 香蕉视频免费网站| 亚洲大胆在线| 韩日午夜在线资源一区二区| 蜜桃av在线| 日韩精品在线观看网站| 黄色在线观看国产| 久久久三级国产网站| 国产免费999| 欧美电影一区| 91久久久久久久久久久| 91高清在线观看视频| 日韩亚洲国产中文字幕欧美| 欧美日韩综合一区二区| 国产·精品毛片| 欧美 日韩 亚洲 一区| 日韩电影在线观看完整免费观看| 18性欧美xxxⅹ性满足| 韩国福利在线| 欧美人妇做爰xxxⅹ性高电影| 少妇高潮惨叫久久久久| 国产自产高清不卡| 久草视频这里只有精品| 台湾佬综合网| 国产精品丝袜高跟| 伊人影院在线视频| 日韩av在线资源| 无码日韩精品一区二区| 国产精品理伦片| 潘金莲一级淫片aaaaa| 中文一区在线| 一区二区三区四区免费视频| 亚洲午夜免费| 热久久免费国产视频| 天堂中文8资源在线8| 欧美精品一区二区精品网| 黄色网址中文字幕| 亚洲日本电影在线| 欧美 日本 国产| 精品亚洲免费视频| 人人干视频在线| 成人av资源电影网站| 97超碰人人看人人| 成人美女黄网站| 久久综合免费视频影院| 四虎精品在永久在线观看| 欧美视频在线播放| 日韩成人高清视频| 亚洲欧洲精品一区二区精品久久久 | 在线观看免费视频一区| 亚洲成人免费在线观看| 亚洲色图 激情小说| 国产成人亚洲精品青草天美| mm1313亚洲国产精品无码试看| 午夜精品网站| 亚洲精品中文字幕在线 | 日韩av一区二区三区美女毛片| 99久久婷婷国产综合精品首页| 久久99亚洲精品| av网站在线免费观看| 精品国产一区a| 中文字幕人成人乱码亚洲电影| 亚洲综合自拍偷拍| 来吧亚洲综合网| 久久久久久**毛片大全| 国产国语老龄妇女a片| 精品在线播放午夜| 成人免费观看毛片| 激情久久久久久| 青青草免费在线视频观看| 精品久久久中文字幕| 黑人巨大精品欧美一区二区小视频| japansex久久高清精品| 国产精品女主播| av资源亚洲| 国自在线精品视频| 久草免费在线色站| 欧美成人午夜免费视在线看片| porn视频在线观看| 亚洲视频第一页| 在线观看xxx| 精品国产髙清在线看国产毛片| 一级黄色片网站| 欧美亚一区二区| 国产一级片免费视频| 色一情一伦一子一伦一区| 日本亚洲色大成网站www久久| 亚洲一区中文在线| 丝袜美腿小色网| 亚洲欧洲综合另类| 日韩三级在线观看视频| 日韩理论片在线| 精品无码一区二区三区蜜臀| 中文字幕一区二区三区在线不卡 | 国产日韩欧美中文| 国产一区一一区高清不卡| 日本精品性网站在线观看| 日韩大片免费观看| 欧美一区在线直播| 综合日韩av| 日韩av手机在线| yw.尤物在线精品视频| 国产精品免费小视频| 成人亚洲网站| 91社区国产高清| 久久久久久久久成人| 99视频免费观看| 高潮久久久久久久久久久久久久| 国产精品区一区二区三含羞草| avtt综合网| 久久综合狠狠综合久久综青草| 午夜先锋成人动漫在线| 日本精品一区二区| 欧美肥老太太性生活| 精品国产三级a∨在线| 在线播放一区| 欧美韩国日本在线| 男人的j进女人的j一区| 亚洲欧美日本一区二区| 国产精品77777| 好吊色视频一区二区三区| 91在线视频免费观看| 亚洲一区二区自偷自拍 | 亚洲国内在线| 亚洲成人最新网站| 大西瓜av在线| 视频一区二区欧美| 成年人三级黄色片| thepron国产精品| 少妇无套高潮一二三区| 亚洲婷婷在线视频| 日韩黄色三级视频| 欧美日韩中文国产| 国模私拍视频在线| 国产一区二区三区视频在线观看| 秋霞午夜在线观看| 97人人做人人爱| 成人免费黄色| 国产精品国产三级国产专区53 | 99精品一区二区| 亚洲AV成人无码网站天堂久久| 亚洲一级二级在线| 自拍偷拍色综合| 精品久久一二三区| 不卡在线视频| 久久久爽爽爽美女图片| 国产三级一区| 久久亚洲高清| 欧美成人69av| 亚洲精品视频导航| 懂色av一区二区三区免费看| 夜夜春很很躁夜夜躁| 亚洲一区二区三区四区不卡| 亚洲成人av网址| 亚洲成人国产精品| 快射视频在线观看| 91精品国产高清久久久久久| 99精品女人在线观看免费视频| 蜜桃成人在线| 亚洲视频综合| www.污网站| 国产人成一区二区三区影院| 日韩av在线播放观看| 日韩一级黄色片| 日本最新在线视频| 国产成人精品电影久久久| 国产图片一区| 日韩一级片一区二区| 久久99精品久久久久久动态图 | 国产传媒第一页| 亚洲综合在线观看视频| 国产精品久久欧美久久一区| 国产亚洲美女久久| 亚洲伊人av| 国产区二精品视| 欧美特黄a级高清免费大片a级| 国产免费中文字幕| 欧美国产一区二区在线观看| 日本熟女毛茸茸| 亚洲精品国产成人| www在线看| 国产精品美女黄网| 欧美三级网页| 免费不卡av网站| 亚洲日本乱码在线观看| 97人妻精品一区二区三区视频| 中文字幕亚洲色图| 日本h片久久| 亚洲福利av在线| 日本美女一区二区三区视频| 人妻一区二区视频| 在线一区二区三区做爰视频网站| 天天色棕合合合合合合合| 韩国三级电影久久久久久| 国产精伦一区二区三区| 免费看黄在线看| youjizz久久| 久久精品视频5| 亚洲性夜色噜噜噜7777| 日本精品裸体写真集在线观看| 午夜精品视频在线观看一区二区| 日韩经典中文字幕一区| 日本欧美一区二区三区不卡视频| 欧美亚洲动漫制服丝袜| 黄色网在线播放| 91手机在线观看| 亚洲国产免费看| 成人无码www在线看免费| 日韩欧美成人精品| 成人在线观看黄色| 成人激情综合网| 欧美精品97| xxxx黄色片| 欧美色综合网站| 黄在线免费观看| 国产精品一码二码三码在线| 国产欧美不卡| 蜜桃av乱码一区二区三区| 在线播放中文一区| 免费毛片在线看片免费丝瓜视频| 国产精品一级久久久| 日韩综合小视频| 免费在线观看一级片| 日韩电影在线观看中文字幕| 97成人超碰| 亚洲乱码日产精品bd在线观看| 不卡高清视频专区| 特级西西444www大胆免费看| 久久人人爽人人爽人人片亚洲| 成人av综合网| av丝袜天堂网| 亚洲伊人色欲综合网| 国产一级免费在线观看| 亚洲自拍偷拍色片视频| 9国产精品视频| 肉色超薄丝袜脚交69xx图片 | 亚洲久久视频| 九九热免费在线| 亚洲高清不卡av| 国产精品伦一区二区| 国产色一区二区三区| 中文字幕精品—区二区四季| 亚洲精品一区二区三区蜜桃| 日韩女在线观看| 欧美午夜影院| 99精品全国免费观看| 精品国产乱码久久久久久图片 | 色婷婷视频在线观看| 欧美日韩免费观看一区| 国产精品影音先锋| 中文字幕日本视频| 91精品国产91久久久久久久久 | 久久久久久久久久久91| 成人三级视频| 久久国产精品无码一级毛片|