• ListView 自己定义BaseAdapter实现单选打勾(无漏洞)


    假设须要完整demo,请评论留下邮箱

    (眼下源代码已经不发送。假设须要源代码,加qq316701116。不喜勿扰)


    近期由于一个项目的原因须要自己定义一个BaseAdapter实现ListVIew单选打勾的功能,尽管听起来非常easy,我在网上也 看过一些样例,似乎是实现了,但往往存在一些漏洞。往往漏洞例如以下

    1、网上样例item较少,item增多时漏洞出现,忽略了BaseAdapter中getView()方法中convertView重用的问题

    2、忽略了BaseAdapter中getView()方法并非一下子载入全然部item,上下拖动listview时item会又一次载入。getview会又一次被调用,所以上下拖动的时候漏洞出 现

    3、破坏了getview()方法中的convertView重用的长处,选择每次载入,都又一次new一个convertView,尽管实现了,却大大减少了性能


    综合以上,你会发现。自己定义一个合理的BaseAdapter以及重写getView()方法是实现本功能的关键所在


    我们先来看看getView方法有什么奥秘

    看看getVIew()方法的參数列表

    publicView getView (int position, View convertView, ViewGroup parent)

    先来解析下參数:position表示第position个item;

                                   convertView表示一个item布局,也就是一个item的句柄

                                   parent表示使用这个Adapter的ListView


    对于getVIew的重用和优化功能,在这里我就不具体说明。由于网上这部分的博客说的非常多,并且说得还不错

    假如你的手机一次性能显示10个item。那么,在第一次载入的时候。这10个item调用getVIew方法的时候,传入的參数中 convertView都是null

    但当你向下拖动listview,第11个item显示而第1个item离开的时候,此时getVIew方法的调用传入的參数中 convertView就是第1个item的 convertView,这就是 convertView的重用,我们能够通过 convertView訪问item的各个控件,改动控件的text、图片等,就变成了第11个显示的item

    假如item里面有一个TextView。写着当前item是第几个,那第1个item的TextVIew就写着第一。当第11个item调用getVIew的传入的 是第1个item的convertView,通过 convertView获取的TextView事实上是第1个item的TextView,我们仅仅要将 TextView的text改成第十一


    上下拖动listview,仅仅会有10个 convertView实例存在。getVIew()会被重复调用,存在着

    1——11——21

    2——12——22

    3——13——23

    。。。

    10——20——30

    这么一个 convertView的相应关系

    可參考博客http://blog.csdn.net/kaixinbingju/article/details/8650249

    依照上面这个说法设计getVIew方法是合理的、高效的

    有了上面的叙述。那实现 ListView 自己定义BaseAdapter实现单选打勾 功能就有了理论基础

    下面是我实现该功能的核心代码

    ListVitw里面item的布局文件listitem_place.xml

    <span style="font-size:14px;"><?

    xml version="1.0" encoding="utf-8"?

    > <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="60dp" android:background="@drawable/greywhite" > <LinearLayout android:layout_height="wrap_content" android:layout_width="wrap_content" android:layout_margin="7dp" android:orientation="vertical"> <TextView android:id="@+id/place_name" android:layout_height="wrap_content" android:layout_width="wrap_content" android:textColor="@drawable/black" android:singleLine="true" android:ellipsize="end" android:textSize="14sp" /> <TextView android:id="@+id/place_adress" android:layout_height="wrap_content" android:layout_width="wrap_content" android:textColor="@drawable/darkgrey" android:singleLine="true" android:ellipsize="end" android:textSize="12sp" android:layout_marginRight="40dp" /> </LinearLayout> <ImageView android:id="@+id/place_select" android:layout_height="25dp" android:layout_width="25dp" android:layout_alignParentRight="true" android:layout_marginRight="10dp" android:layout_centerVertical="true" /> </RelativeLayout></span>


    自己定义的BaseAdapter,关键

    <pre name="code" class="java"><span style="font-size:14px;">package com.vr.souhuodong.UI.Adapter;
    
    import java.util.List;
    
    import android.R.integer;
    import android.view.LayoutInflater;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.view.ViewGroup;
    import android.widget.BaseAdapter;
    import android.widget.ImageView;
    import android.widget.TextView;
    
    import com.baidu.mapapi.search.core.PoiInfo;
    import com.vr.souhuodong.R;
    
    public class PlaceListAdapter extends BaseAdapter {
    	
    	List<PoiInfo> mList;
    	LayoutInflater mInflater;
    	int notifyTip ;
    	
    	private class MyViewHolder {
    		TextView placeName;
    		TextView placeAddree;
    		ImageView placeSelected;
    	}
    
    	public PlaceListAdapter(LayoutInflater mInflater , List<PoiInfo> mList) {
    		super();
    		this.mList = mList;
    		this.mInflater = mInflater;
    		notifyTip = -1 ;
    	}
    	
    	
    	/**
    	 * 设置第几个item被选择,非常关键
    	 * @param notifyTip
    	 */
    <span style="color:#ff0000;">	public void setNotifyTip(int notifyTip) {
    		this.notifyTip = notifyTip;
    	}</span>
    	
    	@Override
    	public int getCount() {
    		// TODO Auto-generated method stub
    		return mList.size();
    	}
    
    	@Override
    	public Object getItem(int position) {
    		// TODO Auto-generated method stub
    		return mList.get(position);
    	}
    
    	@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
    		MyViewHolder holder;
    		if (convertView == null) {
    			System.out.println("----aa-");
    			convertView = mInflater.inflate(com.vr.souhuodong.R.layout.listitem_place, parent, false);		
    		    holder = new MyViewHolder();
    			holder.placeName = (TextView) convertView
    					.findViewById(com.vr.souhuodong.R.id.place_name);
    			holder.placeAddree = (TextView) convertView
    					.findViewById(com.vr.souhuodong.R.id.place_adress);
    			holder.placeSelected = (ImageView) convertView
    					.findViewById(com.vr.souhuodong.R.id.place_select);
    			holder.placeName.setText(mList.get(position).name);
    			holder.placeAddree.setText(mList.get(position).address);
    			holder.placeSelected.setBackgroundResource(R.drawable.greywhite);
    			convertView.setTag(holder);
    		} else {
    			holder = (MyViewHolder) convertView.getTag();			
    		}
    		holder.placeName.setText(mList.get(position).name);
    		holder.placeAddree.setText(mList.get(position).address);
    		<span style="color:#ff0000;">//依据又一次载入的时候第position条item是否是当前所选择的。选择载入不同的图片。图片是打勾图片
    		if(notifyTip == position ){			
    			holder.placeSelected.setBackgroundResource(R.drawable.ic_select);//打勾图片
    		}			
    		else {
    			holder.placeSelected.setBackgroundResource(R.drawable.greywhite);//未打勾图片
    		}</span>
    
    		return convertView;
    	}
    	
    
    }
    </span>


    
    
    

    ListView的OnitemClickListenr监听器的Onlick()回调函数

    <span style="font-size:14px;">		@Override
    		public void onItemClick(AdapterView<?

    > parent, View view, int position, long id) { // TODO Auto-generated method stub <span style="color:#ff0000;">// 通知是适配器第position个item被选择了 mAdapter.setNotifyTip(position); // 选中项打勾 mSelectImg.setBackgroundResource(R.drawable.greywhite); mSelectImg = (ImageView) view.findViewById(R.id.place_select); mSelectImg.setBackgroundResource(R.drawable.ic_select); </span> }</span>


    红色为关键

    以上就是所有内容,假设有什么疑问能够评论回复,假设希望完整demo。请评论留下邮箱

  • 相关阅读:
    SpringCloud 学习笔记(7)路由网关Zuul
    调用数据库中某特定项的方法
    节点在TreeView中无限添加,无刷新实现父节点选中,子节点同时选中
    jQuery formValidator 表单校验插件4.1.1高仿网易邮箱注册页面(已发演示链接)
    jQuery formValidator 4.0 表单验证插件(正式版)
    jQuery formValidator表单验证插件4.1.0 下载 演示 文档 可换肤 代码生成器
    jQuery formValidator表单验证插件3.5a 版本发布,适合jQuery1.3.2类库
    武林英雄辅助工具
    jQuery formValidator表单验证插件4.1.3提供下载
    jQuery formValidator4.0.1 表单校验插件更新日志(已提供下载)
  • 原文地址:https://www.cnblogs.com/mthoutai/p/7219276.html
Copyright © 2020-2023  润新知