Android列表控件选项中添加进度框ProgressBar实现 推荐
2012-09-17 22:41
627 查看
今天有时间就学习了下在ListView、GridView列表项中清加ProgressBar,小马用最简单的代码实现可以通用的功能,人人都能看懂,哈哈,直接说下,如果你的适配器getView方法返回的View是一个自定义控件的话,有点不好实现哦,不过可以用两个控件之间Visible 、Invisible来切换实现今天的效果,下面的例子是主类、适配器、异步下载类等的都写在一个类里面了,为的是发的博文里一次性看的话方便,如果大家觉得结构不清楚的话根据自身需求自行抽取下,今天的DEMO只是个简单的思路,其它控件列表项中添加进度框大家也可以用如下的方法实现,老规矩,先看效果,再看代码:
(截图有点失真,但无防)
一:效果图如下
二:效果看完了,看下实现的路是怎样的,吼吼:核心代码如下:
package com.example.listviewitemprogress; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; import android.app.Activity; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.os.AsyncTask; import android.os.Bundle; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.Button; import android.widget.ImageView; import android.widget.ListView; import android.widget.ProgressBar; import android.widget.TextView; /** * @author 小马果 * ListView列表项中添加ProgressBar */ public class MainActivity extends Activity { private ListView mListView = null ; private static final String imgUrl = "http://www.qq510.net/uploads/allimg/100613/2_100613171230_5.jpg"; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); init(); } private void init(){ mListView = (ListView)findViewById(R.id.listview); mListView.setAdapter(new MyListViewAdapter(this)); } private class MyListViewAdapter extends BaseAdapter{ private LayoutInflater inflater = null; public MyListViewAdapter(Context con){ inflater = (LayoutInflater)con.getSystemService(LAYOUT_INFLATER_SERVICE); } @Override public int getCount() { // TODO Auto-generated method stub return Integer.MAX_VALUE; } @Override public Object getItem(int arg0) { // TODO Auto-generated method stub return arg0; } @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { // TODO Auto-generated method stub ViewHolder mHolder = new ViewHolder() ; if(convertView == null){ convertView = inflater.inflate(R.layout.list_item, null); mHolder.iv = (ImageView)(convertView.findViewById(R.id.iv)); mHolder.mBtn = (Button)(convertView.findViewById(R.id.button)); mHolder.pb = (ProgressBar)(convertView.findViewById(R.id.progressBar1)); mHolder.tv = (TextView)(convertView.findViewById(R.id.textView1)); convertView.setTag(mHolder); }else{ mHolder = (ViewHolder)convertView.getTag(); } new AsyncTask<ViewHolder, Void, Bitmap>() { private ViewHolder v; @Override protected Bitmap doInBackground(ViewHolder... params) { v = params[0]; return BitmapFactory.decodeStream(getStreamFromURL(imgUrl)); } @Override protected void onPostExecute(Bitmap result) { super.onPostExecute(result); v.pb.setVisibility(View.GONE); v.mBtn.setVisibility(View.VISIBLE); v.iv.setImageBitmap(result); } }.execute(mHolder); return convertView; } } static class ViewHolder{ ImageView iv = null ; Button mBtn = null ; ProgressBar pb = null ; TextView tv = null ; } static String length; public static InputStream getStreamFromURL(String imageURL) { InputStream in=null; try { URL url=new URL(imageURL); HttpURLConnection connection=(HttpURLConnection) url.openConnection(); // connection.setRequestProperty("Connection", "Keep-Alive");//维持长连接 connection.setConnectTimeout(6* 1000);//设置连接超时 if (connection.getResponseCode() != 200) throw new RuntimeException("请求失败"); length = connection.getHeaderField("Content-Length"); in=connection.getInputStream(); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } return in; } }
三:再来看下两个布局吧(为方便查,小马就放一起了:)
主布局文件: <RelativeLayout 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" > <ListView android:id="@+id/listview" android:layout_width="fill_parent" android:layout_height="fill_parent" android:drawSelectorOnTop="false" android:choiceMode="none" android:focusable="false" android:scrollingCache="false" android:fadingEdge="none" android:focusableInTouchMode="false" android:clickable="false" android:dividerHeight="0.5dip" /> </RelativeLayout> ListView列表控件Item布局: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="110dp" android:background="#00ffeeaa" > <ImageView android:id="@+id/iv" android:layout_width="110dp" android:background="@drawable/ic_action_search" android:layout_height="110dp" android:contentDescription="@string/hello_world"/> <Button android:id="@+id/button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_centerVertical="true" android:text="@string/xiaomaguo"/> <ProgressBar android:id="@+id/progressBar1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_centerVertical="true" android:layout_alignTop="@+id/button" android:layout_marginLeft="29dp" /> <TextView android:id="@+id/textView1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBaseline="@+id/button" android:layout_alignBottom="@+id/button" android:layout_centerVertical="true" android:layout_toLeftOf="@+id/button" android:text="@string/cool" /> </RelativeLayout>
最后,由于选项中使用的图片是小马从网上异步下载加载的,所以得开下联网权限,大家别忘了加就行了,如下:
<uses-permission android:name="android.permission.INTERNET"/>
怎么样?简单吧,刚开始的时间没思路,后来玩花辨的时候想到了,美丽说瀑布流实现的原理跟这个差不多,上面这个只是个小的DEMO,给大家提供个思路,GridView等其它控件,大家可以直接参照上面这个代码来写,吼吼,小DEMO源码已经加在附件中,觉得有用就下下来瞅瞅吧,加油,每天进步一点点,祝 :Happy ! O_O
附件:http://down.51cto.com/data/2361454
相关文章推荐
- Android列表控件选项中添加进度框ProgressBar实现
- android开发实现列表控件滚动位置精确保存和恢复的方法(推荐)
- Android开发中给EditText控件添加TextWatcher监听实现对输入字数的限制(推荐)
- Android实现多层级Spinner列表选项实时更新树形层级
- Android实现多层级Spinner列表选项实时更新树形层级
- Android 动态移动控件实现 推荐
- Android控件Gridview实现多个menu模块,可添加可删除
- Android中RecyclerView的item中控件的点击事件添加删除一行、上移下移一行的代码实现
- Android:控件Spinner实现下拉列表
- 浅谈Android列表ListView下拉刷新控件的实现(一)
- android中ListView添加CheckBox控件实现选择
- 老李推荐:第14章8节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-获取控件列表并建立控件树 3
- android 实现具有进度描述的多列表文件下载
- AndrowListView实现(自定义游戏列表)防止屏幕闪烁,设置分割线android中不推荐的方法,要考虑向下兼容,用了推荐的新方法,可能不兼容旧版本系统的手机
- 老李推荐:第14章8节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-获取控件列表并建立控件树 1
- Android控件Gridview实现多个menu模块,可添加可删除
- Android仿微信下拉列表实现 推荐
- android列表【android开发记录片】android下实现圆角列表布局控件
- 打造Android集合控件数据绑定(支持添加监听,支持AbsListView与RecycleView,支持异步加载等)(三)具体实现
- Android控件Spinner实现下拉列表及监听功能