温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么在android中使用viewpager实现一个竖直滑动效果

发布时间:2021-05-14 17:43:36 来源:亿速云 阅读:197 作者:Leah 栏目:移动开发

这期内容当中小编将会给大家带来有关怎么在android中使用viewpager实现一个竖直滑动效果,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

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>

上述就是小编为大家分享的怎么在android中使用viewpager实现一个竖直滑动效果了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI