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

Android Transition Framework詳解---超炫的動畫框架

移動開發(fā) Android
早在Android 4.4,Transition 就已經(jīng)引入,但在5.0才得以真正的實(shí)現(xiàn)。而究竟Transition是用來干嘛的呢。接下來我將通過實(shí)例和原理解析來分析下Google這個(gè)強(qiáng)大的動畫框架。

 

前言

早在Android 4.4,Transition 就已經(jīng)引入,但在5.0才得以真正的實(shí)現(xiàn)。而究竟Transition是用來干嘛的呢。接下來我將通過實(shí)例和原理解析來分析下Google這個(gè)強(qiáng)大的動畫框架。

先來張效果圖鎮(zhèn)住場面   

 

這個(gè)效果下文會介紹如何實(shí)現(xiàn),不過要先理解透這個(gè)框架的一些基礎(chǔ)概念。

Transition Framework 核心就是根據(jù)Scene(場景,下文解釋)的不同幫助開發(fā)者們自動生成動畫。通常主要是通過以下幾個(gè)方法開啟動畫。

  • TransitionManager.go()
  • beginDelayedTransition()
  • setEnterTransition()/setSharedElementEnterTransition()

我們來逐一解釋以上各種情況

TransitionManager.go()

首先,先介紹下Scene這個(gè)類,看看官方的解釋

A scene represents the collection of values that various properties in the View hierarchy will have when the scene is applied. A Scene can be configured to automatically run a Transition when it is applied, which will animate the various property changes that take place during the scene change.

通俗的解釋就是這個(gè)類存儲著一個(gè)根view下的各種view的屬性。通常由getSceneForLayout (ViewGroup sceneRoot,int layoutId,Context context)獲取實(shí)例。

  • sceneRoot

scene發(fā)生改變和動畫執(zhí)行的位置

  • layoutId

即上文所說的根view

可能這樣解釋有點(diǎn)無力,下面我舉個(gè)例子。  

[[185335]] 

 

  1. private Scene scene1; 
  2.  
  3. private Scene scene2; 
  4.  
  5. private boolean isScene2; 
  6.  
  7. @Override 
  8.  
  9. protected void onCreate(Bundle savedInstanceState) { 
  10.  
  11.     super.onCreate(savedInstanceState); 
  12.  
  13.     setContentView(R.layout.activity_scene); 
  14.  
  15.     initToolbar(); 
  16.  
  17.     initScene(); 
  18.  
  19.  
  20.  
  21. private void initScene() { 
  22.  
  23.     ViewGroup sceneRoot= (ViewGroup) findViewById(R.id.scene_root); 
  24.  
  25.     scene1=Scene.getSceneForLayout(sceneRoot,R.layout.scene_1,this); 
  26.  
  27.     scene2=Scene.getSceneForLayout(sceneRoot,R.layout.scene_2,this); 
  28.  
  29.     TransitionManager.go(scene1); 
  30.  
  31.  
  32.  
  33. /** 
  34.  
  35.  * scene1和scene2相互切換,播放動畫 * @param view 
  36.  
  37.   */ 
  38.  
  39. public void change(View view){ 
  40.  
  41.     TransitionManager.go(isScene2?scene1:scene2,new ChangeBounds()); 
  42.  
  43.     isScene2=!isScene2; 
  44.  
  45.  

scene1:   

 

scene2:   

 

注意,兩個(gè)scene布局中1和4,2和3除了圖片位置大小不一樣,其id是一樣的。可以當(dāng)成一個(gè)view.因?yàn)榉治霰容^起始scene 的不同創(chuàng)建動畫是針對于同一個(gè)view的。

上述簡單的例子是通過第一種方式TransitionManager.go()觸發(fā)動畫。即在進(jìn)入Activity的時(shí)候,手動將start scene通過TransitionManager.go(scene1)設(shè)置為scene1。點(diǎn)擊button通過TransitionManager.go(scene2,new ChangeBounds())切換到end scene狀態(tài):scene2.Transition 框架通過ChangeBounds類分析start scene和end scene的不同創(chuàng)建并播放動畫。由于ChangeBounds類是分析比較兩個(gè)scene中view的位置邊界創(chuàng)建移動和縮放動畫。發(fā)現(xiàn)從scene1->scene2其實(shí)是1->4,2->3。于是就執(zhí)行相應(yīng)的動畫,即是如下效果:  

 

類似于ChangeBounds類的還有以下幾種,他們都是繼承Transiton類

  • ChangeBounds

檢測view的位置邊界創(chuàng)建移動和縮放動畫

  • ChangeTransform

檢測view的scale和rotation創(chuàng)建縮放和旋轉(zhuǎn)動畫

  • ChangeClipBounds

檢測view的剪切區(qū)域的位置邊界,和ChangeBounds類似。不過ChangeBounds針對的是view而ChangeClipBounds針對的是view的剪切區(qū)域(setClipBound(Rect rect)中的rect)。如果沒有設(shè)置則沒有動畫效果

  • ChangeImageTransform

檢測ImageView(這里是專指ImageView)的尺寸,位置以及ScaleType,并創(chuàng)建相應(yīng)動畫。

  • Fade,Slide,Explode

這三個(gè)都是根據(jù)view的visibility的不同分別創(chuàng)建漸入,滑動,爆炸動畫。

以上各個(gè)動畫類的實(shí)現(xiàn)效果如下: 

 

 

  • AutoTransition

如果TransitionManager.go(scene1)不指定動畫,則默認(rèn)動畫是AutoTransition類。它其實(shí)是一個(gè)動畫集合,查看源碼可知其實(shí)是動畫集合中添加了Fade和ChangeBounds類。

  1. private void init() { 
  2.  
  3.   setOrdering(ORDERING_SEQUENTIAL); 
  4.  
  5.   addTransition(new Fade(Fade.OUT)). 
  6.  
  7.           addTransition(new ChangeBounds()). 
  8.  
  9.           addTransition(new Fade(Fade.IN)); 
  10.  
  11.  

說到動畫集合,其實(shí)動畫類不僅可以通過類似new ChangeBounds()方法創(chuàng)建,也可以通過xml文件創(chuàng)建。且如果對于動畫集合,xml方式可能會更加方便。

只需要兩步,第一步在res/transition創(chuàng)建一個(gè)xml文件,如下:

res/transition/changebounds_and_fade.xml:

  1. <?xml version="1.0" encoding="utf-8"?> 
  2.  
  3. <transitionSet xmlns:android="http://schemas.android.com/apk/res/android"
  4.  
  5. <changeBounds /> 
  6.  
  7. <fade /> 
  8.  
  9. </transitionSet>  

然后再代碼中調(diào)用:

  1. Transition sets=TransitionInflater.from(this).inflateTransition(R.transition.changebounds_and_fade); 

最后補(bǔ)充一點(diǎn),關(guān)于和TransitionManager.go(scene2)其實(shí)是調(diào)用當(dāng)前的scene(scene1)的scene1.exit()以及下一個(gè)scene(scene2)的scene2.enter()

而它們又分別會觸發(fā)scene1.setExitAction()和scene1.setEnterAction().可以在這兩個(gè)方法中定制一些特別的效果.

beginDelayedTransition()

接下來介紹下一個(gè)觸發(fā)方式,如果上面的理解透了話下面的就很簡單了。之前的那種TransitionManager.go()一直都是根據(jù)xml文件創(chuàng)造start scene和end scene,這樣未免有些麻煩。

而beginDelayedTransition()原理則是通過代碼改變view的屬性,然后通過之前介紹的ChangeBounds等類分析start scene和end Scene不同來創(chuàng)建動畫。

依然舉個(gè)例子:  

[[185338]] 

 

  1. @Override 
  2.  
  3. protected void onCreate(Bundle savedInstanceState) { 
  4.  
  5.     super.onCreate(savedInstanceState); 
  6.  
  7.     setContentView(R.layout.activity_begin_delayed); 
  8.  
  9.     initToolBar(); 
  10.  
  11.     initView(); 
  12.  
  13.  
  14.  
  15. @Override 
  16.  
  17. public void onClick(View v) { 
  18.  
  19.     //start scene 是當(dāng)前的scene 
  20.  
  21.   TransitionManager.beginDelayedTransition(sceneRoot, TransitionInflater.from(this).inflateTransition(R.transition.explode_and_changebounds)); 
  22.  
  23.     //next scene 此時(shí)通過代碼已改變了scene statue 
  24.  
  25.   changeScene(v); 
  26.  
  27.  
  28.  
  29. private void changeScene(View view) { 
  30.  
  31.     changeSize(view); 
  32.  
  33.     changeVisibility(cuteboy,cutegirl,hxy,lly); 
  34.  
  35.     view.setVisibility(View.VISIBLE); 
  36.  
  37.  
  38.  
  39. /** 
  40.  
  41.  * view的寬高1.5倍和原尺寸大小切換 * 配合ChangeBounds實(shí)現(xiàn)縮放效果 * @param view 
  42.  
  43.   */ 
  44.  
  45. private void changeSize(View view) { 
  46.  
  47.     isImageBigger=!isImageBigger; 
  48.  
  49.     ViewGroup.LayoutParams layoutParams = view.getLayoutParams(); 
  50.  
  51.     if(isImageBigger){ 
  52.  
  53.         layoutParams.width=(int)(1.5*primarySize); 
  54.  
  55.         layoutParams.height=(int)(1.5*primarySize); 
  56.  
  57.     }else { 
  58.  
  59.         layoutParams.width=primarySize; 
  60.  
  61.         layoutParams.height=primarySize; 
  62.  
  63.     } 
  64.  
  65.     view.setLayoutParams(layoutParams); 
  66.  
  67.  
  68.  
  69. /** 
  70.  
  71.  * VISIBLE和INVISIBLE狀態(tài)切換 * @param views 
  72.  
  73.   */ 
  74.  
  75. private void changeVisibility(View ...views){ 
  76.  
  77.     for (View view:views){ 
  78.  
  79.         view.setVisibility(view.getVisibility()==View.VISIBLE?View.INVISIBLE:View.VISIBLE); 
  80.  
  81.     } 
  82.  
  83.  

當(dāng)觸發(fā)點(diǎn)擊事件時(shí)候,此時(shí)記錄下當(dāng)前scene status,然后改變被點(diǎn)擊view的尺寸,并改變其他view的visibility,再記錄下改變后的scene status。而本例中beginDelayedTransition()第二個(gè)參數(shù)傳的是一個(gè)ChangeBounds和Explode動畫集合,所以這個(gè)集合的中改變尺寸的執(zhí)行縮放動畫,改變visibility的執(zhí)行爆炸效果。整體效果如下:  

 

界面切換動畫

前面說了那么多終于到了重頭戲了:Activity/Fragment之前的切換效果。界面切換有兩種,一種是不帶共享元素的Content Transition一種是帶有共享元素的Shared Element Transition。

Content Transition

先解釋下幾個(gè)重要概念:   

 

  • A.exitTransition(transition)

Transition框架會先遍歷A界面確定要執(zhí)行動畫的view(非共享元素view),執(zhí)行A.exitTransition()前A界面會獲取界面的start scene(view 處于VISIBLE狀態(tài)),然后將所有的要執(zhí)行動畫的view設(shè)置為INVISIBLE,并獲取此時(shí)的end scene(view 處于INVISIBLE狀態(tài)).根據(jù)transition分析差異的不同創(chuàng)建執(zhí)行動畫。

  • B.enterTransition()

Transition框架會先遍歷B界面,確定要執(zhí)行動畫的view,設(shè)置為INVISIBLE。執(zhí)行B.enterTransition()前獲取此時(shí)的start scene(view 處于INVISIBLE狀態(tài)),然后將所有的要執(zhí)行動畫的view設(shè)置為VISIBLE,并獲取此時(shí)的end scene(view 處于VISIBLE狀態(tài)).根據(jù)transition分析差異的不同創(chuàng)建執(zhí)行動畫。   

 

根據(jù)上文解釋,界面切換動畫是建立在visibility的改變的基礎(chǔ)上的,所以getWindow().setEnterTransition(transition);中的參數(shù)一般傳的是Fade,Slide,Explode類的實(shí)例(因?yàn)檫@三個(gè)類是通過分析visibility不同創(chuàng)建動畫的)。通常寫一個(gè)完整的Activity Content Transiton有以下幾個(gè)步驟:

  • 在style中添加
  1. <item name="android:windowActivityTransitions">true</item> 

Material主題的應(yīng)用自動設(shè)置為true.

  • 設(shè)置相應(yīng)的A離開/B進(jìn)入/B離開/A重新進(jìn)入動畫。
  1. //A 不設(shè)置默認(rèn)為null 
  2.  
  3. getWindow().setExitTransition(transition); 
  4.  
  5. //B 不設(shè)置默認(rèn)為Fade 
  6.  
  7. getWindow().setEnterTransition(transition); 
  8.  
  9. //B 不設(shè)置默認(rèn)為EnterTransition 
  10.  
  11. getWindow().setReturnTransition(transition); 
  12.  
  13. //A 不設(shè)置默認(rèn)為ExitTransition 
  14.  
  15. getWindow().setReenterTransition(transition);  

當(dāng)然也可以在主題中設(shè)置

  1. <item name="android:windowEnterTransition">@transition/slide_and_fade</item> 
  2.  
  3. <item name="android:windowReturnTransition">@transition/return_slide</item>  
  • 跳轉(zhuǎn)界面

這里的跳轉(zhuǎn)界面不能僅僅startActivity(intent),需要

  1. Bundle bundle=ActivityOptionsCompat.makeSceneTransitionAnimation(activity).toBundle; 
  2.  
  3. startActivity(intent,bundle)  

ok到這里為止既可以運(yùn)行activity之間的切換動畫了。

但是你會發(fā)現(xiàn),在界面切換的時(shí)候,A退出時(shí),過了一小會,B就進(jìn)入了,(真是過分,不給A完全展示ExitTransition)如果你是想等A完全退出后B再進(jìn)入可以通過設(shè)置setAllowEnterTransitionOverlap(false)(默認(rèn)是true),同樣可以在xml中設(shè)置:

  1. <item name="android:windowAllowEnterTransitionOverlap">false</item> 
  2. <item name="android:windowAllowReturnTransitionOverlap">false</item>  

說了這么多我覺得又得舉個(gè)簡單例子。

A.Activity:

  1. @Override 
  2.  
  3. protected void onCreate(Bundle savedInstanceState) { 
  4.  
  5.     super.onCreate(savedInstanceState); 
  6.  
  7.     setContentView(R.layout.activity_main); 
  8.  
  9.     initToolBar(); 
  10.  
  11.     getWindow().setExitTransition(TransitionInflater.from(this).inflateTransition(R.transition.slide)); 
  12.  
  13.     //未設(shè)置setReenterTransition()默認(rèn)和setExitTransition一樣 
  14.  
  15.  
  16.  
  17. public void goContentTransitions(View view){ 
  18.  
  19.     Intent intent = new Intent(this, ContentTransitionsActivity.class); 
  20.  
  21.     ActivityOptionsCompat activityOptionsCompat = ActivityOptionsCompat.makeSceneTransitionAnimation(this); 
  22.  
  23.     startActivity(intent,activityOptionsCompat.toBundle()); 
  24.  
  25.  

res/translation/slide.xml:

  1. <transitionSet xmlns:android="http://schemas.android.com/apk/res/android"
  2.  
  3. <slide android:duration="1000"></slide> 
  4.  
  5. </transitionSet>  

B.Activity:

  1. @Override 
  2.  
  3. protected void onCreate(Bundle savedInstanceState) { 
  4.  
  5.     super.onCreate(savedInstanceState); 
  6.  
  7.     setContentView(R.layout.activity_content_transitions); 
  8.  
  9.     initToolbar(); 
  10.  
  11.  
  12.     Slide slide=new Slide(); 
  13.  
  14.     slide.setDuration(500); 
  15.  
  16.     slide.setSlideEdge(Gravity.LEFT); 
  17.  
  18.     getWindow().setEnterTransition(slide); 
  19.  
  20.     getWindow().setReenterTransition(new Explode().setDuration(600)); 
  21.  
  22.  

實(shí)現(xiàn)的效果如下:  

 

 

仔細(xì)看著動畫你其實(shí)可以發(fā)現(xiàn)A的狀態(tài)欄也跟著下拉上拉了,而且和下面的視圖有一定的間距。處女座表示不能忍。

其實(shí)從原理上來解釋,Activity的切換動畫針對的是整個(gè)界面的view的visibility,而有沒有什么方法能讓Transition框架只關(guān)注某一個(gè)view或者不關(guān)注某個(gè)view呢。當(dāng)然,transition.addTarget()和transition.excludeTarget()可以分別實(shí)現(xiàn)上述功能。

方便的是也可以在xml設(shè)置該屬性,那么我們現(xiàn)在要做的是將statusBar排除掉,可以在slide.xml這樣寫:

  1. <transitionSet xmlns:android="http://schemas.android.com/apk/res/android"
  2.  
  3. <slide android:duration="1000"
  4.  
  5.     <targets > 
  6.  
  7.         <!--表示除了狀態(tài)欄--> 
  8.  
  9.         <target android:excludeId="@android:id/statusBarBackground"/> 
  10.  
  11.         <!--表示只針對狀態(tài)欄--> 
  12.  
  13.  <!--<target android:targetId="@android:id/statusBarBackground"/>-->  </targets> 
  14.  
  15. </slide> 
  16.  
  17. </transitionSet>  

大功告成,效果我就不貼了,各位可以腦補(bǔ)一下...

Shared Element Transition  

 

界面切換中往往Content Transition和Shared Element Transition是同時(shí)存在的,區(qū)別于Content Transition,主要有以下幾個(gè)不同點(diǎn):

  • startActivity()
  1. Bundle bundle=ActivityOptionsCompat.makeSceneTransitionAnimation(activity,pairs).toBundle; 
  2.  
  3. startActivity(intent,bundle)  

這里的pairs是Pair<View, String>類的實(shí)例集合,存儲著兩個(gè)activity之間共享view和name。這里的name要和B界面的共享view的transitionName一致。就像這樣:

  1. Intent intent = new Intent(this, WithSharedElementTransitionsActivity.class); 
  2. ActivityOptionsCompat activityOptionsCompat = ActivityOptionsCompat.makeSceneTransitionAnimation(this 
  3.  ,new Pair<View, String>(shared_image,"shared_image_"
  4.        ,new Pair<View, String>(shared_text,"shared_text_")); 
  5. startActivity(intent,activityOptionsCompat.toBundle());//xml<TextView 
  6.  android:text="withShared" 
  7.  android:transitionName="shared_text_" 
  8. style="@style/MaterialAnimations.TextAppearance.Title.Inverse" 
  9.  android:layout_width="wrap_content" 
  10.  android:layout_height="wrap_content" /> 
  11.  
  12.  
  13. ><de.hdodenhof.circleimageview.CircleImageView 
  14.  android:id="@+id/icon_gg" 
  15.  android:layout_centerInParent="true" 
  16.  android:src="@mipmap/xkl" 
  17.  android:transitionName="shared_image_" 
  18.  android:layout_width="150dp" 
  19.  android:layout_height="150dp" />  
  • setSharedElementEnterTransition()/setSharedElementReturnTransition()

不設(shè)置的話默認(rèn)是@android:transition/move動畫。而setExitTransition()和setEnterTransition()默認(rèn)為null和Fade.

其實(shí)Shared Element Transition原理和Content Transition類似都是根據(jù)始末scene status的不同創(chuàng)建動畫。

不同的是Content Transition是通過改變view的visibility來改變scene狀態(tài)從而進(jìn)一步創(chuàng)建動畫,而Shared Element Transition是分析A B界面共享view的尺寸,位置,樣式的不同創(chuàng)建動畫化的。所以前者通常設(shè)置Fade等Transition后者通常設(shè)置ChangeBounds等Transition.

最后的最后讓我們來分析如何實(shí)現(xiàn)文章一開始的那個(gè)gif圖效果。

  1. 整個(gè)動畫包括Content Transition和Shared Element Transition。而A界面的setExitTransition()并沒有設(shè)置為null。
  2. 當(dāng)進(jìn)入B界面,這里的共享view只是單純的移動所以setSharedElementEnterTransition(transition)可以不用設(shè)置,默認(rèn)為move。同時(shí)會執(zhí)行一個(gè)水紋展開動畫,這個(gè)可以通過ViewAnimationUtils.createCircularReveal()方法實(shí)現(xiàn)。在Shared Element Transition結(jié)束之后執(zhí)行Content Transition,可以看出是Slide動畫。所以可以通過設(shè)置setExitTransition(new Slide())完成。注意這里Slide只作用于底部的item(要設(shè)置target),否則就作用于一整個(gè)視圖了。
  3. 最關(guān)鍵的來了,在B退出時(shí)候,可以看到屏幕上半部分向上滑過,下半部分向下滑過。一種從中間撕開的視覺效果。所以可以將布局一分為二并指定為用兩個(gè)不同方向的Slide的Target,差不多像這樣:
  1. <transitionSet 
  2.  
  3. android:duration="800" xmlns:android="http://schemas.android.com/apk/res/android"
  4.  
  5. <slide android:slideEdge="top"
  6.  
  7.  <targets > 
  8.  
  9.      <target android:targetId="@id/viewGroup_top"></target> 
  10.  
  11.  </targets> 
  12.  
  13. </slide> 
  14.  
  15. <slide android:slideEdge="bottom"
  16.  
  17.  <targets > 
  18.  
  19.      <target android:targetId="@id/viewGroup_bottom"></target> 
  20.  
  21.  </targets> 
  22.  
  23. </slide> 
  24.  
  25. </transitionSet>  

這里其實(shí)有個(gè)坑,我們先來看看isTransitionGroup()這個(gè)方法:

  1. public boolean isTransitionGroup() { 
  2.  
  3.  if ((mGroupFlags & FLAG_IS_TRANSITION_GROUP_SET) != 0) { 
  4.  
  5.      return ((mGroupFlags & FLAG_IS_TRANSITION_GROUP) != 0); 
  6.  
  7.  } else { 
  8.  
  9.      final ViewOutlineProvider outlineProvider = getOutlineProvider(); 
  10.  
  11.      return getBackground() != null || getTransitionName() != null || 
  12.  
  13.              (outlineProvider != null && outlineProvider != ViewOutlineProvider.BACKGROUND); 
  14.  
  15.  } 
  16.  
  17.  

返回值為true表示這個(gè)ViewGroup作為一個(gè)整體執(zhí)行Activity Transition,false表示這個(gè)ViewGroup中子view各自執(zhí)行各自的。如果這個(gè)ViewGroup設(shè)置了background或者TransitionName,或者setTransitionGroup(true)則返回值為true表示作為一個(gè)整體執(zhí)行動畫.

所以這里的viewGroup_bottom和viewGroup_top最好設(shè)置下setTransitionGroup(true).

實(shí)現(xiàn)效果如下,自己加了點(diǎn)其他特效  

 

 

具體代碼我就不貼了,本文的所有的代碼已上傳Github(我是鏈接),包括Fragment的切換本文未作介紹代碼中有寫。希望大家能點(diǎn)個(gè)star。

如果你看了一遍還是不知所云那我強(qiáng)烈建議你結(jié)合代碼運(yùn)行下在看一遍,其實(shí)搞懂了還是蠻簡單的。

最后我想說的是關(guān)于這個(gè)Transition Framework還有一些內(nèi)容沒說完,可能要等過段時(shí)間更新了,接下來還會寫關(guān)于Dagger 2的相關(guān)文章以及NavigationBar的加強(qiáng)版,敬請期待吧。

責(zé)任編輯:龐桂玉 來源: 安卓巴士Android開發(fā)者門戶
相關(guān)推薦

2024-06-04 08:23:19

2012-07-11 15:54:59

canvas

2012-07-13 13:41:35

Canvas

2012-07-13 13:52:54

Canvas

2011-06-29 13:22:58

CSS3

2011-06-21 13:31:13

JavaScript

2017-07-18 16:00:09

炫酷動畫開源框架APP

2024-03-28 09:11:24

CSS3TransitionCSS屬性

2014-09-18 09:27:32

AndroidTransition框

2025-01-06 11:59:32

2013-04-17 10:16:25

語言

2015-12-01 09:52:03

CSS3動畫源碼

2025-05-13 02:01:00

Three.jsSprite粒子

2013-08-07 10:47:58

Android特效ListView

2013-08-07 10:35:02

AndroidListView拖拽

2022-07-08 09:55:54

CSS轉(zhuǎn)場動畫

2011-03-03 10:16:46

jQueryJavaScript

2011-08-02 14:45:11

HTML 5

2011-06-14 18:37:50

Flash

2022-08-11 09:30:52

transitionCSS
點(diǎn)贊
收藏

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

国产精品va视频| 中文字幕一区二区三区四区免费看 | 成人午夜在线影院| 欧美丰满熟妇bbbbbb| 成人盗摄视频| 色婷婷精品大在线视频| 中文字幕成人一区| 好吊视频一区二区三区| 美女91精品| 久久精品国产清自在天天线 | 一区二区网站| 91电影在线观看| 国产一二三四区在线观看| 欧美一区,二区| 久久99精品久久久久久动态图| 久久久久久亚洲| 刘亦菲国产毛片bd| 欧美三级自拍| 欧美一级久久久久久久大片| 116极品美女午夜一级| 成年人网站在线| www成人在线观看| 粉嫩av一区二区三区免费观看 | 欧美一区二区私人影院日本| 欧美性久久久久| 婷婷社区五月天| 亚洲乱熟女一区二区| 中文亚洲字幕| 久久久精品免费| 激情av在线播放| 中文字幕在线观看1| 国产精品一区二区三区www| 亚洲成人综合在线| 亚洲国产一区二区在线| 全部免费毛片在线播放一个| 久久精品国产亚洲a| 久久久久久亚洲综合影院红桃| 日本精品久久中文字幕佐佐木| 麻豆明星ai换脸视频| 欧美精品系列| 亚洲免费影视第一页| 白嫩情侣偷拍呻吟刺激| 日韩综合一区二区三区| 欧美色图第一页| 精品www久久久久奶水| 国产社区精品视频| 亚洲国产毛片aaaaa无费看| 国产一二三四五| 看黄网站在线| 中文字幕综合网| 亚洲午夜精品一区二区| 二人午夜免费观看在线视频| 国产亚洲欧美色| 品久久久久久久久久96高清| 日本又骚又刺激的视频在线观看| 9色porny自拍视频一区二区| 国内精品**久久毛片app| 精品人妻伦一二三区久久| 狠狠色狠狠色综合日日91app| 国产精品综合不卡av| 一区二区自拍偷拍| 精品在线观看免费| 成人午夜高潮视频| 99精品人妻无码专区在线视频区| 精品一区二区日韩| 亚洲a在线观看| 亚洲精品成人区在线观看| 国产精品123| 国产精品久久7| 桃花色综合影院| 国产午夜一区二区三区| 丝袜足脚交91精品| 麻豆av免费在线观看| 亚洲美女免费视频| 精品少妇在线视频| 日韩国产网站| 51精品视频一区二区三区| 欧美精品色视频| 超碰成人在线观看| 日韩精品在线观| www亚洲色图| 亚欧美无遮挡hd高清在线视频| 欧美高跟鞋交xxxxxhd| 日韩欧美亚洲一区二区三区| 另类图片国产| 91精品久久久久久久久久| 国产草草影院ccyycom| 成人精品视频一区| 鲁鲁视频www一区二区| 在线观看二区| 亚洲图片欧美色图| www日韩在线观看| 欧美成人一级| 精品调教chinesegay| 性色国产成人久久久精品| 亚洲一级二级| 国产精品免费在线免费| 国产美女三级无套内谢| 99免费精品在线观看| 夜夜爽99久久国产综合精品女不卡| av电影高清在线观看| 色欧美乱欧美15图片| 992kp免费看片| 亚洲国产精品嫩草影院久久av| 色偷偷偷亚洲综合网另类| 久久精品视频久久| 免费高清在线一区| 精品婷婷色一区二区三区蜜桃| 伊人在线视频| 色综合激情五月| 欧洲成人午夜精品无码区久久| 精品国产欧美日韩| 久久久久久久久久久av| 做爰无遮挡三级| 99re这里都是精品| 喜爱夜蒲2在线| 成人亚洲网站| 亚洲欧美日韩一区二区三区在线| 欧美日韩一级大片| 美女网站色91| 欧美三级网色| 国产美女高潮在线观看| 日韩三级在线观看| 99久久精品久久亚洲精品| 香蕉视频成人在线观看| 成人免费视频视频在| 日本免费在线观看| 欧美午夜精品久久久久久超碰| 欲求不满的岳中文字幕| 国产精品成人一区二区网站软件| 91精品国产综合久久香蕉最新版| 国产视频网址在线| 偷偷要91色婷婷| 催眠调教后宫乱淫校园| 欧美一区不卡| 亚洲精品免费网站| 免费av网站在线看| 欧美性色黄大片| 在线观看日本中文字幕| 久久久久久久高潮| 久热这里只精品99re8久| 僵尸再翻生在线观看免费国语| 欧美mv日韩mv国产网站| 国内偷拍精品视频| 国产在线播放一区三区四| 夜夜春亚洲嫩草影视日日摸夜夜添夜| 国产精品伊人| 日韩中文有码在线视频| 亚洲天堂2021av| 欧美激情中文字幕| 超碰在线公开97| 欧美顶级大胆免费视频| 成人在线一区二区| 久久日韩视频| 日韩一区二区免费高清| 国产精品99久久久久久成人| 激情图片小说一区| 亚洲最新免费视频| www欧美在线观看| 欧美精品在线免费| 免费观看黄一级视频| 亚洲成人高清在线| 欧美无人区码suv| 久久国产欧美| 伊人精品久久久久7777| 国产精品一级在线观看| 欧美精品18videos性欧| 五月天婷婷在线播放| 欧美性猛xxx| 欧美a在线播放| 国产乱码精品一区二区三区av | 黄色在线小视频| 欧洲一区二区av| 久久久久亚洲av片无码| 国产激情一区二区三区桃花岛亚洲| mm131午夜| 国偷自产av一区二区三区| 欧美一区二区三区图| 风间由美一区| 日韩免费一区二区三区在线播放| 国产精品23p| 国产日韩视频一区二区三区| 亚洲黄色片免费| 亚洲福利久久| 亚洲视频sss| 久久99国产精品久久99大师| 国产精品99久久久久久久久久久久| 免费黄网站在线播放| 精品国产百合女同互慰| 亚洲精品一区二三区| 亚洲色欲色欲www| 天天插天天射天天干| 精品中文字幕一区二区小辣椒| 欧美不卡在线播放| 日韩高清欧美| 精品久久久久久综合日本 | 欧美视频一区二区三区| 九九视频在线免费观看| 久久精品欧美一区二区三区不卡| 亚洲综合在线一区二区| 六月婷婷一区| 69sex久久精品国产麻豆| 精品国产一区二区三区小蝌蚪 | 欧美日韩久久婷婷| 国产一区二区三区的电影| 国产精品h视频| 国产91久久精品一区二区| 91久久国产综合久久蜜月精品| 欧美日韩视频网站| 久久久久久久久久久国产| 9色在线观看| 日韩电影中文字幕| 99久久精品免费看国产交换| 欧美自拍偷拍一区| 福利一区二区三区四区| 国产精品黄色在线观看| 亚洲av无码一区二区三区网址| 国产一区二区三区综合| 日日噜噜夜夜狠狠| 中文在线不卡| 欧美午夜小视频| 自由日本语亚洲人高潮| 亚洲最大色综合成人av| 国产成人黄色| 久久精品午夜一区二区福利| 一本一道久久a久久| 成人午夜在线视频一区| 欧美91在线|欧美| 国产精品国语对白| av资源亚洲| 欧美一级片免费在线| 888av在线视频| 久久久久久久久久久免费精品| 影音先锋男人在线资源| 久久久久999| 麻豆电影在线播放| 精品国产一区二区在线| 99青草视频在线播放视| 国产一区二区久久精品| 精品一二三区视频| 亚洲欧美色图片| 蜜桃视频在线观看网站| 亚洲人成绝费网站色www| 三区在线视频| 日韩精品久久久久久福利| 婷婷综合激情网| 亚洲精品美女久久| 婷婷色在线视频| 亚洲欧美国产日韩天堂区| 日本免费一区二区三区最新| 亚洲欧洲国产一区| 国产在线三区| 色综久久综合桃花网| av资源在线观看免费高清| 中文字幕亚洲一区二区三区| 男人和女人做事情在线视频网站免费观看| 日韩亚洲国产中文字幕| 免费黄色在线| 欧美黑人xxx| 美女av在线免费看| 国产97在线观看| 成人亚洲视频| 亚洲自拍偷拍色片视频| 成人另类视频| 麻豆成人小视频| 日韩成人精品一区| 无码毛片aaa在线| 在线成人h网| 青青在线免费观看视频| 韩国精品主播一区二区在线观看 | 免费欧美网站| **亚洲第一综合导航网站| 综合久久成人| 牛人盗摄一区二区三区视频| 毛片在线免费播放| 午夜精品一区二区三区电影天堂 | 欧美日韩国产精品一卡| 欧美四级在线| 97香蕉超级碰碰久久免费软件 | 中国女人一级一次看片| 欧美日韩一二三区| 精品国产黄色片| 亚洲精品久久久一区二区三区 | 欧美一级全黄| 亚洲精品美女久久7777777| 欧美一区网站| www.国产区| 国产1区2区3区精品美女| 亚洲a v网站| 一区二区在线观看免费视频播放| 久久久久久少妇| 欧美一区二区大片| 日韩欧美在线番号| 久久躁狠狠躁夜夜爽| 亚洲人成在线网站| 91久久精品国产91久久性色| 欧美调教视频| 成人免费看片视频在线观看| 久久久噜噜噜久久狠狠50岁| 妖精视频在线观看| 中文字幕欧美日本乱码一线二线| 久久国产精品二区| 欧美三级电影在线看| 视频国产在线观看| 欧美精品一区在线播放| 国产三级一区| 蜜桃臀一区二区三区| 午夜亚洲福利| 欧美日韩中文不卡| 久久亚洲一级片| 国产无码精品在线观看| 91精品欧美综合在线观看最新| 黄色免费在线播放| 午夜精品久久久久久99热| 91丨精品丨国产| 亚洲高清在线播放| 久久国产直播| 亚洲观看黄色网| 亚洲愉拍自拍另类高清精品| 国产精品久久久久久免费免熟| 亚洲男女自偷自拍图片另类| 538在线精品| 99在线高清视频在线播放| 91综合久久| 成年网站在线播放| 久久婷婷久久一区二区三区| 日韩精品成人一区| 欧美va在线播放| 久久bbxx| 成人做爽爽免费视频| 97久久视频| 激情五月俺来也| 亚洲国产激情av| 涩涩视频在线观看| 亚洲网站在线播放| 亚洲成人人体| 欧美一区二区三区成人久久片| 亚洲综合三区| 最近中文字幕免费视频| 色呦呦国产精品| 国产日韩精品在线看| 国产成人精品免高潮在线观看 | 亚洲天堂av网| 欧美三级精品| 亚洲高清资源综合久久精品| 美腿丝袜亚洲色图| www深夜成人a√在线| 欧美一区二区二区| 国产天堂在线播放视频| 国产激情一区二区三区在线观看| 黄色亚洲在线| 在线观看国产三级| 色欧美乱欧美15图片| 成人高清网站| 亚洲qvod图片区电影| 中文乱码免费一区二区三区下载| 美女被艹视频网站| 亚洲成人激情综合网| 日本福利在线观看| 国产激情久久久| 午夜精品久久久久久久四虎美女版| 九九热精品国产| 亚洲一区二区三区不卡国产欧美| 欧洲av在线播放| 国产成人自拍视频在线观看| 日本在线电影一区二区三区| 日韩av自拍偷拍| 亚洲高清免费视频| 日韩在线无毛| 成人久久一区二区| 伊人激情综合| 少妇无套高潮一二三区| 欧美精品123区| 51av在线| 一区二区精品视频| 盗摄精品av一区二区三区| 久久亚洲天堂网| 视频在线观看一区二区| 综合成人在线| 国产九九在线视频| 一二三四社区欧美黄| 女人偷人在线视频| 91视频-88av| 亚洲在线成人| 青花影视在线观看免费高清| 精品国产乱子伦一区| 日韩中文视频| 久久手机在线视频| 亚洲国产电影在线观看| 精品人妻伦一二三区久久| 国产aⅴ夜夜欢一区二区三区| 婷婷伊人综合| 在线免费观看成年人视频| 5566中文字幕一区二区电影| 在线看的毛片| 超碰10000| 国产精品灌醉下药二区| 视频二区在线| 亚洲bt欧美bt日本bt| 日韩精品视频网|