Android使用ViewPager实现图片轮播系列之三:手动滑动 + 左右箭头(1)

简介: Android使用ViewPager实现图片轮播系列之三:手动滑动 + 左右箭头(1)
@BindView(R.id.viewPager)
ViewPager viewPager;
@BindView(R.id.ivPre)
ImageView ivPre;
@BindView(R.id.ivNext)
ImageView ivNext;
private int[] imagePaths = {
R.mipmap.scenery1, R.mipmap.scenery2, R.mipmap.scenery3, R.mipmap.scenery4,
R.mipmap.scenery5
};
ArrayList imageViewList;
private MyPagerAdapter myPagerAdapter;
private int currentPosition;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_vptest3);
ButterKnife.bind(this);
initData();
}
@OnClick({R.id.ivPre, R.id.ivNext})
public void onViewClicked(View view) {
switch (view.getId()) {
case R.id.ivPre:
currentPosition -= 1;
viewPager.setCurrentItem(currentPosition);
break;
case R.id.ivNext:
currentPosition += 1;
viewPager.setCurrentItem(currentPosition);
break;
}
}
private void initData() {
imageViewList = new ArrayList<>();
viewPager.setCurrentItem(0);
setDataToViewPager();
}
/**
• 把数据设置到 ViewPager 上
*/
private void setDataToViewPager() {
// 将图片放到集合中
imageViewList = new ArrayList<>();
for (int imagePath : imagePaths) {
ImageView imageView = new ImageView(this);
imageView.setImageResource(imagePath);
// Glide.with(this).load(imagePath).into(imageView);
imageView.setScaleType(ImageView.ScaleType.FIT_XY);
imageViewList.add(imageView);
}
// 进行适配
myPagerAdapter = new MyPagerAdapter();
if (viewPager != null) {
viewPager.setAdapter(myPagerAdapter);
}
// 第一次进入 不显示前置箭头
ivPre.setVisibility(View.GONE);
viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
currentPosition = position;
// 第一个位置 不显示前置箭头
ivPre.setVisibility(position == 0 ? View.GONE : View.VISIBLE);
// 最后一个位置 不显示后置箭头
ivNext.setVisibility(position == imageViewList.size() - 1 ? View.GONE : View.VISIBLE);
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
}
/**
• 自定义适配器
*/
private class MyPagerAdapter extends PagerAdapter {
@Override
public int getCount() {
相关文章
|
6月前
|
JavaScript Android开发
使用贝叶斯曲线滑动安卓屏幕(autojsPro7)
使用贝叶斯曲线滑动安卓屏幕(autojsPro7)
231 0
|
5月前
|
Android开发 容器
35. 【Android教程】视频页面:ViewPager
35. 【Android教程】视频页面:ViewPager
58 3
|
3月前
|
Android开发
Android使用ViewPager做无限轮播,人为滑动时停止
Android使用ViewPager做无限轮播,人为滑动时停止
70 2
|
4月前
|
Android开发
Android仿高德首页三段式滑动
Android仿高德首页三段式滑动
123 0
|
5月前
|
编解码 Android开发
Android 解决TextView多行滑动与NestedScrollView嵌套滑动冲突的问题
Android 解决TextView多行滑动与NestedScrollView嵌套滑动冲突的问题
80 0
|
5月前
|
XML Android开发 UED
|
6月前
|
Android开发 Kotlin 索引
Android Compose——ScrollableTabRow和LazyColumn同步滑动
Android Compose——ScrollableTabRow和LazyColumn同步滑动
307 0
|
6月前
|
Android开发
[Android]DrawerLayout滑动菜单+NavigationView
[Android]DrawerLayout滑动菜单+NavigationView
76 0
|
Android开发
Android功能总结:仿照Launcher的Workspace实现左右滑动切换
      对于Launcher的桌面滑动大家应该都比较熟悉了,最好的体验应该是可以随着手指的滑动而显示不同位置的桌面, 比一般用ViewFlinger+动画所实现的手势切换页面感觉良好多了~~~~ 分析了一下Launcher中的WorkSpace,里面有太多的代码我们用不上了(拖拽,长按,,,),把里面的冗余代码去掉得到实现滑动切换屏幕所必需的。
860 0
|
1天前
|
XML 存储 Java
探索安卓开发之旅:从新手到专家
【10月更文挑战第35天】在数字化时代,安卓应用的开发成为了一个热门话题。本文旨在通过浅显易懂的语言,带领初学者了解安卓开发的基础知识,同时为有一定经验的开发者提供进阶技巧。我们将一起探讨如何从零开始构建第一个安卓应用,并逐步深入到性能优化和高级功能的实现。无论你是编程新手还是希望提升技能的开发者,这篇文章都将为你提供有价值的指导和灵感。
下一篇
无影云桌面