Android:ViewPager實現螢幕輪轉和使用PagerTabStrip,

來源:互聯網
上載者:User

Android:ViewPager實現螢幕輪轉和使用PagerTabStrip,

  ① ViewPager類直接繼承了ViewGroup類,所有它是一個容器類,可以在其中添加其他的view類。

  ② ViewPager類需要一個PagerAdapter適配器類給它提供資料。

  ③ ViewPager經常和Fragment一起使用,並且提供了專門的FragmentPagerAdapter和FragmentStatePagerAdapter類供Fragment中的ViewPager使用。

   在編寫ViewPager的應用的使用,還需要使用兩個組件類分別是PagerTitleStrip類和PagerTabStrip類,PagerTitleStrip類直接繼承自ViewGroup類,而PagerTabStrip類繼承PagerTitleStrip類,所以這兩個類也是容器類。但是有一點需要注意,在定義XML的layout的時候,這兩個類必須是ViewPager標籤的子標籤,不然會出錯。

 

activity_main.xml

<RelativeLayout 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.support.v4.view.ViewPager        android:id="@+id/viewpager"        android:layout_width="wrap_content"        android:layout_height="wrap_content">        <android.support.v4.view.PagerTabStrip            android:id="@+id/viewpager_tab"            android:layout_width="wrap_content"            android:layout_height="50dp"            android:background="#ffe66f"            >        </android.support.v4.view.PagerTabStrip>    </android.support.v4.view.ViewPager></RelativeLayout>

MainActivity.java

   裡面有很詳細的注釋,我就不在這贅述了.

package com.example.administrator.viewpagerdemo;import android.app.Activity;import android.os.Bundle;import android.support.v4.view.PagerAdapter;import android.support.v4.view.PagerTabStrip;import android.support.v4.view.PagerTitleStrip;import android.support.v4.view.ViewPager;import android.view.LayoutInflater;import android.view.Menu;import android.view.MenuItem;import android.view.View;import android.view.ViewGroup;import java.util.ArrayList;import java.util.List;public class MainActivity extends Activity {    private ViewPager viewPager = null;    private PagerTabStrip pagerTabStrip = null;  //導航條    private List<View> viewContainter = new ArrayList<View>();   //存放容器    private List<String> tabContainter = new ArrayList<String>();   //存放 tab導航    private ViewPagerAdapter viewPagerAdapter;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        // 綁定組件        viewPager = (ViewPager) findViewById(R.id.viewpager);        pagerTabStrip = (PagerTabStrip) findViewById(R.id.viewpager_tab);        pagerTabStrip.setTextColor(getResources().getColor(R.color.black));  //設定 字型顏色        //取消Tab 下面的長橫線        pagerTabStrip.setDrawFullUnderline(false);        //設定每個Tab的底線顏色        pagerTabStrip.setTabIndicatorColor(getResources().getColor(R.color.red));        pagerTabStrip.setTextSize(0,40);        pagerTabStrip.setTextSpacing(10);        //建立四個view的樣式,並找到他們        View view_1 = LayoutInflater.from(getApplicationContext()).inflate(R.layout.viewpager_view_1,null);        View view_2 = LayoutInflater.from(getApplicationContext()).inflate(R.layout.viewpager_view_2,null);        View view_3 = LayoutInflater.from(getApplicationContext()).inflate(R.layout.viewpager_view_3,null);        View view_4 = LayoutInflater.from(getApplicationContext()).inflate(R.layout.viewpager_view_4,null);        //加入ViewPage的容器        viewContainter.add(view_1);        viewContainter.add(view_2);        viewContainter.add(view_3);        viewContainter.add(view_4);        //想Tab容器中加入標籤        tabContainter.add("最近");        tabContainter.add("今天");        tabContainter.add("明天");        tabContainter.add("後天");        //初始化viewPagerAdapter        viewPagerAdapter = new ViewPagerAdapter();        //設定adapter        viewPager.setAdapter(viewPagerAdapter);           }    //viewpager的適配器    private class ViewPagerAdapter extends PagerAdapter{        //該方法 決定 並 返回 viewpager中組件的數量        @Override        public int getCount() {            return viewContainter.size();        }        @Override        public boolean isViewFromObject(View view, Object o) {            return view == o;        }        //滑動切換的時候,消除當前組件        @Override        public void destroyItem(ViewGroup container, int position, Object object) {            container.removeView(viewContainter.get(position));        }        //每次滑動的時候產生的組件        @Override        public Object instantiateItem(ViewGroup container, int position) {            container.addView(viewContainter.get(position));            return viewContainter.get(position);        }        //設定Tab        @Override        public CharSequence getPageTitle(int position) {            return tabContainter.get(position);        }    }    @Override    public boolean onCreateOptionsMenu(Menu menu) {        // Inflate the menu; this adds items to the action bar if it is present.        getMenuInflater().inflate(R.menu.menu_main, menu);        return true;    }    @Override    public boolean onOptionsItemSelected(MenuItem item) {        // Handle action bar item clicks here. The action bar will        // automatically handle clicks on the Home/Up button, so long        // as you specify a parent activity in AndroidManifest.xml.        int id = item.getItemId();        //noinspection SimplifiableIfStatement        if (id == R.id.action_settings) {            return true;        }        return super.onOptionsItemSelected(item);    }}

 

我們還需要建立四個View的布局檔案,裡面就放了一個ImageView,並且指定了背景,在這裡我就貼出來一個布局檔案的代碼(其他的都一樣)

<?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:layout_height="match_parent">    <ImageView        android:id="@+id/viewpager_view_image_1"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:background="@drawable/image1"/></LinearLayout>

:

對於PagerAdapter類,android的文檔已經說的很清楚了,必須至少實現如下的4個方法,如果需要更好的擴充也可以實現更多的方法。

public Object instantiateItem(ViewGroup container, int position)

 

public void destroyItem(ViewGroup container, int position,Object object) 

public int getCount()

public boolean isViewFromObject(View arg0, Object arg1) 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.