首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 移动开发 > Android >

Android运用ViewPager实现左右滑动效果

2012-10-14 
Android使用ViewPager实现左右滑动效果使用ViewPager用使用android的兼容包,android-support-v4.jar。工程

Android使用ViewPager实现左右滑动效果

使用ViewPager用使用android的兼容包,android-support-v4.jar。

工程源代码下载:点击下载

在res/layout下建立三个文件first.xml,second.xml,third.xml,随便加入一些控件

Android运用ViewPager实现左右滑动效果

main.xml文件的布局如下:

<?xml version="1.0" encoding="utf-8"?><FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="fill_parent"    android:layout_height="fill_parent"    android:orientation="vertical" >    <android.support.v4.view.ViewPager        android:id="@+id/viewpager"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_gravity="center"        />   <RelativeLayout        android:layout_width="fill_parent"       android:layout_height="wrap_content"       >    <LinearLayout        android:id="@+id/group"        android:layout_width="fill_parent"        android:layout_height="wrap_content"        android:layout_alignParentBottom="true"          android:layout_marginBottom="30dp"        android:orientation="horizontal"        android:gravity="center_horizontal"       />             </RelativeLayout></FrameLayout>


在LinaerLayout外面套一个RelativeLayout是为了使得

android:layout_alignParentBottom="true" 这行代码有用

LinaerLayout主要是布局下面的小圆点。要使用两张图片R.drawable.page_indicator_focused和R.drawable.page_indicator。

在主Activity中的代码没什么好说的直接贴上来

package com.zhycheng.viewpage;import java.util.ArrayList;import android.app.Activity;import android.os.Bundle;import android.os.Parcelable;import android.support.v4.view.PagerAdapter;import android.support.v4.view.ViewPager;import android.support.v4.view.ViewPager.OnPageChangeListener;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.view.ViewGroup.LayoutParams;import android.widget.ImageView;import android.widget.LinearLayout;import android.widget.Toast;public class ViewPageActivity extends Activity implements OnPageChangeListener {ViewPager mvp;ImageView []images;ImageView iv;LinearLayout ll;ViewGroup vg;    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        //        final ArrayList<View> aViews=new ArrayList<View>();        LayoutInflater lf=LayoutInflater.from(this);        vg=(ViewGroup) lf.inflate(R.layout.main, null);        View v1=lf.inflate(R.layout.first, null);        View v2=lf.inflate(R.layout.second, null);        View v3=lf.inflate(R.layout.third, null);        aViews.add(v1);        aViews.add(v2);        aViews.add(v3);        mvp=(ViewPager) vg.findViewById(R.id.viewpager);        ll=(LinearLayout) vg.findViewById(R.id.group);                       images=new ImageView[aViews.size()];        for(int i=0;i<images.length;i++)        {        iv=new ImageView(this);        iv.setLayoutParams(new LayoutParams(20,20));        iv.setPadding(20, 0, 20, 0);        if(i==0)        {        iv.setBackgroundResource(R.drawable.page_indicator_focused);        }        else        {        iv.setBackgroundResource(R.drawable.page_indicator);        }        images[i]=iv;        ll.addView(images[i]);        }                                               PagerAdapter pa=new PagerAdapter(){@Overridepublic int getCount() {// TODO Auto-generated method stubreturn aViews.size();}@Overridepublic void destroyItem(View container, int position, Object object) {// TODO Auto-generated method stub((ViewPager)container).removeView(aViews.get(position));}@Overridepublic boolean isViewFromObject(View arg0, Object arg1) {// TODO Auto-generated method stubreturn arg0==arg1;}@Overridepublic void finishUpdate(View arg0) {// TODO Auto-generated method stub}@Overridepublic Object instantiateItem(View arg0, int arg1) {// TODO Auto-generated method stub((ViewPager)arg0).addView(aViews.get(arg1),0);return aViews.get(arg1);}@Overridepublic void restoreState(Parcelable arg0, ClassLoader arg1) {// TODO Auto-generated method stub}@Overridepublic Parcelable saveState() {// TODO Auto-generated method stubreturn null;}@Overridepublic void startUpdate(View arg0) {// TODO Auto-generated method stub}};setContentView(vg);        mvp.setAdapter(pa);        mvp.setOnPageChangeListener(this);     }@Overridepublic void onPageScrollStateChanged(int arg0) {// TODO Auto-generated method stub//Toast.makeText(this, "onPageScrollStateChanged"+arg0, 1000).show();}@Overridepublic void onPageScrolled(int arg0, float arg1, int arg2) {// TODO Auto-generated method stub//Toast.makeText(this, "onPageScrolled", 1000).show();}@Overridepublic void onPageSelected(int arg0) {// TODO Auto-generated method stubfor(int i=0;i<images.length;i++){if(i==arg0){images[i].setBackgroundResource(R.drawable.page_indicator_focused);}else{images[i].setBackgroundResource(R.drawable.page_indicator);}}}}


 

 

 

热点排行