博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android ViewPager多页面滑动切换以及动画效果
阅读量:5898 次
发布时间:2019-06-19

本文共 4748 字,大约阅读时间需要 15 分钟。

hot3.png

一、首先,我们来看一下效果图,这是新浪微博的Tab滑动效果。我们可以手势滑动,也可以点击上面的头标进行切换。与此同方式, 白色横条会移动到相应的页卡头标下。这是一个动画效果,白条是缓慢滑动过去的。好了,接下来我们就来实现它。 二、在开始前,我们先要认识一个控件,ViewPager。它是google SDk中自带的一个附加包的一个类,可以用来实现屏幕间的切换。 这个附加包是android-support-v4.jar,在最后的源码中会提供给大家,在libs文件夹中。当然你也可以自己从网上搜索最新的版本。 找到它后,我们需要在项目中添加 三、我们先做界面, 界面设计很简单,第一行三个头标,第二行动画图片,第三行页卡内容展示。 复制代码

复制代码 我们要展示三个页卡,所以还需要三个页卡内容的界面设计,这里我们只设置了背景颜色,能起到区别作用即可。 复制代码

复制代码 四、代码部分要进行初始化的工作 (1) 先来变量的定义 复制代码    private ViewPager mPager;//页卡内容    private List

listViews; // Tab页面列表    private ImageView cursor;// 动画图片    private TextView t1, t2, t3;// 页卡头标    private int offset = 0;// 动画图片偏移量    private int currIndex = 0;// 当前页卡编号    private int bmpW;// 动画图片宽度 复制代码 (2) 初始化头标 复制代码 1     /** 2      * 初始化头标 3 */ 4     private void InitTextView() { 5         t1 = (TextView) findViewById(R.id.text1); 6         t2 = (TextView) findViewById(R.id.text2); 7         t3 = (TextView) findViewById(R.id.text3); 8 9         t1.setOnClickListener(new MyOnClickListener(0)); 10         t2.setOnClickListener(new MyOnClickListener(1)); 11         t3.setOnClickListener(new MyOnClickListener(2)); 12     } 复制代码 复制代码 1     /** 2      * 头标点击监听 3 */ 4     public class MyOnClickListener implements View.OnClickListener { 5         private int index = 0; 6 7         public MyOnClickListener(int i) { 8             index = i; 9         } 10 11         @Override 12         public void onClick(View v) { 13             mPager.setCurrentItem(index); 14         } 15     }; 复制代码 相信大家看后都没什么问题,点击第几个,就展示第几个页卡内容。 (3) 初始化页卡内容区 复制代码 1     /** 2      * 初始化ViewPager 3 */ 4     private void InitViewPager() { 5         mPager = (ViewPager) findViewById(R.id.vPager); 6         listViews = new ArrayList(); 7         LayoutInflater mInflater = getLayoutInflater(); 8         listViews.add(mInflater.inflate(R.layout.lay1, null)); 9         listViews.add(mInflater.inflate(R.layout.lay2, null)); 10         listViews.add(mInflater.inflate(R.layout.lay3, null)); 11         mPager.setAdapter(new MyPagerAdapter(listViews)); 12         mPager.setCurrentItem(0); 13         mPager.setOnPageChangeListener(new MyOnPageChangeListener()); 14     } 复制代码 我们将三个页卡界面装入其中,默认显示第一个页卡。这里我们还需要实现一个适配器。 复制代码 1 /** 2      * ViewPager适配器 3 */ 4     public class MyPagerAdapter extends PagerAdapter { 5         public ListmListViews; 6 7         public MyPagerAdapter(ListmListViews) { 8             this.mListViews = mListViews; 9         } 10 11         @Override 12         public void destroyItem(View arg0, int arg1, Object arg2) { 13             ((ViewPager) arg0).removeView(mListViews.get(arg1)); 14         } 15 16         @Override 17         public void finishUpdate(View arg0) { 18         } 19 20         @Override 21         public int getCount() { 22             return mListViews.size(); 23         } 24 25         @Override 26         public Object instantiateItem(View arg0, int arg1) { 27             ((ViewPager) arg0).addView(mListViews.get(arg1), 0); 28             return mListViews.get(arg1); 29         } 30 31         @Override 32         public boolean isViewFromObject(View arg0, Object arg1) { 33             return arg0 == (arg1); 34         } 35 36         @Override 37         public void restoreState(Parcelable arg0, ClassLoader arg1) { 38         } 39 40         @Override 41         public Parcelable saveState() { 42             return null; 43         } 44 45         @Override 46         public void startUpdate(View arg0) { 47         } 48     } 复制代码 这里我们实现了各页卡的装入和卸载 (3) 初始化动画 复制代码 1     /** 2      * 初始化动画 3 */ 4     private void InitImageView() { 5         cursor = (ImageView) findViewById(R.id.cursor); 6         bmpW = BitmapFactory.decodeResource(getResources(), R.drawable.a) 7                 .getWidth();// 获取图片宽度 8         DisplayMetrics dm = new DisplayMetrics(); 9         getWindowManager().getDefaultDisplay().getMetrics(dm); 10         int screenW = dm.widthPixels;// 获取分辨率宽度 11         offset = (screenW / 3 - bmpW) / 2;// 计算偏移量 12         Matrix matrix = new Matrix(); 13         matrix.postTranslate(offset, 0); 14         cursor.setImageMatrix(matrix);// 设置动画初始位置 15     } 复制代码 根据屏幕的分辨率和图片的宽度计算动画移动的偏移量 实现页卡切换监听 复制代码 1 /** 2      * 页卡切换监听 3 */ 4     public class MyOnPageChangeListener implements OnPageChangeListener { 5 6         int one = offset * 2 + bmpW;// 页卡1 -> 页卡2 偏移量 7         int two = one * 2;// 页卡1 -> 页卡3 偏移量 8 9         @Override 10         public void onPageSelected(int arg0) { 11             Animation animation = null; 12             switch (arg0) { 13             case 0: 14                 if (currIndex == 1) { 15                     animation = new TranslateAnimation(one, 0, 0, 0); 16                 } else if (currIndex == 2) { 17                     animation = new TranslateAnimation(two, 0, 0, 0); 18                 } 19                 break; 20             case 1: 21                 if (currIndex == 0) { 22                     animation = new TranslateAnimation(offset, one, 0, 0); 23                 } else if (currIndex == 2) { 24                     animation = new TranslateAnimation(two, one, 0, 0); 25                 } 26                 break; 27             case 2: 28                 if (currIndex == 0) { 29                     animation = new TranslateAnimation(offset, two, 0, 0); 30                 } else if (currIndex == 1) { 31                     animation = new TranslateAnimation(one, two, 0, 0); 32                 } 33                 break; 34             } 35             currIndex = arg0; 36             animation.setFillAfter(true);// True:图片停在动画结束位置 37             animation.setDuration(300); 38             cursor.startAnimation(animation); 39         } 40 41         @Override 42         public void onPageScrolled(int arg0, float arg1, int arg2) { 43         } 44 45         @Override 46         public void onPageScrollStateChanged(int arg0) { 47         } 48     } 复制代码 五、打完收工,快来看看自己的劳动成果吧 源码分享:http://115.com/file/dpi0unyg

转载于:https://my.oschina.net/u/1177694/blog/497943

你可能感兴趣的文章
AMD与天津海光合资生产x86服务器芯片
查看>>
提升CRM实施成功率
查看>>
雅虎开源了TensorFlowOnSpark
查看>>
ERP实施应立足于两点
查看>>
网络安全保险在欧洲更受欢迎
查看>>
三星未及时提供系统更新 荷兰消协把它告上法庭
查看>>
如何处理IT事件管理以避免混乱
查看>>
投资半导体产业不能只想赚快钱
查看>>
物联网确保消费者隐私安全 才能起飞
查看>>
iPhone升級iOS 10变砖 可用iTunes恢复
查看>>
揭秘使用免费WiFi的真实代价
查看>>
思科:网络可见化仍然是安全的数字化转型改造的关键
查看>>
CloudCC CRM梳理CRM软件已经实现的发展
查看>>
《交互式程序设计 第2版》一2.3.2 数组
查看>>
移动互联网金融app 存在信息安全问题
查看>>
Android 开发中使用 SQLite 数据库
查看>>
Android后门GhostCtrl,完美控制设备任意权限并窃取用户数据
查看>>
IBM郭继军:机器学习配合行业经验将帮助企业成就未来
查看>>
Rambus9000万美元收购Inphi存储器互联业务
查看>>
3GPP一反常态提前制定NB-IoT标准有何深意?
查看>>