android - 在 ImaveView 上添加间隔,如图像轮播
问题描述
我正在使用 ImageView 添加一个新的图像轮播。
我的activity_main.xml:
<androidx.viewpager.widget.ViewPager
android:id="@+id/viewPagerId"
android:layout_width="match_parent"
android:layout_height="200dp" />
我的幻灯片 layout_file.xml:
<ImageView
android:id="@+id/layoutimageViewId"
android:layout_width="0dp"
android:layout_height="170dp"
android:scaleType="fitXY"
android:adjustViewBounds="true"
android:layout_marginLeft="8dp"
android:layout_marginRight="8dp"
android:layout_marginTop="8dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:srcCompat="@drawable/ic_launcher_background"/>
我的幻灯片适配器类:
public class SlideHomepageAdapter extends PagerAdapter {
//**Adapter for slideshow in homepage.
Context context;
List<ModalClass> mList;
public SlideHomepageAdapter(Context context, List<ModalClass> mList) {
this.context = context;
this.mList = mList;
}
@Override
public int getCount() {
return mList.size();
}
@Override
public boolean isViewFromObject(@NonNull View view, @NonNull Object object) {
return view==object;
}
@NonNull
@Override
public Object instantiateItem(@NonNull ViewGroup container, int position) {
LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View view = inflater.inflate(R.layout.layout_file, null);
ImageView imageView = view.findViewById(R.id.layoutimageViewId);
imageView.setImageResource(mList.get(position).getImage());
container.addView(view);
return view;
}
@Override
public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
container.removeView((View) object);
}}
我的 MainActivity 类中的代码:
viewPager = findViewById(R.id.viewPagerId);
mList = new ArrayList<>();
mList.add(new ModalClass(R.drawable.banner_eeee, "Title"));
mList.add(new ModalClass(R.drawable.banner_gggg, "Title"));
mList.add(new ModalClass(R.drawable.banner_ffff, "Title"));
mList.add(new ModalClass(R.drawable.banner_gggg, "Title"));
mList.add(new ModalClass(R.drawable.banner_eeee, "Title"));
SlideHomepageAdapter slideHomepageAdapter = new SlideHomepageAdapter(this, mList);
viewPager.setAdapter(slideHomepageAdapter);
如何为自动滑动添加间隔?例如,每张图像之间自动滑动 3 秒?
我总共有 5 张图片。我不认为要在上面添加更多图像。
解决方案
您可以像这样简单地设置一个计时器:
new Timer().scheduleAtFixedRate(task, after, interval);
TASK 是您要调用的方法。之后是初始延迟,例如它在 30 秒后开始。并且间隔可能是显示下一张图像的 3 秒延迟/这样你就可以有一个重复的任务。在您的任务方法中,您可以简单地调用:
private void Task(){
mYourViewPagerName.setCurrentItem(CurrentPosition);
CurrentPosition = Currentposition + 1}
CurrentPosition 将是显示给用户的项目的位置。还有其他方法,例如使用警报管理器来完成您可以研究的重复性任务。
推荐阅读
- git - git filter-repo --refs
不带标签 - node.js - 如何使用 Google-sheet-apis(Node.js) 从 google-sheet 中获取特定行?
- math - 椭圆的一部分的周长
- android - 将微信支付集成到 Android 应用 (Java)
- javascript - 主窗口事件侦听器在 iframe 中不起作用
- templates - Ansible/Jinja2 模板:for 循环运行两次
- reactjs - 提交表单后设置内容为空
- ios - 如何快速从 UIImagePickerController 获取 UIImage 元数据?像“.location”
- laravel - DOMPDF 在服务器中运行良好,但在服务器中出现 http 错误 503
- ios - 在 Scenekit 中添加动画到 SCNNode