android ListView中自定义SimpleAdapter动态添加ratingBar及图片更新

android中listView的实现有多种方式,但是当我们利用simpleAdapter实现listView的时候,SimpleAdapter并没有提供显示一个ratingBar的功能(即上面的星星用来评分的控件)。要实现上面的功能,我们可以通过继承SimpleAdapter类重写其中一些方法来实现。下面即是此类的实现:

package nate.android.Service;

import java.util.List;
import java.util.Map;
import com.nate.wte.LocalSql.StoresInfoDB;
import android.content.Context;
import android.graphics.Bitmap;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Checkable;
import android.widget.ImageView;
import android.widget.RatingBar;
import android.widget.SimpleAdapter;
import android.widget.TextView;

public class MySimpleAdapter extends SimpleAdapter {
	private int[] mTo;
    private String[] mFrom;
    private ViewBinder mViewBinder;
    private List<? extends Map<String, ?>> mData;
    private int mResource;
    private int mDropDownResource;
    private LayoutInflater mInflater;
	public MySimpleAdapter(Context context,
			List<? extends Map<String, ?>> data, int resource, String[] from,
			int[] to) {
		super(context, data, resource, from, to);
		mData = data;
        mResource = mDropDownResource = resource;
        mFrom = from;
        mTo = to;
        mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
	}
	 /**
     * @see android.widget.Adapter#getView(int, View, ViewGroup)
     */
    public View getView(int position, View convertView, ViewGroup parent) {
        return createViewFromResource(position, convertView, parent, mResource);
    }
    private View createViewFromResource(int position, View convertView,
            ViewGroup parent, int resource) {
        View v;
        if (convertView == null) {
            v = mInflater.inflate(resource, parent, false);

            final int[] to = mTo;
            final int count = to.length;
            final View[] holder = new View[count];

            for (int i = 0; i < count; i++) {
                holder[i] = v.findViewById(to[i]);
            }

            v.setTag(holder);
        } else {
            v = convertView;
        }
        bindView(position, v);

        return v;
    }

    private void bindView(int position, View view) {
        final Map dataSet = mData.get(position);
        if (dataSet == null) {
            return;
        }
        final ViewBinder binder = mViewBinder;
        final View[] holder = (View[]) view.getTag();
        final String[] from = mFrom;
        final int[] to = mTo;
        final int count = to.length;

        for (int i = 0; i < count; i++) {
            final View v = holder[i];
            if (v != null) {
                final Object data = dataSet.get(from[i]);
                String text = data == null ? "" : data.toString();
                if (text == null) {
                    text = "";
                }
                boolean bound = false;
                if (binder != null) {
                    bound = binder.setViewValue(v, data, text);
                }
                if (!bound) {
                    if (v instanceof Checkable) {
                        if (data instanceof Boolean) {
                            ((Checkable) v).setChecked((Boolean) data);
                        } else {
                            throw new IllegalStateException(v.getClass().getName() +
                                    " should be bound to a Boolean, not a " + data.getClass());
                        }
                    } else if (v instanceof TextView) {
                        // Note: keep the instanceof TextView check at the bottom of these
                        // ifs since a lot of views are TextViews (e.g. CheckBoxes).
                        //setViewText((TextView) v, text);
                        ((TextView) v).setText(text);
                    } else if (v instanceof ImageView) {
                    	if (data instanceof Integer) {
                            setViewImage((ImageView) v, (Integer) data);
                        }
                    	else if(data instanceof byte[]) {      //备注1
								Bitmap bmp;
								byte[] image = (byte[])data;
								if(b.length!=0){
								bmp = BitmapFactory.decodeByteArray(b, 0, b.length);
								((ImageView) v).setImageBitmap(bmp);
                        	}
                        }
                    else if(v instanceof RatingBar){
                    	float score = Float.parseFloat(data.toString());  //备注2
                    	((RatingBar)v).setRating(score);
                    }
                    else {
                        throw new IllegalStateException(v.getClass().getName() + " is not a " +
                                " view that can be bounds by this SimpleAdapter");
                    }
                }
            }
        }
    }

    public void setViewImage(ImageView v, int value) {
        v.setImageResource(value);
}

以上MySimpleAdapter类继承自SimpleAdapter,我们要实现的效果主要在 private void bindView(int position, View view) 函数中添加(更改)就行。这个函数中相当于将控件与数据对应,然后在应用此类时,如下

MySimpleAdapter myListAdapter = new MySimpleAdapter(this,list,R.layout.stores,
		new String[]{"store_name", "store_score","store_pic","store_scores","phone"},
		new int[]{R.id.store_name, R.id.store_score,R.id.store_pic,R.id.store_score_bar,R.id.showPhone});

此adapter内容与上面图中显示的listView中的item内容一致。

[java] view
plain
copy

  1. myListView.setAdapter(myListAdapter);  

在备注2处实现了当View是一个RatingBar的类型时也能在listView中显示的效果的功能。此时我们的data就是我们要显示的ratingBar中star的个数(也就是评分数
!!!

在备注1处,我们将网络或者是从数据库等地方取来的图片数据(Blob类型然后转成byte[]类型)(比如我们之前可以使用

[java] view
plain
copy

  1. public byte[] Bitmap2Bytes(Bitmap bm){    
  2.          ByteArrayOutputStream baos = new ByteArrayOutputStream();      
  3.          bm.compress(Bitmap.CompressFormat.PNG, 100, baos);      
  4.          return baos.toByteArray();    
  5.         }  

 将图片转成byte[]类型存储)。扯远了!总之备注一处就是运用上面添加ratingBar同样的原理将byte[]类型的图片还原(这是原来的SimpleAdapter中没有实现的)。

时间: 2024-09-13 10:07:50

android ListView中自定义SimpleAdapter动态添加ratingBar及图片更新的相关文章

android ListView内数据的动态添加与删除实例代码_Android

main.xml 文件:  复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?>  <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"       android:layout_width="fill_parent"       android:layout_height

android ListView内数据的动态添加与删除实例代码

main.xml 文件: 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_pa

android代码优化----ListView中自定义adapter的封装

[正文] [引入] 我们一般编写listView的时候顺序是这样的: 需要展示的数据集List<T> 为这个数据集编写一个ListView 为这个ListView编写一个Adapter,一般继承自BaseAdapter 在BaseAdapter内部编写一个ViewHolder类,对应ListView里面的item控件,提高控件的查询效率 分析: List<T>:ListView --> Adapter extends BaseAdapter --> ViewHolder

Android ListView中动态显示和隐藏Header&amp;Footer的方法_Android

ListView的模板写法 ListView模板写法的完整代码: •android代码优化----ListView中自定义adapter的封装(ListView的模板写法) 以后每写一个ListView,就这么做:直接导入ViewHolder.java和ListViewAdapter,然后写一个自定义adapter继承自ListViewAdapter就行了. ListView中动态显示和隐藏Header&Footer 如果需要动态的显示和隐藏footer的话,按照惯例,误以为直接通过setVis

Android ListView中动态显示和隐藏Header&Footer的方法

ListView的模板写法 ListView模板写法的完整代码: •android代码优化----ListView中自定义adapter的封装(ListView的模板写法) 以后每写一个ListView,就这么做:直接导入ViewHolder.java和ListViewAdapter,然后写一个自定义adapter继承自ListViewAdapter就行了. ListView中动态显示和隐藏Header&Footer 如果需要动态的显示和隐藏footer的话,按照惯例,误以为直接通过setVis

揭秘在ListView等AdapterView上动态添加删除项的陷阱_Android

如何避开在ListView等AdapterView上动态添加删除项的陷阱,下面就为大家分享,具体内容如下 首先,定义如下array资源,作为列表的加载内容: <resources> <string name="app_name">MyListView</string> <string-array name="language"> <item>Java</item> <item>C&l

c# listview或datagridview显示动态添加的数据,效果是局部(刷新)添加数据,添加新数据同时对操作原显示数据无影响

问题描述 c#listview或datagridview显示动态添加的数据,效果是局部(刷新)添加数据,添加新数据同时对操作原显示数据无影响 解决方案 解决方案二:你说的添加新数据是重新绑定,还是在原基础上增加行?解决方案三:引用1楼dongxinxi的回复: 你说的添加新数据是重新绑定,还是在原基础上增加行? 增加行例如:listview展示如下:1abc2def3ghi一段时间数据库有新数据1abc2def3ghi4jkl5mnp解决方案四:无非就是比较两条数据是非"一样"嘛傻瓜式

text-Android中怎样获取动态添加EditText的内容

问题描述 Android中怎样获取动态添加EditText的内容 RT,在Android中如何获得动态添加EditText的输入文本内容? 解决方案 search是一个TextView,类似于这样处理就行了: search.addTextChangedListener(new TextWatcher() { //输入后的串 qr 0 1 2 @Override public void onTextChanged(CharSequence s, int start, int before, int

app-Android中怎样实现动态添加一行EditView

问题描述 Android中怎样实现动态添加一行EditView 类似于联系人app中添加联系人号码的功能,可以按+后添加一栏EditView,增加一个号码,或是按按钮后增加修改联系人姓名(增加前缀后缀)的EditView. 解决方案 就拿添加联系人来说的:首先有一个按钮,你点击(这里是点击事件)后,会弹出一个界面,这个界面你用来添加手机,添加成功后,点击按钮后就添加了(这里点击按钮 后是对数据库执行添加操作的,如果是修改的话,你根据点击的位置得到联系人的Id,然后到数据库里修改就行了). 这里主