zoukankan      html  css  js  c++  java
  • Android多画面幻灯片:ViewPager基础上,利用与PagerTabStrip出生缺陷(源代码)

    近期使用ViewPager。读了几个人说是不是很清晰的信息,干脆自己写demo总结下。

    样例非常easy。Activity里有三个界面能够滑动。每个界面都有一个button并设置好了监听。PagerTabStrip也就是滑动时的那个标识线。在View的下方。下为代码:

    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"
        android:paddingBottom="@dimen/activity_vertical_margin"
        android:paddingLeft="@dimen/activity_horizontal_margin"
        android:paddingRight="@dimen/activity_horizontal_margin"
        android:paddingTop="@dimen/activity_vertical_margin"
        tools:context=".MainActivity" >
    
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/hello_world" />
    
        <android.support.v4.view.ViewPager
            android:id="@+id/viewpager"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true" >
    
            <android.support.v4.view.PagerTabStrip
                android:id="@+id/pagertab"
                android:layout_width="match_parent"
                android:layout_height="wrap_content" 
                android:layout_gravity="bottom"/>
        </android.support.v4.view.ViewPager>
    
    </RelativeLayout>

    以下是三个view布局,都差点儿相同:

    first_pager_layout.xml

    <?

    xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:background="@android:color/holo_blue_bright"> <Button android:id="@+id/btn_in_first" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="请点击" android:layout_gravity="center"/> </LinearLayout>


    second_pager_layout.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical" 
        android:background="@android:color/holo_green_light">
     <Button 
        android:id="@+id/btn_in_second"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="请点击"
        android:layout_gravity="center"/>   
    
    </LinearLayout>
    

    third_pager_layout.xml

    <?xml version="1.0" encoding="utf-8"?

    > <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:background="@android:color/holo_red_light"> <Button android:id="@+id/btn_in_third" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="请点击" android:layout_gravity="center"/> </LinearLayout>


    MainActivity.java(这是主程序里。在里面实例化ViewPager并设置它的适配器)

    package org.yanzi.testviewpager1;
    
    import java.util.ArrayList;
    import java.util.List;
    
    import android.app.Activity;
    import android.content.Context;
    import android.graphics.Color;
    import android.os.Bundle;
    import android.support.v4.view.PagerTabStrip;
    import android.support.v4.view.PagerTitleStrip;
    import android.support.v4.view.ViewPager;
    import android.support.v4.view.ViewPager.OnPageChangeListener;
    import android.view.LayoutInflater;
    import android.view.Menu;
    import android.view.View;
    import android.widget.Button;
    import android.widget.Toast;
    
    public class MainActivity extends Activity {
    
    	List<View> mViews = new ArrayList<View>();
    	String[] mTitles = {"页面1", "页面2", "页面3"};
    	MyPagerAdapter pagerAdapter;
    	PagerTabStrip pagerTabStrip;
    	PagerTitleStrip pagerTitleStrip;
    	ViewPager viewPager;
    	View view1, view2, view3;
    	Button btn1, btn2, btn3;
    	BtnListener btnListener;
    
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.activity_main);
    		initUI();
    		LayoutInflater flater = (LayoutInflater) this.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    
    		view1 = flater.inflate(R.layout.first_pager_layout, null);
    		view2 = flater.inflate(R.layout.second_pager_layout, null);
    		view3 = flater.inflate(R.layout.third_pager_layout, null);
    		mViews.add(view1);
    		mViews.add(view2);
    		mViews.add(view3);
    		pagerAdapter = new MyPagerAdapter(mViews, mTitles);
    		viewPager.setAdapter(pagerAdapter);
    		viewPager.setCurrentItem(1);
    
    		//设置pagerTabStrip
    		pagerTabStrip.setTabIndicatorColor(Color.RED);
    		pagerTabStrip.setTextColor(Color.RED);
    		pagerTabStrip.setClickable(false);
    		pagerTabStrip.setTextSpacing(40);
    		pagerTabStrip.setBackgroundColor(Color.GRAY);
    		pagerTabStrip.setDrawFullUnderline(true);
    		/*		pagerTitleStrip.setTextColor(Color.RED);
    		pagerTitleStrip.setTextSpacing(40);*/
    
    		//ViewPager滑动监听
    		viewPager.setOnPageChangeListener(new OnPageChangeListener() {
    
    			@Override
    			public void onPageSelected(int arg0) {
    				// TODO Auto-generated method stub
    				showToast("切换至:" + mTitles[arg0]);
    			}
    
    			@Override
    			public void onPageScrolled(int arg0, float arg1, int arg2) {
    				// TODO Auto-generated method stub
    
    			}
    
    			@Override
    			public void onPageScrollStateChanged(int arg0) {
    				// TODO Auto-generated method stub
    
    			}
    		});
    		
    		initBtns();
    
    	}
    
    	@Override
    	public boolean onCreateOptionsMenu(Menu menu) {
    		// Inflate the menu; this adds items to the action bar if it is present.
    		getMenuInflater().inflate(R.menu.main, menu);
    		return true;
    	}
    	private void initUI(){
    		viewPager = (ViewPager)findViewById(R.id.viewpager);
    		pagerTabStrip = (PagerTabStrip)findViewById(R.id.pagertab);
    		//		pagerTitleStrip = (PagerTitleStrip)findViewById(R.id.pagertab);
    	}
    	private void initBtns(){
    		if(view1 != null){
    			btn1 = (Button)view1.findViewById(R.id.btn_in_first);
    
    		}
    		if(view2 != null){
    			btn2 = (Button)view2.findViewById(R.id.btn_in_second);
    		}
    		if(view3 != null){
    			btn3 = (Button)view3.findViewById(R.id.btn_in_third);
    		}
    		btnListener = new BtnListener();
    		
    		btn1.setOnClickListener(btnListener);
    		btn2.setOnClickListener(btnListener);
    		btn3.setOnClickListener(btnListener);
    	}
    	class BtnListener implements View.OnClickListener{
    
    		@Override
    		public void onClick(View v) {
    			// TODO Auto-generated method stub
    			switch (v.getId()){
    			case R.id.btn_in_first:
    				showToast("您点击了第一个界面");
    				break;
    			case R.id.btn_in_second:
    				showToast("您点击了第2个界面");
    				break;
    			case R.id.btn_in_third:
    				showToast("您点击了第3个界面");
    				break;
    			default:break;
    			}
    		}
    
    	}
    	private void showToast(String s){
    		Toast.makeText(getApplicationContext(), s, Toast.LENGTH_SHORT).show();
    	}
    
    }
    

    MyPagerAdapter.java(这是ViewPager的适配器,继承PagerAdapter,将其单独写到一个文件中了)

    package org.yanzi.testviewpager1;
    
    import java.util.List;
    
    import android.support.v4.view.PagerAdapter;
    import android.view.View;
    import android.view.ViewGroup;
    
    public class MyPagerAdapter extends PagerAdapter {
    	private List<View> mListViews;
    	private String[] mTitles;
    	public MyPagerAdapter(List<View> views, String[] titles){
    		this.mListViews = views;
    		this.mTitles = titles;
    	}
    	@Override
    	public int getCount() {
    		// TODO Auto-generated method stub
    		return mListViews.size();
    	}
    
    	@Override
    	public boolean isViewFromObject(View arg0, Object arg1) {
    		// TODO Auto-generated method stub
    		return (arg0==arg1);
    	}
    	@Override
    	public void destroyItem(ViewGroup container, int position, Object object) {
    		// TODO Auto-generated method stub
    		container.removeView(mListViews.get(position));
    	}
    	@Override
    	public Object instantiateItem(ViewGroup container, int position) {
    		// TODO Auto-generated method stub
    		container.addView(mListViews.get(position), 0);
    		return mListViews.get(position);
    	}
    	@Override
    	public CharSequence getPageTitle(int position) {
    		// TODO Auto-generated method stub
    		return mTitles[position];
    	}
    	
    
    
    }
    

    要点:

    1、ViewPager说白了就是个控件,在使用时包名要带全是android.support.v4.view.ViewPager。

    由于我的ADT-Bundle版本号比較高。这个包默认自带了,且默认是随apk打包导出的。

    例如以下图:



    假设在Android Private Libraries里没这个包,则要自己在属性的Libraries里自己加入。

    加入后记得在上图所看到的的Order and Export里将其打勾。

    2.理论上说要实现滑屏仅仅要一个ViewPager就能够了,不须要再在里面嵌套例如以下:

            <android.support.v4.view.PagerTabStrip
                android:id="@+id/pagertab"
                android:layout_width="match_parent"
                android:layout_height="wrap_content" 
                android:layout_gravity="bottom"/>

    这个PagerTabStrip就是个横线,假设想用它来标识当前在哪个View的话能够加它,当然最后你会发现这就是个坑爹的玩意。

    除了PagerTabStrip。另一个PagerTitleStrip,两者的使用方法地位都是一样的,均要嵌套在ViewPager里。差别是:

    a、PagerTabStrip在效果上包括了PagerTitleStrip,假设仅仅加入PagerTabStrip能够看到仅仅有线,可是它占的布局是有一定高度的。

    默认是不显示标题的,假设要显示需在适配器里重写:

    @Override
    public CharSequence getPageTitle(int position) {
    // TODO Auto-generated method stub
    return mTitles[position];
    }

    就会显示标题了。关于标题及这个线的颜色,和整个标识View的背景能够再代码里设置。demo里有演示样例。

    b、PagerTitleStrip仅仅显示标题而没有那个线。

    c、PagerTabStrip能够点击切换View,而PagerTitleStrip不能点击。很多其它參见链接

    两者相对父亲ViewPager的位置,也就是标识是在View的上面还是以下。通过PagerTabStrip的属性android:layout_gravity="bottom"来设置。

    3、就像ListView的一样,ViewPager的关键在于适配器,而要用正常使用须要至少重写以下四个方法:

    	@Override
    	public int getCount() {
    		// TODO Auto-generated method stub
    		return mListViews.size();
    	}
    
    	@Override
    	public boolean isViewFromObject(View arg0, Object arg1) {
    		// TODO Auto-generated method stub
    		return (arg0==arg1);
    	}
    	@Override
    	public void destroyItem(ViewGroup container, int position, Object object) {
    		// TODO Auto-generated method stub
    		container.removeView(mListViews.get(position));
    	}
    	@Override
    	public Object instantiateItem(ViewGroup container, int position) {
    		// TODO Auto-generated method stub
    		container.addView(mListViews.get(position), 0);
    		return mListViews.get(position);
    	}

    以下这种方法是用来显示标题的,一般不重写,由于PagerTabStrip是个中看不中用的玩意。

    	@Override
    	public CharSequence getPageTitle(int position) {
    		// TODO Auto-generated method stub
    		return mTitles[position];
    	}

    4、在设置适配器后。通过viewPager.setCurrentItem(1);来设置默认的ViewPager显示哪一个View。

    1标识第二个界面。

    5、每个View里都用子控件。通过initBtns()来获得,注意findViewById时一定要前面加上它的父亲.例如以下:

    btn1 = (Button)view1.findViewById(R.id.btn_in_first);更为严谨的做法是仅仅有显示当前View时,这个View里的控件才干够被监听。


    6、当ViewPager的View发生变化时,设置监听:

    //ViewPager滑动监听
    viewPager.setOnPageChangeListener(new OnPageChangeListener() {


    @Override
    public void onPageSelected(int arg0) {
    // TODO Auto-generated method stub
    showToast("切换至:" + mTitles[arg0]);
    }


    @Override
    public void onPageScrolled(int arg0, float arg1, int arg2) {
    // TODO Auto-generated method stub


    }


    @Override
    public void onPageScrollStateChanged(int arg0) {
    // TODO Auto-generated method stub


    }
    });

    7、PagerTabStrip里的非常多方法都是没有效果的如pagerTabStrip.setTextSpacing(40); 

    pagerTabStrip.setDrawFullUnderline(true);

    以下是效果图:




    能够看到显示页面3时,以下的PageTabStrip居然发生移位了,没人会须要这种体验,真是个坑爹的玩意啊。本来我还不死心想找到不自己写PageTabStrip情况下解决这个问题。看到链接 彻底放弃了。关于标识还是自己来写吧,兴许文章会再给出完整演示样例。

    代码下载:http://download.csdn.net/detail/yanzi1225627/7223287




  • 相关阅读:
    STM32---GPIO
    SQLITE笔记
    STM32 ---- PWM
    STM32--- IIC使用
    TP配置apache下Rewrite模式
    韩顺平老师SNS数据库表 http://blog.csdn.net/zxman660/article/details/7786994
    HashMap和HashTable的区别http://blog.csdn.net/shohokuf/article/details/3932967
    HashMap和HashSet的区别http://www.importnew.com/6931.html
    在mysql中存储生日,php中计算今天是否为用户生日
    文件的MIME类型
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/4607295.html
Copyright © 2011-2022 走看看