【Android UI】案例03滑动切换效果的实现(ViewPager)

       本例使用ViewPager实现滑动切换的效果。本例涉及的ViewPager。为android.support.v4.view.ViewPager。所以须要在android项目中导入android-support-v4.jar。
       本例中ViewPager是实现滑动效果的核心部分。对其设置PageChangeListener监听事件,是实现滑动效果的核心思路。

【转载使用,请注明出处:http://blog.csdn.net/mahoking
       首先是主界面layout.xml文件。activity_03_viewpager.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" >
    <LinearLayout android:layout_width="match_parent"
        android:layout_height="40dp"
        android:orientation="horizontal">
        <TextView android:layout_height="match_parent"
            android:layout_width="match_parent"
            android:layout_weight="1"
            android:gravity="center"
            android:text="选项卡01"
            android:id="@+id/activity_03_viewpager_textview_01"/>
        <TextView android:layout_height="match_parent"
            android:layout_width="match_parent"
            android:layout_weight="1"
            android:text="选项卡02"
            android:gravity="center"
            android:id="@+id/activity_03_viewpager_textview_02"/>
        <TextView android:layout_height="match_parent"
            android:layout_width="match_parent"
            android:layout_weight="1"
            android:gravity="center"
            android:text="选项卡03"
            android:id="@+id/activity_03_viewpager_textview_03"/>
    </LinearLayout>
	<ImageView
	        android:id="@+id/cursor"
	        android:layout_width="match_parent"
	        android:layout_height="wrap_content"
	        android:scaleType="matrix"
	        android:src="@drawable/example03_cursor" />
	
	<android.support.v4.view.ViewPager
        android:id="@+id/activity_03_viewpager_vPager"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:layout_weight="1.0"
        android:background="#000000"
        android:flipInterval="30"
        android:persistentDrawingCache="animation" />
</LinearLayout>

       以上须要一个ImageView组件,该组件实现一种动态移动标签的效果,读者能够自行选择喜欢的标签下的底部长方形图片。可參考效果截图。


      主Activity(ViewPagerActivity)的编写。

首先是全局变量的定义:

private ViewPager mPager;// 页卡内容
private List<View> listViews; // Tab页面列表
private ImageView cursor;// 动绘图片
private TextView t1, t2, t3;// 页卡头标
private int offset = 0;// 动绘图片偏移量
private int currIndex = 0;// 当前页卡编号
private int bmpW;// 动绘图片宽度

         本例提供了三个初始化布局空间的方法,分别为:initTextViews()、initImageView()、initViewPager()。

initTextViews()

private void initTextViews() {
		t1 = (TextView) findViewById(R.id.activity_03_viewpager_textview_01);
		t2 = (TextView) findViewById(R.id.activity_03_viewpager_textview_02);
		t3 = (TextView) findViewById(R.id.activity_03_viewpager_textview_03);

		t1.setOnClickListener(new MyOnClickListener(0));
		t2.setOnClickListener(new MyOnClickListener(1));
		t3.setOnClickListener(new MyOnClickListener(2));
	}


initImageView()

private void initViewPager() {

		mPager = (ViewPager) findViewById(R.id.activity_03_viewpager_vPager);
		listViews = new ArrayList<View>();
		LayoutInflater mInflater = getLayoutInflater();
		listViews.add(mInflater.inflate(R.layout.layout_03_layout01, null));
		listViews.add(mInflater.inflate(R.layout.layout_03_layout02, null));
		listViews.add(mInflater.inflate(R.layout.layout_03_layout03, null));
		mPager.setAdapter(new ViewPagerAdapter(listViews));
		mPager.setCurrentItem(0);
		mPager.setOnPageChangeListener(new MyOnPageChangeListener());
	}

 

initViewPager()

/**
	 * 初始化动画
	 */
	private void initImageView() {
		cursor = (ImageView) findViewById(R.id.cursor);
		bmpW = BitmapFactory.decodeResource(getResources(), R.drawable.example03_cursor)
				.getWidth();// 获取图片宽度
		DisplayMetrics dm = new DisplayMetrics();
		getWindowManager().getDefaultDisplay().getMetrics(dm);
		int screenW = dm.widthPixels;// 获取分辨率宽度
		offset = (screenW / 3 - bmpW) / 2;// 计算偏移量
		Matrix matrix = new Matrix();
		matrix.postTranslate(offset, 0);
		cursor.setImageMatrix(matrix);// 设置动画初始位置
	}


        有上述方法可见,本例须要两内部类MyOnClickListener、MyOnPageChangeListener,去处理监听事件。


MyOnClickListener

/**
	 * 点击监听事件
	 *
	 */
	public class MyOnClickListener implements View.OnClickListener {
		private int index = 0;

		public MyOnClickListener(int i) {
			index = i;
		}

		@Override
		public void onClick(View v) {
			mPager.setCurrentItem(index);
		}
	};

MyOnPageChangeListener

/**
	 * 
	 *页卡切换监听
	 */
	public class MyOnPageChangeListener implements OnPageChangeListener{
		 int one = offset * 2 + bmpW;// 页卡1 -> 页卡2 偏移量
		       int two = one * 2;// 页卡1 -> 页卡3 偏移量
		
		        @Override
	         public void onPageSelected(int arg0) {
	             Animation animation = null;
		             switch (arg0) {
	            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 == 0) {
		                    animation = new TranslateAnimation(offset, two, 0, 0);
		                } else if (currIndex == 1) {
	                    animation = new TranslateAnimation(one, two, 0, 0);
		                 }
	                 break;
		            }
		             currIndex = arg0;
		             animation.setFillAfter(true);// True:图片停在动画结束位置
		            animation.setDuration(300);
		             cursor.startAnimation(animation);
		         }

	         @Override
	        public void onPageScrolled(int arg0, float arg1, int arg2) {
		         }
	 
		         @Override
		        public void onPageScrollStateChanged(int arg0) {
		        }
	}


         在此补充一下。本例须要展示三个页卡,所以还须要三个页卡内容的界面设计。在这里我们仅仅设置了背景颜色,仅仅为起到差别作用。

layout_03_layout01.xml

<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="#FF6666">
    
</LinearLayout>


效果截图:

 

【转载使用。请注明出处:http://blog.csdn.net/mahoking

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Android实现左右滑动动画,可以使用ViewPager。ViewPager是一个视图容器,可以让用户在屏幕上左右滑动,以便浏览多个页面。 下面是一些步骤,以实现ViewPager左右滑动翻页效果: 1. 在布局文件中添加ViewPager。 ```xml <android.support.v4.view.ViewPager android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#FFFFFF" /> ``` 2. 在MainActivity中,创建一个PagerAdapter类,它将管理页面。 ```java public class MyPagerAdapter extends PagerAdapter { private List<View> viewList; public MyPagerAdapter(List<View> viewList) { this.viewList = viewList; } @Override public int getCount() { return viewList.size(); } @Override public boolean isViewFromObject(View view, Object object) { return view == object; } @Override public void destroyItem(ViewGroup container, int position, Object object) { container.removeView(viewList.get(position)); } @Override public Object instantiateItem(ViewGroup container, int position) { container.addView(viewList.get(position)); return viewList.get(position); } } ``` 3. 在MainActivity中,为ViewPager设置PagerAdapter。 ```java ViewPager viewPager = findViewById(R.id.viewPager); List<View> viewList = new ArrayList<>(); viewList.add(new View(this)); viewList.add(new View(this)); viewList.add(new View(this)); MyPagerAdapter adapter = new MyPagerAdapter(viewList); viewPager.setAdapter(adapter); ``` 现在,当用户在ViewPager中左右滑动时,页面将滑动到下一页,实现了左右滑动翻页效果。 当然,你可以在PagerAdapter中添加自己的View,以实现更多的自定义效果

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值