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 ...
随机推荐
- 视频直播SDK-ios版
IOS视频直播接入说明 一.名词解释 分辨率:用于计算机视频处理的图像,以水平和垂直方向上所能显示的像素数来表示分辨率.常见视频分辨率的有1080P即1920x1080,720P即1080x720,6 ...
- 纯CSS3之五子棋(黑白棋)画法
无聊想用JS写个五子棋玩玩,这边先用CSS3画出了五子棋,感觉挺惊艳的.发上来看看 PS:第一次发博文T-T 此为个人原创. 不多说上图: 代码如下: <!DOCTYPE html> & ...
- select函数的用法
首先介绍阻塞方式与非阻塞方式: 阻塞方式(block),就是进程或是线程执行到这些函数时必须等待某个事件的发生.如果事件没有发生,进程或线程就被阻塞,函数不能立即返回. 非阻塞方式(non-block ...
- 游戏UI框架设计(四) : 模态窗体管理
游戏UI框架设计(四) --模态窗体管理 我们在开发UI窗体时,对于"弹出窗体"往往因为需要玩家优先处理弹出小窗体,则要求玩家不能(无法)点击"父窗体",这种窗 ...
- 最强 IDE Visual Studio 2017 正式版发布
Visual Studio 2017 正式版发布,该版本不仅添加了实时单元测试.实时架构依赖关系验证等新特性,还对许多实用功能进行了改进,如代码导航.IntelliSense.重构.代码修复和调试等等 ...
- 徒手用Java来写个Web服务器和框架吧<第一章:NIO篇>
因为有个不会存在大量连接的小的Web服务器需求,不至于用上重量级服务器,于是自己动手写一个服务器. 同时也提供了一个简单的Web框架.能够简单的使用了. 大体的需求包括 能够处理HTTP协议. 能够提 ...
- Nginx+IIS+Redis 处理Session共享问题 2
接下来主要说下利用nginx来测试 两台Windows server 1.10.120.131.210 - 端口84部署demo 2.10.120.131.211 - 端口84部署demo ngi ...
- (七)javascript中的数组
一. 一维数组 1.1 声明数组 var 数组名=new Array(数组大小); 1.2 添加元素 <script> var a=new Array(3); a[0]="张三 ...
- Python 之 json 模块
引言 对于做web开发的人来说,json文本必须要熟知与熟练使用的.大部分网站的API接口调用返回的数据,就是json格式的.如果看json对象所包含的内容,相信对熟悉Python的人开说,很快就能把 ...
- 我的Node.js学习历程
学习一门技术,每个人都有每个人的方法.我的方法很简单,做项目. 基本概念 在搭建一个node网站之前,还是要掌握一些基本的概念的,这里列举一下,具体的内容大家自己到网上去查: npm bower ex ...