listview展示倒计时
- public class MainActivity extends Activity {
- /**截至时间数据源**/
- private List<Date> listData;
- /**当前时间**/
- private long time_Current;
- /**ListView控件**/
- private ListView listView;
- /**适配器**/
- private MyCountAdapter myCountAdapter;
- //这里很重要,使用Handler的延时效果,每隔一秒刷新一下适配器,以此产生倒计时效果
- private Handler handler_timeCurrent = new Handler(){
- @Override
- public void handleMessage(Message msg) {
- time_Current = time_Current+1000;
- myCountAdapter.notifyDataSetChanged();
- handler_timeCurrent.sendEmptyMessageDelayed(0,1000);
- }
- };
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- listView = (ListView) findViewById(R.id.listView);
- //模拟活动截至时间数据
- listData = new ArrayList<Date>();
- listData.add(new Date(2016,3,16,8,20,31));
- listData.add(new Date(2016,3,16,8,21,20));
- listData.add(new Date(2016,3,16,13,21,22));
- listData.add(new Date(2016,3,16,8,21,20));
- listData.add(new Date(2016,3,16,8,21,23));
- listData.add(new Date(2016,3,16,14,21,20));
- listData.add(new Date(2016,3,16,8,21,23));
- listData.add(new Date(2016,3,16,8,21,24));
- listData.add(new Date(2016,3,16,8,21,20));
- listData.add(new Date(2016,3,16,8,22,25));
- listData.add(new Date(2016,3,16,8,23,20));
- listData.add(new Date(2016,3,16,8,24,26));
- listData.add(new Date(2016,3,16,8,25,20));
- listData.add(new Date(2016,3,16,8,24,25));
- listData.add(new Date(2016,3,16,8,25,20));
- listData.add(new Date(2016,3,16,8,24,26));
- listData.add(new Date(2016,3,16,11,20,20));
- listData.add(new Date(2016,3,16,14,40,20));
- listData.add(new Date(2016,3,16,8,44,20));
- listData.add(new Date(2016,3,16,10,20,20));
- //模拟当前服务器时间数据
- Date date = new Date(2016,3,16,8,20,20);
- time_Current = date.getTime();
- myCountAdapter = new MyCountAdapter();
- listView.setAdapter(myCountAdapter);
- handler_timeCurrent.sendEmptyMessageDelayed(0,1000);
- }
- //防止当前Activity结束以后, handler依然继续循环浪费资源
- @Override
- protected void onDestroy() {
- handler_timeCurrent.removeCallbacksAndMessages(null);
- super.onDestroy();
- }
- public class MyCountAdapter extends BaseAdapter{
- @Override
- public int getCount() {
- return listData.size();
- }
- @Override
- public Object getItem(int position) {
- return listData.get(position);
- }
- @Override
- public long getItemId(int position) {
- return position;
- }
- @Override
- public View getView(int position, View convertView, ViewGroup parent) {
- ViewHolder holder = null;
- if(convertView == null){
- convertView = View.inflate(MainActivity.this, R.layout.item_adapter_listview, null);
- holder = new ViewHolder();
- holder.tv_hour = (TextView) convertView.findViewById(R.id.tv_hour);
- holder.tv_minute = (TextView) convertView.findViewById(R.id.tv_minute);
- holder.tv_second = (TextView) convertView.findViewById(R.id.tv_second);
- convertView.setTag(holder);
- }else{
- holder = (ViewHolder) convertView.getTag();
- }
- Date date_finish = listData.get(position);
- updateTextView( date_finish.getTime()-time_Current, holder);
- return convertView;
- }
- /****
- * 刷新倒计时控件
- */
- public void updateTextView(long times_remain,ViewHolder hoder) {
- if (times_remain <= 0) {
- hoder.tv_hour.setText("00");
- hoder.tv_minute.setText("00");
- hoder.tv_second.setText("00");
- return;
- }
- //秒钟
- long time_second = (times_remain/1000)%60;
- String str_second;
- if (time_second < 10) {
- str_second = "0" + time_second;
- } else {
- str_second = "" + time_second;
- }
- long time_temp = ((times_remain / 1000) - time_second) / 60;
- //分钟
- long time_minute = time_temp % 60;
- String str_minute;
- if (time_minute < 10) {
- str_minute = "0" + time_minute;
- } else {
- str_minute = "" + time_minute;
- }
- time_temp = (time_temp - time_minute) / 60;
- //小时
- long time_hour = time_temp;
- String str_hour;
- if (time_hour < 10) {
- str_hour = "0" + time_hour;
- } else {
- str_hour = "" + time_hour;
- }
- hoder.tv_hour.setText(str_hour);
- hoder.tv_minute.setText(str_minute);
- hoder.tv_second.setText(str_second);
- }
- private class ViewHolder{
- /** 小时 **/
- private TextView tv_hour;
- /** 分钟 **/
- private TextView tv_minute;
- /** 秒 **/
- private TextView tv_second;
- }
- }
- }
listview展示倒计时的更多相关文章
- Xamarin.Android 调用Web Api(通过ListView展示远程获取的数据)
xamarin.android如何调用sqlserver 数据库呢(或者其他的),很多新手都会有这个疑问.xamarin.android调用远程数据主要有两种方式: 在Android中保存数据或调用数 ...
- 解决viewpager+多个fragment+listview,listview展示内容高度不自适应出现多余空白问题
一.重写viewpager import android.content.Context; import android.support.v4.view.ViewPager; import andro ...
- android listview展示图片
最近学习android开发,感触颇多,和网站开发对比,还是有很大的差距,在这里记录一下. android listview展示图片 在网站开发上,展示图片非常简单,一个HTML img标签就搞定,加上 ...
- Android中Listview展示及其优化好处
展示效果: 中间的item条目是可以上下滑动的. 代码实现: @Override public View getView(int position, View convertView, ViewGro ...
- WPF ListView展示层叠信息
通常我们在ListView中展示一列同类数据,例如城市名称.不过可以对ListView的DataTemplate稍作修改,让其显示层叠信息.例如:需要在ListView中显示省份和省份对应的城市名称. ...
- C# listview展示表格格式
有时候我们需要展示表格格式的数据,首先想到的是用datagridview控件,比如更改datagridview某一行的数据,这样操作起来就比较麻烦,而listview属于轻量级,刷新和更改相对来说效率 ...
- xamarin.forms之实现ListView列表倒计时
做商城类APP时经常会遇到抢购倒计时的功能,之前做小区宝iOS的时候也有类似的功能,想着参考iOS做的思路,自定义一个Cell,在Cell中每秒刷新一下控件的文本值,但使用xamarin.forms实 ...
- ListView展示不同布局需要注意的地方
尊重劳动成果,转载请标明出处:http://www.cnblogs.com/tangZH/p/8419010.html 我们在项目中经常需在一个listview中展示不一样的布局,我们可以在adapt ...
- Wpf ListView展示风格
ListView数据绑定控件,通常是竖列展示,也可以通过改变ListView的布局来改变它的展示方式 如图展示: 主要需用修改的样式如下: <!--GridView Header样式 去除Gri ...
随机推荐
- iOS基础之顺传逆传传值(delegate、block)
写给iOS新手的福利! 在项目中经常会用到传值,根据传值的方向分为顺传(从根控制器到子控制器)和逆传(从子控制器到根控制器).在这里写了个Demo简单演示了效果,创建了两个控制器: 一个为根控制器,一 ...
- javascript作用域和闭包之我见
javascript作用域和闭包之我见 看了<你不知道的JavaScript(上卷)>的第一部分--作用域和闭包,感受颇深,遂写一篇读书笔记加深印象.路过的大牛欢迎指点,对这方面不懂的同学 ...
- Maven的声明周期(Lifecycle )和命令(Phase)
生命周期(Lifecycle ) Maven有三套相互独立的生命周期(Lifecycle ): Clean Lifecycle:做一些清理工作: Default Lifecycle:构建的核心部分.编 ...
- 使用Nexus搭建Maven代理仓库
使用Maven构建和管理项目是非常享受的一件事,我们可以从Maven中央仓库下载所需要的构件(artifact),但实际开发中由于种种原因我们需要在架设一个Maven本地代理仓库,如:不方便访问公网. ...
- 【RecyclerView与Glide】实现一个Android电子书阅读APP
http://www.cnblogs.com/xfangs/ 欢迎在本文下方评论,小方很需要鼓励支持!!! 本系列教程仅供学习交流 小说阅读器最终实现效果见 第一篇博文 前言 在上一篇文章中,我们实现 ...
- 每天一个Linux命令 9
Linux常用命令: 压缩命令:gzip 解压命令:gunzip 压缩命令:zip 解压命令:unzip 压缩命令:bzip2 解压命令:bunzip2 压缩打包命令:tar 1.命令名称:gzi ...
- 轻松理解JavaScript之AJAX
摘要 AJAX技术是网页构建的必备技能之一,本文希望能帮助大家轻松的学习这项技术 一.什么是ajax? ajax(异步javascript xml) 能够刷新局部网页数据而不是重新加载整个网页. 二. ...
- 在SSRS的每一页重复显示table header
现在在做一个关于SSRS报表展示的项目,但是我困顿在如何在table的每一页让table header重复显示.因为我在table属性中勾选了"Report header columns o ...
- 第一章Python起步
1.1搭建编程环境 编程环境的正确搭建很重要,一定要参考先搭配好环境变量,不然用着会很麻烦,在这里推荐使用工具pycharm,亿图图示画流程图,一定要正确安装,搭配好环境变量,后面要添加很多模块,前期 ...
- Java中反射与常用方法
java通常是先有类再有对象,有对象我就可以调用方法或者属性. 反射其实是通过Class对象来调用类里面的方法.通过反射可以调用私有方法和私有属性.大部分框架都是运用反射原理. 如何获得Class ...