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 ...
随机推荐
- JavaScript基础——兼容性、错误处理
JavaScript基础-错误处理Throw.Try.Catch try语句执行可能出错的代码 catch语句处理捕捉到的错误 throw语句创建自定义错误语句 发生的常见的错误类型 可能是语法错误, ...
- x86主机搭建家庭智能路由系统 ---- 设计篇
组件简介 Proxmox: 基于Debian的虚拟化系统,支持OpenVZ和KVM. pfSense: 基于FreeBSD的开源路由系统. FreeNAS: 开源NAS系统. shadowsocks: ...
- Vue学习之路---No.1(分享心得,欢迎批评指正)
首先为了打消大家对Vue.js存在的顾虑,先通过大家所熟知的JQ作为对比. 都知道JQ的语法相对简单.清楚.使用方便.功能齐全: 那么Vue.js呢,同样的,Vue.js与JQ在很多地方都是相同之处, ...
- SEO-站外优化规范
站外优化规范 新站 前期(提高网站曝光率<信息发布平台>) 一. 分类目录信息发布 二. 黄页网信息发布 三. 友链平台信息发布 四. 各大论坛引蜘蛛区信息发布 五. 网址提交 六. 社区 ...
- 009 Java集合浅析4
前面一篇教程中,我们分析了List派别中的最常见也最重要的一个类ArrayList<E>.从我们的分析来看,ArrayList作为动态数组的模拟,使用的是连续内存空间来存储数据,带来了可随 ...
- 队列工厂之RedisMQ
本次和大家分享的是RedisMQ队列的用法,前两篇文章队列工厂之(MSMQ)和队列工厂之RabbitMQ分别简单介绍对应队列环境的搭建和常用方法的使用,加上本篇分享的RedisMQ那么就完成了咋们队列 ...
- dreamweaver破解版下载地址
dreamweaver CC 2015可以在可视化环境中设计的你网页,非常方便高效完成网页设计.Adobe Dreamweaver CC 2015支持CSS编辑器.和jQuery库代码自动完成功能等等 ...
- JS Math.round()方法原理
请先测试代码: <!doctype html> <html lang="en"> <head> <meta charset="U ...
- 使用moment.js轻松管理日期和时间
大家在前端Javascript开发中会遇到处理日期时间的问题,经常会拿来一大堆处理函数才能完成一个简单的日期时间显示效果.今天我给大家介绍一个轻量级的Javascript日期处理类库:moment.j ...
- css的存在方式和选择器
css的存在方式 元素内联 页面嵌入 外部引入 元素内联 直接在html的标签中定义样式,类似于: <div style="属性1;属性2;属性3"><div&g ...