android viewpager实现竖直滑动效果

所属分类: 软件编程 / Android 阅读数: 46
收藏 0 赞 0 分享

做过android开发的朋友们,一定知道viewpager是什么,但是viewpager只能水平滑动。现在有的项目引导页也开始使用竖直滑动,这个时候viewpager就不能帮到我们了,怎么办?只有自定义了,今天就简单讲下viewpager竖直滑动的实现,但是这是告诉大家怎么实现,具体肯定不能用于真实项目中,因为还有些细节没处理,只是给大家讲个思路而已!

首先新建一个android项目叫:Customviewpager

我们也知道viewpager也是继承了ViewGroup类的,在这里我们写一个CustomViewPager类也继承了ViewGroup。

其实代码很少,先贴代码然后讲解:

CustomViewPager.java

public class CustomViewPager extends ViewGroup {
 private static final String TAG = CustomViewPager.class.getSimpleName();
 private float startX = 0;
 private GestureDetector detector;
 int a = 30;
 public CustomViewPager(Context context, AttributeSet attrs, int defStyle) {
 super(context, attrs, defStyle);
 }
 
 public CustomViewPager(Context context, AttributeSet attrs) {
 super(context, attrs);
 init(context);
 }
 private void init(Context context) {
 detector = new GestureDetector(context, new GestureDetector.SimpleOnGestureListener(){
 /**
 * distanceX 在屏幕上要移动的距离 而不是坐标
 */
 @Override
 public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
 scrollBy(0, (int)distanceY);
 return true;
 }
 });
 }
 public CustomViewPager(Context context) {
 super(context);
 }
 @Override
 protected void onLayout(boolean changed, int l, int t, int r, int b) {
 for(int i=0;i<getChildCount();i++){
 View childView = getChildAt(i);
// childView.layout(i*getWidth(), 0, (i+1)*getWidth(), getHeight());、//这是水平方向滑动
 childView.layout(0, i*getHeight(), getWidth(), (i+1)*getHeight());//这是竖直方向滑动
 }
 }
 /**
 * 这个默认super.onTouchEvent(event)为false
 */
 @Override
 public boolean onTouchEvent(MotionEvent event) {
 detector.onTouchEvent(event);
 return true;
 }
}

MainActivity.java

public class MainActivity extends ActionBarActivity {
 private CustomViewPager custom_view_pager;
 private int[] ids = {R.drawable.a1,R.drawable.a2,R.drawable.a3,R.drawable.a4,R.drawable.a5,R.drawable.a6};
 private List<ImageView> imageViews;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 DisplayUtil.init(this);
 custom_view_pager = (CustomViewPager) findViewById(R.id.custom_view_pager);
 initData();
 }
 private void initData() {
 imageViews = new ArrayList<>();
 for(int i=0;i<ids.length;i++){
 ImageView imageView = new ImageView(this);
 imageView.setBackgroundResource(ids[i]);
 imageViews.add(imageView);
 custom_view_pager.addView(imageView);
 }
 }
}

这就可以了,再贴下布局文件

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="fill_parent"
 android:layout_height="fill_parent"
 >
 <zhi.more.customviewpager.view.CustomViewPager
  android:id="@+id/custom_view_pager"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
   />
</RelativeLayout>

这里注意下:onTouchEvent()这个方法返回值。返回true和false有啥区别。简单的说下

返回true表示自己处理了这个滑动事件。返回false表示传递给子view,而当前这个父view就不再持有这个滑动事件了,想很好了解这个问题,就设计到view事件传递了,大家可以通过在down,move,up下返回不同的值,打log去分析原理,,在这里就不讲解了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

使用ViewPager实现android软件使用向导功能实现步骤

现在的大部分android软件,都是使用说明,就是第一次使用该软件时,会出现向导,可以左右滑动,然后就进入应用的主界面了,下面我们就实现这个功能
收藏 0 赞 0 分享

android在异步任务中关闭Cursor的代码方法

android在异步任务中如何关闭Cursor?在我们开发应用的时候,很多时候会遇到这种问题,下面我们就看看代码如何实现
收藏 0 赞 0 分享

Android自定义桌面功能代码实现

android自定义桌面其实很简单,看一个例子就明白了
收藏 0 赞 0 分享

android将图片转换存到数据库再从数据库读取转换成图片实现代码

有时候我们想把图片存入到数据库中,尽管这不是一种明智的选择,但有时候还是不得以会用到,下面说说将图片转换成byte[]数组存入到数据库中去,并从数据库中取出来转换成图像显示出来
收藏 0 赞 0 分享

TextView显示系统时间(时钟功能带秒针变化

用System.currentTimeMillis()可以获取系统当前的时间,我们可以开启一个线程,然后通过handler发消息,来实时的更新TextView上显示的系统时间,可以做一个时钟的功能
收藏 0 赞 0 分享

Android用ListView显示SDCard文件列表的小例子

本文简单实现了用ListView显示SDCard文件列表,目录的回退等功能暂不讨论,获取文件列表,files即为所选择目录下的所有文件列表
收藏 0 赞 0 分享

Android拦截外拨电话程序示例

这篇文章主要介绍了Android拦截外拨电话的示例,大家参考使用吧
收藏 0 赞 0 分享

通过Html网页调用本地安卓(android)app程序代码

如何使用html网页和本地app进行传递数据呢?经过研究,发现还是有方法的,总结了一下,大致有一下几种方式
收藏 0 赞 0 分享

android Textview文字监控(Textview使用方法)

以手机号充值为例,当用户输入最后一位数时候,进行汇率的变换,本文就实现类似这样的功能
收藏 0 赞 0 分享

Android ListView长按弹出菜单二种实现方式示例

这篇文章主要介绍了Android ListView长按弹出菜单的方法,大家参考实现
收藏 0 赞 0 分享
查看更多