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)
232 0
|
5月前
|
Android开发 容器
35. 【Android教程】视频页面:ViewPager
35. 【Android教程】视频页面:ViewPager
58 3
|
3月前
|
Android开发
Android使用ViewPager做无限轮播,人为滑动时停止
Android使用ViewPager做无限轮播,人为滑动时停止
75 2
|
4月前
|
Android开发
Android仿高德首页三段式滑动
Android仿高德首页三段式滑动
134 0
|
5月前
|
编解码 Android开发
Android 解决TextView多行滑动与NestedScrollView嵌套滑动冲突的问题
Android 解决TextView多行滑动与NestedScrollView嵌套滑动冲突的问题
89 0
|
5月前
|
XML Android开发 UED
|
6月前
|
Android开发 Kotlin 索引
Android Compose——ScrollableTabRow和LazyColumn同步滑动
Android Compose——ScrollableTabRow和LazyColumn同步滑动
311 0
|
6月前
|
Android开发
[Android]DrawerLayout滑动菜单+NavigationView
[Android]DrawerLayout滑动菜单+NavigationView
76 0
|
3天前
|
搜索推荐 Android开发 开发者
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。
|
5天前
|
Android开发 Swift iOS开发
探索安卓与iOS开发的差异和挑战
【10月更文挑战第37天】在移动应用开发的广阔舞台上,安卓和iOS这两大操作系统扮演着主角。它们各自拥有独特的特性、优势以及面临的开发挑战。本文将深入探讨这两个平台在开发过程中的主要差异,从编程语言到用户界面设计,再到市场分布的不同影响,旨在为开发者提供一个全面的视角,帮助他们更好地理解并应对在不同平台上进行应用开发时可能遇到的难题和机遇。