• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Android 自定义ListView

java 搞代码 4年前 (2022-01-09) 32次浏览 已收录 0个评论

本文讲实现一个自定义列表的Android程序,程序将实现一个使用自定义的适配器(Adapter)绑定
数据,通过contextView.setTag绑定数据有按钮的ListView。
系统显示列表(ListView)时,首先会实例化一个适配器,本文将实例化一个自定义的适配器。实现
自定义适配器,必须手动映射数据,这时就需要重写getView()方法,系统在绘制列表的每一行的时候
将调用此方法。
ListView在开始绘制的时候,系统自动调用getCount()函数,根据函数返回值得到ListView的长度,
然后根据这个长度,调用getView()逐一画出每一行。
具体使用方法可以参考下面代码,只需记住Android自定义ListView三步骤:
第一步:准备主布局文件、组件布局文件等
第二步:获取并整理数据
第三部:绑定数据,这里我们是通过自己编写Adapter类来完成的
1.首先新建一个list.XML

Java代码

<?xml version="1.0" encoding="utf-8"?>  <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"      android:layout_width="match_parent"      android:layout_height="match_parent"      android:orientation="vertical" >      <LinearLayout android:layout_width="match_parent"          android:layout_height="match_parent"          android:orientation="horizontal" android:background="#f1e4f1">          <ImageView               android:id="@+id/image"              android:layout_width="wrap_content"              android:layout_height="wrap_content"/>          <TextView               android:id="@+id/title"              android:layout_width="wrap_content"              android:layout_height="wrap_content"              android:textColor="#666872"/>          <Button               android:id="@+id/view"              android:layout_width="wrap_content"              android:layout_height="wrap_content"              android:text="详细"/>      </LinearLayout>      <TextView           android:id="@+id/info"          android:layout_width="wrap_content"          android:layout_height="wrap_content"          android:textColor="#666872"/>  </LinearLayout>

2、新建一个适配器类MyAdspter.java

Java代码

public class MyAdspter extends BaseAdapter {        private List<Map<String, Object>> data;      private LayoutInflater layoutInflater;      private Context context;      public MyAdspter(Context context,List<Map<String, Object>> data){          this.context=context;          this.data=data;          this.layoutInflater=LayoutInflater.from(context);      }      /**      * 组件集合,对应list.xml中的控件      * @author Administrator      */      public final class Zujian{          public ImageView image;          public TextView title;          public Button view;          public TextView info;      }      @Override      public int getCount() {          return data.size();      }      /**      * 获得某一位置的数据      */      @Override      public Object getItem(int position) {          return data.get(position);      }      /**      * 获得唯一标识      */      @Override      public long getItemId(int position) {          return position;      }        @Override      public View getView(int position, View convertView, ViewGroup parent) {          Zujian zujian=null;          if(convertView==null){              zujian=new Zujian();              //获得组件,实例化组件              convertView=layoutInflater.inflate(R.layout.list, null);              zujian.image=(ImageView)convertView.findViewById(R.id.image);              zujian.title=(TextView)convertView.findViewById(R.id.title);              zujian.view=(Button)convertView.findViewById(R.id.view);              zujian.info=(TextView)convertView.findViewById(R.id.info);              convertView.setTag(zujian);          }else{              zujian=(Zujian)convertView.getTag();          }          //绑定数据          zujian.image.setBackgroundResource((Integer)data.get(position).get("image"));          zujian.title.setText((String)data.get(position).get("title"));          zujian.info.setText((String)data.get(position).get("info"));          return convertView;      }    }

关于上面LayoutInflater的使用:在实际开发种LayoutInflater这个类还是非常有用的。它的作用类似
于 findViewById(),不同点是LayoutInflater是用来找layout下xml布局文件,并且会实例化!。
getView()的三个参数:position表示将显示的是第几行,covertView是从布局文件中inflate来的布
局。我们用LayoutInflater的方法将定义好的list.xml文件提取成View实例用来显示。然后将xml文件
中的各个组件实例化,这样便可以将数据对应到各个组件上了。但是按钮为了响应点击事件,需要为
它添加点击监听器,这样就能捕获点击事件。
3、activity_main.xml中添加ListView控件

Java代码

<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"      android:paddingBottom="@dimen/activity_vertical_margin"      android:paddingLeft="@dimen/activity_horizontal_margin"      android:paddingRight="@dimen/activity_horizontal_margin"      android:paddingTop="@dimen/activity_vertical_margin"      tools:context=".MainActivity" >      <ListView           android:id="@+id/list"          android:layout_width="fill_parent"          android:layout_height="fill_parent"></ListView>  </RelativeLayout>

4、在activity中调用ListView

Java代码

public class MainActivity extends Activity {        private ListView listView=null;       @Override      protected void onCreate(Bundle savedInstanceState) {          super.onCrea<em>本文来源gao.dai.ma.com搞@代*码(网$</em>te(savedInstanceState);          setContentView(R.layout.activity_main);          listView=(ListView)findViewById(R.id.list);          List<Map<String, Object>> list=getData();          listView.setAdapter(new MyAdspter(this, list));      }      @Override      public boolean onCreateOptionsMenu(Menu menu) {          getMenuInflater().inflate(R.menu.main, menu);          return true;      }        public List<Map<String, Object>> getData(){          List<Map<String, Object>> list=new ArrayList<Map<String,Object>>();          for (int i = 0; i < 10; i++) {              Map<String, Object> map=new HashMap<String, Object>();              map.put("image", R.drawable.ic_launcher);              map.put("title", "这是一个标题"+i);              map.put("info", "这是一个详细信息"+i);              list.add(map);          }          return list;      }  }

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Android 自定义ListView

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址