Android 实现列表倒计时功能

所属分类: 软件编程 / Android 阅读数: 74
收藏 0 赞 0 分享

单个计时器,然后遍历数据 刷新条目;

两种实现方式:1、Handler轮询; 2、子线程睡眠(时间到后 移除列表中的条目会有问题);

代码很简单,没有任何难度,列表使用 RecyclerView+BaseRecyclerViewAdapterHelper实现;

implementation 'androidx.recyclerview:recyclerview:1.1.0'
 implementation 'com.github.CymChad:BaseRecyclerViewAdapterHelper:3.0.1'
 
public class MainActivity extends AppCompatActivity {
 private RecyclerView rv;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 rv = findViewById(R.id.rv);
 initView();
 initData();
 findViewById(R.id.btn).setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View view) {
  quickAdapter.addData(0,new TimeBean("附加商品、离活动结束还剩:" , 99));
  rv.scrollToPosition(0);
  }
 });
 }
 private QuickAdapter quickAdapter;
 private void initView() {
 quickAdapter = new QuickAdapter(R.layout.item);
 rv.setLayoutManager(new LinearLayoutManager(this));
 rv.setAdapter(quickAdapter);
 rv.setItemAnimator(null);
 Countdown();
 }
 private void initData() {
 List<TimeBean> datas = new ArrayList<>();
 for (int i = 1; i < 10; i++) {
  datas.add(new TimeBean("商品" + i + "、离活动结束还剩:", (i + 5) * i));
 }
 quickAdapter.setNewData(datas);
 }
 private class QuickAdapter extends BaseQuickAdapter<TimeBean, BaseViewHolder> {
 public QuickAdapter(int layoutResId) {
  super(layoutResId);
 }
 @Override
 protected void convert(BaseViewHolder vh, TimeBean datas) {
  vh.setText(R.id.tv, datas.getStr() + "");
  vh.setText(R.id.tv2, datas.getTime() + "s");
 }
 }
 private Handler mHandler = new Handler();
 private Runnable runnable;
 private void Countdown() {
 runnable = new Runnable() {
  @Override
  public void run() {
  for (int i = 0; i < quickAdapter.getData().size(); i++) {
   TimeBean bean = quickAdapter.getData().get(i);
   if (bean.getTime() > 0) {
   bean.setTime(bean.getTime() - 1);
   quickAdapter.setData(i, bean);
   } else {
   quickAdapter.remove(i);
   }
  }
  mHandler.postDelayed(runnable, 1000L);
  }
 };
 mHandler.postDelayed(runnable, 1000L);
 }
 private void Countdown2() {
 new Thread(new Runnable() {
  @Override
  public void run() {
  while (true){
   SystemClock.sleep(1000L);
   for (int i = 0; i < quickAdapter.getData().size(); i++) {
   final TimeBean bean = quickAdapter.getData().get(i);
   final int finalI = i;
   if (bean.getTime() > 0) {
    bean.setTime(bean.getTime() - 1);
    runOnUiThread(new Runnable() {
    @Override
    public void run() {
     quickAdapter.setData(finalI, bean); 
    }
    });
   } else {
    // 当时间是0时 移除条目(子线程加睡眠模式移除条目有问题,原因时数据源未更新)
    runOnUiThread(new Runnable() {
    @Override
    public void run() {
     quickAdapter.remove(finalI);
    }
    });
   }
   }
  }
  }
 }).start();
 }
 @Override
 protected void onDestroy() {
 super.onDestroy();
 mHandler.removeCallbacks(runnable);
 mHandler.removeCallbacksAndMessages(null);
 mHandler = null;
 }
public class TimeBean {
 public TimeBean(String str, int time) {
 this.str = str;
 this.time = time;
 }
 private String str;
 private int time;
}

 Get 、 Set方法就不写了;

布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context=".MainActivity">
 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:id="@+id/btn"
 android:text="ADD"
 />
 <androidx.recyclerview.widget.RecyclerView
 android:id="@+id/rv"
 android:layout_width="match_parent"
 android:layout_height="match_parent"></androidx.recyclerview.widget.RecyclerView>
</LinearLayout>
//下面是item
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 xmlns:tools="http://schemas.android.com/tools"
 android:orientation="horizontal"
 android:paddingBottom="@dimen/dp_10"
 android:layout_height="60dp">
 <TextView
 android:background="#33fb1212"
 android:id="@+id/tv"
 tools:text="你好啊"
 android:gravity="center_vertical"
 android:textSize="17dp"
 android:paddingLeft="15dp"
 android:textColor="#333"
 android:layout_width="0dp"
 android:layout_weight="2"
 android:layout_height="match_parent" />
 <TextView
 android:background="#33fb1212"
 android:id="@+id/tv2"
 tools:text="0s"
 android:gravity="center_vertical"
 android:textSize="17dp"
 android:paddingLeft="15dp"
 android:textColor="#333"
 android:layout_width="0dp"
 android:layout_weight="1"
 android:layout_height="match_parent" />
</LinearLayout>
更多精彩内容其他人还在看

Android框架学习之Volley和Glide详解

这篇文章主要给大家介绍了关于Android框架学习之Volley和Glide的相关资料,文中通过示例代码介绍的非常详细,对各位Android开发者们具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Android中Fragment的基本用法示例总结

Fragment是activity的界面中的一部分或一种行为,下面这篇文章主要给大家介绍了关于Android中Fragment的基本用法的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
收藏 0 赞 0 分享

Android.mk引入第三方jar包和so库文件的方法

这篇文章主要介绍了Android.mk引入第三方jar包和so库文件的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Android仿微信录制小视频

这篇文章主要为大家详细介绍了Android仿微信录制小视频,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

android实现一键锁屏和一键卸载的方法实例

这篇文章主要给大家介绍了关于android如何实现一键锁屏和一键卸载的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
收藏 0 赞 0 分享

Android手势密码--设置和校验功能的实现代码

这篇文章主要介绍了Android手势密码--设置和校验功能的实现代码,非常不错,具有一定的参考校验价值,需要的朋友可以参考下
收藏 0 赞 0 分享

Kotlin学习笔记之const val与val

这篇文章主要给大家介绍了关于Kotlin学习笔记之const val与val的相关资料,并给大家介绍了const val和val区别以及Kotlin中var和val的区别,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Android实现调用系统分享功能示例的总结

这篇文章主要介绍了通过Android调用系统分享文本信息、单张图片、多个文件和指定分享到微信、QQ,同时分享图片和文字的功能示例,小编觉得挺不错,一起跟随小编过来看看吧
收藏 0 赞 0 分享

Android自定义view实现输入控件

这篇文章主要为大家详细介绍了Android自定义view实现输入控件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android使用Intent.ACTION_SEND分享图片和文字内容的示例代码

这篇文章主要介绍了Android使用Intent.ACTION_SEND分享图片和文字内容的示例代码的实例代码,具有很好的参考价值,希望对大家有所帮助,一起跟随小编过来看看吧
收藏 0 赞 0 分享
查看更多