How to achieve horizontal scrolling images on Android?
To achieve horizontal scrolling images in Android, you can use either RecyclerView or ViewPager.
- Utilize RecyclerView:
To begin with, add a RecyclerView component to your layout file.
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" />
Then, in your Activity or Fragment, locate the RecyclerView and configure the LayoutManager and Adapter.
RecyclerView recyclerView = findViewById(R.id.recyclerView);
recyclerView.setLayoutManager(new LinearLayoutManager(this, LinearLayoutManager.HORIZONTAL, false));
recyclerView.setAdapter(new ImageAdapter(imageList));
ImageAdapter is a custom implementation of RecyclerView.Adapter used for binding data and creating views.
public class ImageAdapter extends RecyclerView.Adapter<ImageAdapter.ImageViewHolder> {
private List<Drawable> imageList;
public ImageAdapter(List<Drawable> imageList) {
this.imageList = imageList;
}
@NonNull
@Override
public ImageViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_image, parent, false);
return new ImageViewHolder(view);
}
@Override
public void onBindViewHolder(@NonNull ImageViewHolder holder, int position) {
Drawable image = imageList.get(position);
holder.imageView.setImageDrawable(image);
}
@Override
public int getItemCount() {
return imageList.size();
}
public static class ImageViewHolder extends RecyclerView.ViewHolder {
ImageView imageView;
public ImageViewHolder(@NonNull View itemView) {
super(itemView);
imageView = itemView.findViewById(R.id.imageView);
}
}
}
item_image is a custom layout file used to display the view of a single image.
- Utilize ViewPager:
Firstly, add a ViewPager component to your layout file.
<androidx.viewpager.widget.ViewPager
android:id="@+id/viewPager"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
Next, in your Activity or Fragment, locate the ViewPager and set the PagerAdapter.
ViewPager viewPager = findViewById(R.id.viewPager);
viewPager.setAdapter(new ImagePagerAdapter(imageList));
The ImagePagerAdapter is a custom implementation class of PagerAdapter used to bind data and create views.
public class ImagePagerAdapter extends PagerAdapter {
private List<Drawable> imageList;
public ImagePagerAdapter(List<Drawable> imageList) {
this.imageList = imageList;
}
@Override
public int getCount() {
return imageList.size();
}
@Override
public boolean isViewFromObject(@NonNull View view, @NonNull Object object) {
return view == object;
}
@NonNull
@Override
public Object instantiateItem(@NonNull ViewGroup container, int position) {
ImageView imageView = new ImageView(container.getContext());
imageView.setImageDrawable(imageList.get(position));
container.addView(imageView);
return imageView;
}
@Override
public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
container.removeView((View) object);
}
}
This way, horizontal scrolling images can be implemented in Android.