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

Android ViewPager實現(xiàn)滑動指示條功能

 更新時間:2020年10月21日 10:28:54   作者:Red&&Black  
這篇文章主要介紹了Android-ViewPager實現(xiàn)滑動指示條功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

布局

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity"
    android:orientation="vertical">


  <LinearLayout
      android:layout_width="match_parent"
      android:layout_height="48dp"
      tools:ignore="MissingConstraints" android:id="@+id/linearLayout">

    <TextView
        android:id="@+id/tv_one"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="1.0"
        android:gravity="center"
        android:text="黃色"
        android:textColor="#000000"/>

    <TextView
        android:id="@+id/tv_two"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="1.0"
        android:gravity="center"
        android:text="紅色"
        android:textColor="#000000"/>

    <TextView
        android:id="@+id/tv_three"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="1.0"
        android:gravity="center"
        android:text="綠色"
        android:textColor="#000000"/>
  </LinearLayout>

  <ImageView
      android:id="@+id/img_cursor"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:scaleType="matrix"
      android:src="@mipmap/line"
      />

  <android.support.v4.view.ViewPager
      android:id="@+id/vp_show"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_gravity="center" tools:ignore="MissingConstraints"/>

</LinearLayout>

view1.xml view2.xml… 基本相同

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
       android:orientation="vertical"
       android:layout_width="match_parent"
       android:background="@color/colorAccent"
       android:layout_height="match_parent">
  <View
      android:id="@+id/vp_text"
      android:text="page 2"

      android:layout_width="match_parent"
      android:layout_height="match_parent" />

</LinearLayout>

素材line.png

在這里插入圖片描述

注意,由于api版本不同,android.support.v4.view.ViewPager可能報錯,
更換為androidx.viewpager.widget.ViewPager

java代碼

MyPagerAdapter類

package com.demo;

import android.support.annotation.NonNull;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;

import java.util.ArrayList;

public class MyPagerAdapter extends PagerAdapter {

  private ArrayList<View> viewLists;


  public MyPagerAdapter() {
  }

  public MyPagerAdapter(ArrayList<View> viewLists) {
    this.viewLists = viewLists;
  }

  @Override
  public int getCount() {
    return viewLists.size();
  }

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

  @NonNull
  @Override
  public Object instantiateItem(@NonNull ViewGroup container, int position) {

    container.addView(viewLists.get(position));
    return viewLists.get(position);
  }

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

MainActivity類

package com.demo;

import android.annotation.SuppressLint;
import android.graphics.BitmapFactory;
import android.graphics.Matrix;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.DisplayMetrics;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.TranslateAnimation;
import android.widget.ImageView;
import android.widget.TextView;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity implements View.OnClickListener,
    ViewPager.OnPageChangeListener{

  private ViewPager pager1;
  private ArrayList<View> list;
  private MyPagerAdapter myPagerAdapter;


  private ImageView img_cursor;
  private TextView tv_one;
  private TextView tv_two;
  private TextView tv_three;
  private int offSet = 0; //移動條圖片的偏移量
  private int currIndex = 0; //當(dāng)前頁
  private int imageWidth = 0; //移動條圖片的寬度
  private int one = 0;  //移動條滑動一頁的距離
  private int two = 0;  //移動條滑動兩頁的距離

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    init();

  }

  private void init() {
    tv_one = findViewById(R.id.tv_one);
    tv_two = findViewById(R.id.tv_two);
    tv_three = findViewById(R.id.tv_three);
    img_cursor =findViewById(R.id.img_cursor);

    /**
     * 下劃線動畫的相關(guān)設(shè)置
     */
    //獲取圖片的寬度
    imageWidth = BitmapFactory.decodeResource(getResources(),R.mipmap.line).getWidth();


    DisplayMetrics dm = new DisplayMetrics();
    //獲取手機屏幕寬度
    getWindowManager().getDefaultDisplay().getMetrics(dm);
    int screenW = dm.widthPixels;
    offSet = (screenW/3 - imageWidth) /2 ; //計算偏移量

    Matrix matrix = new Matrix();
    matrix.postTranslate(offSet,0);

    img_cursor.setImageMatrix(matrix);//設(shè)置動畫初始位置

    one = offSet *2 +imageWidth;
    two = one*2;

    pager1 = findViewById(R.id.vp_show);

    //往ViewPager填充View,同時設(shè)置點擊事件與頁面切換事件
    list = new ArrayList<>();
    LayoutInflater li = getLayoutInflater();

    list.add(li.inflate(R.layout.view3,null,false));
    list.add(li.inflate(R.layout.view1,null,false));
    list.add(li.inflate(R.layout.view2,null,false));

    myPagerAdapter= new MyPagerAdapter(list);
    pager1.setAdapter(myPagerAdapter);
    pager1.setCurrentItem(0);     //設(shè)置ViewPager當(dāng)前頁,從0開始算

    tv_one.setOnClickListener(this);
    tv_two.setOnClickListener(this);
    tv_three.setOnClickListener(this);

    pager1.addOnPageChangeListener(this);

  }

  @Override
  public void onPageScrolled(int i, float v, int i1) {

  }

  @Override
  public void onPageSelected(int i) {
    Animation animation = null;
    switch (i){

      case 0:
        if (currIndex==1) {
          animation = new TranslateAnimation(one,0,0,0);
        }
        else if (currIndex==2) {
          animation = new TranslateAnimation(two,0,0,0);
        }
        break;
      case 1:
        if (currIndex==0) {
          animation = new TranslateAnimation(offSet,one,0,0);
        }
        else if (currIndex==2) {
          animation = new TranslateAnimation(two,one,0,0);
        }
        break;
      case 2:
        if (currIndex==1) {
          animation = new TranslateAnimation(one,two,0,0);
        }
        else if (currIndex==0) {
          animation = new TranslateAnimation(offSet,two,0,0);
        }
        break;
    }

    currIndex = i;
    animation.setFillAfter(true); // true表示圖片停在動畫結(jié)束位置
    animation.setDuration(300); //設(shè)置動畫時間
    img_cursor.startAnimation(animation); //開始動畫

  }

  @Override
  public void onPageScrollStateChanged(int i) {

  }

  @Override
  public void onClick(View view) {

    switch (view.getId()) {
      case R.id.tv_one: pager1.setCurrentItem(0);break;
      case R.id.tv_two: pager1.setCurrentItem(1);break;
      case R.id.tv_three: pager1.setCurrentItem(2);break;
    }

  }
}

效果

在這里插入圖片描述

到此這篇關(guān)于Android ViewPager實現(xiàn)滑動指示條功能的文章就介紹到這了,更多相關(guān)Android滑動指示條內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Flutter實現(xiàn)底部導(dǎo)航欄創(chuàng)建詳解

    Flutter實現(xiàn)底部導(dǎo)航欄創(chuàng)建詳解

    ConvexBottomBar是一個底部導(dǎo)航欄組件,用于展現(xiàn)凸起的TAB效果,支持多種內(nèi)置樣式與動畫交互。本文將利用ConvexBottomBar創(chuàng)建漂亮的底部導(dǎo)航欄,感興趣的可以學(xué)習(xí)一下
    2022-01-01
  • Android開發(fā)實現(xiàn)抽屜菜單

    Android開發(fā)實現(xiàn)抽屜菜單

    這篇文章主要為大家詳細介紹了Android開發(fā)實現(xiàn)抽屜菜單,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • Android開發(fā)之Notification手機狀態(tài)欄通知用法實例分析

    Android開發(fā)之Notification手機狀態(tài)欄通知用法實例分析

    這篇文章主要介紹了Android開發(fā)之Notification手機狀態(tài)欄通知用法,結(jié)合實例形式分析了Android Notification手機狀態(tài)欄通知的常見函數(shù)、功能及使用技巧,需要的朋友可以參考下
    2019-03-03
  • 音量控制鍵控制的音頻流(setVolumeControlStream)描述

    音量控制鍵控制的音頻流(setVolumeControlStream)描述

    當(dāng)開發(fā)多媒體應(yīng)用或者游戲應(yīng)用的時候,需要使用音量控制鍵來設(shè)置程序的音量大小,在Android系統(tǒng)中有多種音頻流,感興趣的朋友可以了解下
    2013-01-01
  • Android實現(xiàn)簡單的照相功能

    Android實現(xiàn)簡單的照相功能

    這篇文章主要為大家詳細介紹了Android實現(xiàn)簡單的照相功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Android利用ViewPager實現(xiàn)用戶引導(dǎo)界面效果的方法

    Android利用ViewPager實現(xiàn)用戶引導(dǎo)界面效果的方法

    這篇文章主要介紹了Android利用ViewPager實現(xiàn)用戶引導(dǎo)界面效果的方法,結(jié)合實例形式詳細分析了Android軟件功能界面的初始化、view實例化、動畫功能實現(xiàn)與布局相關(guān)技巧,需要的朋友可以參考下
    2016-07-07
  • 詳解Android微信登錄與分享

    詳解Android微信登錄與分享

    本篇文章主要對Android微信登錄與分享功能的實現(xiàn)進行了介紹。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • Android activity和view判斷滑動

    Android activity和view判斷滑動

    這篇文章主要介紹了Android activity和view判斷滑動的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • Android Parcelable接口使用方法詳解

    Android Parcelable接口使用方法詳解

    這篇文章主要介紹了 Android Parcelable接口使用方法詳解的相關(guān)資料,實現(xiàn)Parcelable就是為了進行序列化,需要的朋友可以參考下
    2017-08-08
  • Android RecycleView添加head配置封裝的實例

    Android RecycleView添加head配置封裝的實例

    這篇文章主要介紹了Android RecycleView添加head配置封裝的實例的相關(guān)資料,這里提供實例幫助大家實現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-08-08

最新評論