栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

Android使用Recyclerview实现图片水平自动循环滚动效果

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Android使用Recyclerview实现图片水平自动循环滚动效果

简介:

本篇博客主要介绍的是如何使用RecyclerView实现图片水平方向自动循环(跑马灯效果)

效果图:

思路:

1.准备m张图片

1.使用Recyclerview实现,返回无数个(实际Interge.MAXVALUE)item,第n个item显示第n%m张图片

3.使用recyclerview.scrollBy  每个一段时间水平滚动一段距离

4.通过layoutManager.findFirstVisibleItemPosition()获取当前显示的第一个View是第几个item,上面的ImageView显示对应de图片

实现代码:

XML文件

1.activity布局文件activity_recy.xml  



 

  




2.适配器布局item_horizon.xml



 


Activity

public class HorizontalActivity extends AppCompatActivity implements RecyAdapter.onItemClickListener {
 private String TAG="HorizontalActivity";

 @BindView(R.id.img)
 ImageView img;
 @BindView(R.id.recyclerview)
 RecyclerView recyclerview;


 private Integer[] mImgIds = {R.drawable.p1, R.drawable.p2, R.drawable.p3, R.drawable.p4, R.drawable.p5,
   R.drawable.pic1, R.drawable.pic5, R.drawable.pic6};
 private List datas;
 private RecyAdapter recyAdapter;
 private Handler mHandler=new Handler();
 private LinearLayoutManager layoutManager;

 private int oldItem=0;


 @Override
 protected void onCreate(@Nullable Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_recy);
  ButterKnife.bind(this);
  initData();
  initRecy();
  img.setImageResource(datas.get(0));
  recyAdapter.setonItemClickListener(this);
 }


 Runnable scrollRunnable=new Runnable() {
  @Override
  public void run() {
   recyclerview.scrollBy(3,0);

//   int firstItem = layoutManager.findFirstVisibleItemPosition();
   int firstItem=layoutManager.findFirstVisibleItemPosition();
   if(firstItem!=oldItem&&firstItem>0){
    oldItem=firstItem;
    img.setImageResource(datas.get(oldItem%datas.size()));
   }

   Log.e(TAG, "run: firstItem:"+firstItem );


   mHandler.postDelayed(scrollRunnable,10);
  }
 };

 private void initRecy() {
  recyAdapter=new RecyAdapter(this,datas);

  layoutManager = new LinearLayoutManager(this);
  layoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
  recyclerview.setLayoutManager(layoutManager);
  recyclerview.setAdapter(recyAdapter);
 }

 private void initData() {
  datas=new ArrayList<>();
  for (int i = 0; i 

适配器RecyAdapter

public class RecyAdapter extends RecyclerView.Adapter implements View.onClickListener {

 private Context context;
 private List datas;
 private onItemClickListener onItemClickListener;

 public RecyAdapter(Context context, List datas) {
  this.context = context;
  this.datas = datas;
 }

 @Override
 public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
  View view = LayoutInflater.from(context).inflate(R.layout.item_horizontal, parent, false);
  ViewHolder vh=new ViewHolder(view);
  view.setonClickListener(this);
  return vh;
 }


 @Override
 public void onBindViewHolder(ViewHolder holder, int position) {
  int newPos=position%datas.size();

  holder.img.setImageResource(datas.get(newPos));

  holder.itemView.setTag(position);


 }

 @Override
 public int getItemCount() {
  return Integer.MAX_VALUE;
 }

 @Override
 public void onClick(View view) {
  if(onItemClickListener!=null){
   onItemClickListener.onItemClick(view, (Integer) view.getTag());
  }
 }


 class ViewHolder extends RecyclerView.ViewHolder {
   ImageView img;
  public ViewHolder(View itemView) {
   super(itemView);
   img=itemView.findViewById(R.id.img);
  }
 }

 public void setonItemClickListener(onItemClickListener listener){
  this.onItemClickListener=listener;

 }
 interface OnItemClickListener{
  void onItemClick(View view,int tag);
 }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/158230.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号