欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android ViewPager實(shí)現(xiàn)動(dòng)畫切換效果

 更新時(shí)間:2021年08月27日 10:40:36   作者:yuminfeng728  
這篇文章主要為大家詳細(xì)介紹了Android ViewPager實(shí)現(xiàn)動(dòng)畫切換效果的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

概述

ViewPager是Android開發(fā)中使用場(chǎng)景非常頻繁的控件,單一的動(dòng)畫效果切換已經(jīng)越來越不能滿足追求個(gè)性化的應(yīng)用中。而ViewPager自身也帶有一個(gè)接口來處理頁面間的動(dòng)畫切換,那就是setPageTransformer。下面我們通過代碼來學(xué)習(xí)動(dòng)畫效果的切換。

實(shí)現(xiàn)簡(jiǎn)單動(dòng)畫切換

代碼如下:

1.布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/view_pager_box"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="horizontal" >

  <android.support.v4.view.ViewPager
    android:id="@+id/viewpager"
    android:layout_margin="10dp"
    android:layout_width="wrap_content"
    android:layout_height="120dp" />

</LinearLayout>

MainActivity 中相關(guān) java 代碼

import android.app.Activity;
import android.os.Bundle;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.ImageView.ScaleType;

public class MainActivity extends Activity {

  private ViewPager viewPager;
  private int[] imageIds = new int[]{R.drawable.pic1,R.drawable.pic2,R.drawable.pic3,R.drawable.pic4,R.drawable.pic5,};
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    viewPager = (ViewPager) findViewById(R.id.viewpager);

    viewPager.setOffscreenPageLimit(3); //設(shè)置內(nèi)存中預(yù)加載頁面數(shù)

    viewPager.setPageTransformer(true, new DepthPageTransformer()); //設(shè)置頁面切換過渡動(dòng)畫

    viewPager.setAdapter(new PagerAdapter() {

      @Override
      public boolean isViewFromObject(View view, Object object) {
        return view == object;
      }

      @Override
      public int getCount() {
        return imageIds.length;
      }

      @Override
      public Object instantiateItem(ViewGroup container, int position) {
        ImageView imageView = new ImageView(MainActivity.this);
        imageView.setScaleType(ScaleType.CENTER_CROP);
        imageView.setImageResource(imageIds[position]);
        imageView.setTag(position); //設(shè)置標(biāo)記
        container.addView(imageView);
        return imageView;
      }

      @Override
      public void destroyItem(ViewGroup container, int position,
          Object object) {
        container.removeView((View)object);
      }
    });
  }
}

3.控制切換動(dòng)畫的類DepthPageTransformer的代碼

import android.support.v4.view.ViewPager;
import android.view.View;

public class DepthPageTransformer implements ViewPager.PageTransformer {

  private static final float MIN_SCALE = 0.75f;

  @Override
  public void transformPage(View view, float position) {

    android.util.Log.i("yuminfeng", "====view:" + view.getTag()  + ",position:" + position);

    int pageWidth = view.getWidth();

    if (position < -1) { // [-Infinity,-1) 
      // This page is way off-screen to the left.
      view.setAlpha(0);

    } else if (position <= 0) { // [-1,0]
      // Use the default slide transition when moving to the left page
      view.setAlpha(1);
      view.setTranslationX(0);
      view.setScaleX(1);
      view.setScaleY(1);

    } else if (position <= 1) { // (0,1]
      // Fade the page out.
      view.setAlpha(1 - position);

      // Counteract the default slide transition
      view.setTranslationX(pageWidth * -position);

      // Scale the page down (between MIN_SCALE and 1)
      float scaleFactor = MIN_SCALE + (1 - MIN_SCALE) * (1 - Math.abs(position));
      view.setScaleX(scaleFactor);
      view.setScaleY(scaleFactor);

    } else { // (1,+Infinity]
      // This page is way off-screen to the right.
      view.setAlpha(0);
    }
  }

}

上面的代碼十分簡(jiǎn)單,僅僅只是ViewPager的初始化配置,然后通過setPageTransformer設(shè)置頁面切換動(dòng)畫。有一個(gè)細(xì)節(jié)還需要注意,設(shè)置setOffscreenPageLimit(3),表示內(nèi)存中預(yù)加載頁面為3,這三個(gè)頁面是不可見的。如果加上當(dāng)前顯示的頁面,總共初始化了4個(gè)頁面。不設(shè)置的話,系統(tǒng)使用默認(rèn)的預(yù)加載的頁數(shù)為1。
第一次啟動(dòng)應(yīng)用后,我們通過在DepthPageTransformer類中記錄的日志可以看到,如下:

總共初始化了4個(gè)view,其中當(dāng)前對(duì)用戶可見view的位置為0,其余都是不可見。所以當(dāng)position=0時(shí),表示當(dāng)前的頁面。

我們繼續(xù)操作并向左滑動(dòng)一頁,日志如下:

由此可以看到,之前的view的位置變?yōu)?1,它的右邊的view位置為0,變成可見。
繼續(xù)滑動(dòng)至最后一頁后:

我們看到最后一頁的view已經(jīng)展現(xiàn)在用戶面前,位置為0,而其他頁面位置都是為負(fù),表示所有頁面都滑至左邊。這時(shí)我們注意的話,可以發(fā)現(xiàn)view:0,不在日志信息中,難道它沒有被初始化?其實(shí)它已經(jīng)被系統(tǒng)回收了,通過Adapter中destroyItem方法。因?yàn)槲覀冎霸O(shè)置ViewPager中預(yù)加載的頁數(shù)限制為3,系統(tǒng)中最多的存在4個(gè)view,所以view:0被回收。

從上面的分析我們可以知道,當(dāng)view的position處于[-1,1]時(shí),該view能夠被用戶所見,其他位置便不可見。而PageTransformer的接口中,真是利用了這個(gè)特點(diǎn),根據(jù)view的position來對(duì)它進(jìn)行縮放,旋轉(zhuǎn)等動(dòng)畫操作。我們繼續(xù)分析DepthPageTransformer類:
當(dāng) position < -1,即[-Infinity,-1) 時(shí):
view處于左邊不可見中,這里view.setAlpha(0); 表示完全透明。
當(dāng)-1 <= position <= 0 時(shí),該view處于可見區(qū)域,:
1.如果view向左滑動(dòng),表示當(dāng)前view逐漸滑出可見區(qū)域
2.如果view向右滑動(dòng),表示左邊的view逐漸劃入當(dāng)前可見區(qū)域。
view.setAlpha(1),設(shè)置透明度,表示完全不透明。
view.setTranslationX(0),表示設(shè)置view相對(duì)于左側(cè)位置的水平位置,距離左邊的距離。
view.setScaleX(1)和view.setScaleY(1),表示view的x,y軸不進(jìn)行縮放。
當(dāng)0 < position <= 1 時(shí),該view處于可見區(qū)域:
1.如果view向右滑動(dòng),表示當(dāng)前view逐漸滑出可見區(qū)域。
2.如果view向左滑動(dòng),表示右邊的view逐漸滑入可見區(qū)域。
view.setAlpha(1 - position),根據(jù)view滑動(dòng)的位置,設(shè)置view的透明度。position 越接近于0,表明view面對(duì)用戶顯示的越多,所以就越不透明。
view.setTranslationX(pageWidth * -position),根據(jù)view滑動(dòng)的位置,設(shè)置view相對(duì)于左側(cè)位置的水平位置,當(dāng)position = 0 時(shí),view完全顯示,這時(shí)相對(duì)左邊為0,當(dāng) position = 1 時(shí),view完全不可見,這時(shí)相對(duì)左邊為view的寬度。
float scaleFactor = MIN_SCALE + (1 - MIN_SCALE) * (1 - Math.abs(position));
view.setScaleX(scaleFactor);
view.setScaleY(scaleFactor);
根據(jù)view的position,設(shè)置view的縮放大小。當(dāng) position,越大時(shí),越遠(yuǎn)離用戶界面,于是越不可見。
當(dāng)1< position 時(shí),即(1,+Infinity]時(shí):
view.setAlpha(0),設(shè)置完全透明不可見。

上述代碼執(zhí)行效果如下:

我們還可以定制其他的動(dòng)畫效果,實(shí)現(xiàn)原理和上面一樣,這里就不一一列出來了。

實(shí)現(xiàn)廣告輪播效果圖

如圖:

實(shí)現(xiàn)上面的效果圖,只需要對(duì)上面的代碼進(jìn)行一些修改即可:

想要在屏幕上出現(xiàn)多個(gè)頁面,我們需要設(shè)置屬性:android:clipChildren=”false”,該屬性的意思是在View進(jìn)行繪制的時(shí)候,不去裁切它們的顯示范圍,即不限制view的顯示范圍。
我們修改布局文件,如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/view_pager_box"
  android:layout_width="match_parent"
  android:layout_height="160dp"
  android:gravity="center"
  android:clipChildren="false"
  android:orientation="horizontal" >

  <android.support.v4.view.ViewPager
    android:id="@+id/viewpager"
    android:layout_width="match_parent"
    android:layout_margin="30dp"
    android:layout_height="120dp" />

</LinearLayout>

在ViewPager的外面控件中設(shè)置了android:clipChildren=”false”,然后設(shè)置viewpager中android:layout_margin屬性,留出間距,方便顯示左右兩邊的圖片。后面我們還要java代碼設(shè)置viewpager的屬性,如:
viewPager.setPageMargin(40); //設(shè)置頁面間間距
這樣可以讓頁面之間存在一定的間隔。最后,我們通過setPageTransformer方法設(shè)置自己定義的動(dòng)畫即可,與上面一致。
該效果的動(dòng)畫類代碼:

import android.support.v4.view.ViewPager;
import android.view.View;

public class AlphaScaleTransformer implements ViewPager.PageTransformer {

  private static final float DEFAULT_MIN_ALPHA = 0.5f;
  private float mMinAlpha = DEFAULT_MIN_ALPHA;
  private static final float DEFAULT_MIN_SCALE = 0.85f;
  private float mMinScale = DEFAULT_MIN_SCALE;
  public static final float DEFAULT_CENTER = 0.5f;

  @Override
  public void transformPage(View view, float position) {
    int pageWidth = view.getWidth();
    int pageHeight = view.getHeight();

    view.setScaleX(0.999f);// hack
    view.setPivotY(pageHeight / 2);
    view.setPivotX(pageWidth / 2);

    if (position < -1) { // [-Infinity,-1)
      view.setAlpha(mMinAlpha);
      view.setScaleX(mMinScale);
      view.setScaleY(mMinScale);
      view.setPivotX(pageWidth);

    } else if (position <= 1) { // [-1,1]

      if (position < 0) // [0,-1]
      { // [1,min]
        float factor = mMinAlpha + (1 - mMinAlpha) * (1 + position);
        float scaleFactor = (1 + position) * (1 - mMinScale) + mMinScale;

        view.setAlpha(factor);
        view.setScaleX(scaleFactor);
        view.setScaleY(scaleFactor);
        view.setPivotX(pageWidth * (DEFAULT_CENTER + (DEFAULT_CENTER * -position)));

      } else// [1,0]
      {
        // [min,1]
        float factor = mMinAlpha + (1 - mMinAlpha) * (1 - position);
        float scaleFactor = (1 - position) * (1 - mMinScale) + mMinScale;

        view.setAlpha(factor);
        view.setScaleX(scaleFactor);
        view.setScaleY(scaleFactor);
        view.setPivotX(pageWidth * ((1 - position) * DEFAULT_CENTER));

      }
    } else { // (1,+Infinity]
      view.setAlpha(mMinAlpha);
      view.setPivotX(0);
      view.setScaleX(mMinScale);
      view.setScaleY(mMinScale);
    }
  }
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android獲取系統(tǒng)時(shí)間以及網(wǎng)絡(luò)時(shí)間

    Android獲取系統(tǒng)時(shí)間以及網(wǎng)絡(luò)時(shí)間

    這篇文章主要為大家詳細(xì)介紹了Android獲取系統(tǒng)時(shí)間以及網(wǎng)絡(luò)時(shí)間的方法,感興趣的小伙伴們可以參考一下
    2016-07-07
  • Android開發(fā)技巧之ViewStub控件惰性裝載

    Android開發(fā)技巧之ViewStub控件惰性裝載

    布局文件中的控件并不一定在程序啟動(dòng)時(shí)全都用到,有一些控件只在特定的情況下才會(huì)被使用到;我們急需一種機(jī)制來改變<include>標(biāo)簽的這種行為,只在需要時(shí)裝載控件。這種機(jī)制就是本節(jié)要介紹的ViewStub控件
    2013-01-01
  • Android版多線程下載 仿下載助手(最新)

    Android版多線程下載 仿下載助手(最新)

    我們都知道,下載助手,比如360,百度的 手機(jī)助手,下載APP的時(shí)候 ,都可以同時(shí)下載多個(gè),所以下載肯定是多線程的,所以我們就需要一個(gè)線程工具類來管理我們的線程,這個(gè)工具類的核心,就是線程池。接下來給大家介紹Android版多線程下載 仿下載助手(最新)
    2015-08-08
  • android實(shí)現(xiàn)音樂播放器

    android實(shí)現(xiàn)音樂播放器

    這篇文章主要為大家詳細(xì)介紹了android實(shí)現(xiàn)音樂播放器,擁有播放、暫停、重新播放和停止等功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • Android Jetpack架構(gòu)組件Lifecycle詳解

    Android Jetpack架構(gòu)組件Lifecycle詳解

    這篇文章主要介紹了Android Jetpack架構(gòu)組件Lifecycle詳解,Lifecycle是Jetpack架構(gòu)組件中用來感知生命周期的組件,使用Lifecycles可以幫助我們寫出和生命周期相關(guān)更簡(jiǎn)潔更易維護(hù)的代碼。對(duì)此感興趣的小伙伴可以來學(xué)習(xí)一下
    2020-07-07
  • Android畫板開發(fā)之橡皮擦功能

    Android畫板開發(fā)之橡皮擦功能

    這篇文章主要為大家詳細(xì)介紹了Android畫板開發(fā)之橡皮擦功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • Android手機(jī)使用Fiddler方法介紹

    Android手機(jī)使用Fiddler方法介紹

    這篇文章主要為大家詳細(xì)介紹了Android手機(jī)使用Fiddler方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • Android購(gòu)物車項(xiàng)目快速開發(fā)

    Android購(gòu)物車項(xiàng)目快速開發(fā)

    這篇文章主要為大家詳細(xì)介紹了Android購(gòu)物車項(xiàng)目快速開發(fā),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 解決Android Studio導(dǎo)入項(xiàng)目非常慢的辦法

    解決Android Studio導(dǎo)入項(xiàng)目非常慢的辦法

    在使用Android studio的時(shí)候常常遇到這樣的問題,從其他地方導(dǎo)入項(xiàng)目,Android studio呈現(xiàn)非常慢的現(xiàn)象!當(dāng)遇到這種情況時(shí),可以看看是下面這篇文章,再按照方法來解決!
    2016-09-09
  • Android開發(fā)Activity的生命周期詳解

    Android開發(fā)Activity的生命周期詳解

    這篇文章主要介紹了Android開發(fā)Activity的生命周期詳解,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參一下
    2022-07-07

最新評(píng)論