博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android实现带图标的ListView
阅读量:5136 次
发布时间:2019-06-13

本文共 4453 字,大约阅读时间需要 14 分钟。

版权声明:本文为博主原创文章。未经博主同意不得转载。

https://blog.csdn.net/bear_huangzhen/article/details/23991119

Android实现带图标的ListView已经成为每个android应用开发刚開始学习的人的必学知识,熟练掌握此知识点,对我们以后的开发工作会大有优点。今天我们就来一步一步实现一个Android带图标的ListView。

(1)首先我们要准备一些必须的资源文件,先随便找8张图片,分别取名叫img01,img02,img03,img04,img05,img06,img07,img08

(2)在layout以下的activity_main.xml中加入一个ListView控件。代码例如以下:

在layout以下加入一个名字叫做items.xml的文件。其内容例如以下:

这个布局文件中面包含一个ImageView和一个TextView,实际上我们能够在这里自己定义各种ListView Item的样式

(3)Java代码部分,我们最基本的工作就是又一次定义类MainListViewAdapter,这个类就是向ListView视图提供数据的。代码有一点点长,是由于我都加了非常具体的凝视,具体例如以下:

public class MainActivity extends Activity {	// 声明ListView控件	private ListView mListView;	// 声明数组链表,其装载的类型是ListItem(封装了一个Drawable和一个String的类)	private ArrayList
mList; /** * Acitivity的入口方法 */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 指定Activity的布局使用activity_main.xml setContentView(R.layout.activity_main); // 通过findviewByID获取到ListView对象 mListView = (ListView) findViewById(R.id.listView1); // 获取Resources对象 Resources res = this.getResources(); mList = new ArrayList
(); // 初始化data。装载八组数据到数组链表mList中 ListItem item = new ListItem(); item.setImage(res.getDrawable(R.drawable.img01)); item.setTitle("项目一"); mList.add(item); item = new ListItem(); item.setImage(res.getDrawable(R.drawable.img02)); item.setTitle("项目二"); mList.add(item); item = new ListItem(); item.setImage(res.getDrawable(R.drawable.img03)); item.setTitle("项目三"); mList.add(item); item = new ListItem(); item.setImage(res.getDrawable(R.drawable.img04)); item.setTitle("项目四"); mList.add(item); item = new ListItem(); item.setImage(res.getDrawable(R.drawable.img05)); item.setTitle("项目五"); mList.add(item); item = new ListItem(); item.setImage(res.getDrawable(R.drawable.img06)); item.setTitle("项目六"); mList.add(item); item = new ListItem(); item.setImage(res.getDrawable(R.drawable.img07)); item.setTitle("项目七"); mList.add(item); item = new ListItem(); item.setImage(res.getDrawable(R.drawable.img08)); item.setTitle("项目八"); mList.add(item); // 获取MainListAdapter对象 MainListViewAdapter adapter = new MainListViewAdapter(); // 将MainListAdapter对象传递给ListView视图 mListView.setAdapter(adapter); } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.activity_main, menu); return true; } /** * 定义ListView适配器MainListViewAdapter */ class MainListViewAdapter extends BaseAdapter { /** * 返回item的个数 */ @Override public int getCount() { // TODO Auto-generated method stub return mList.size(); } /** * 返回item的内容 */ @Override public Object getItem(int position) { // TODO Auto-generated method stub return mList.get(position); } /** * 返回item的id */ @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; } /** * 返回item的视图 */ @Override public View getView(int position, View convertView, ViewGroup parent) { ListItemView listItemView; // 初始化item view if (convertView == null) { // 通过LayoutInflater将xml中定义的视图实例化到一个View中 convertView = LayoutInflater.from(MainActivity.this).inflate( R.layout.items, null); // 实例化一个封装类ListItemView,并实例化它的两个域 listItemView = new ListItemView(); listItemView.imageView = (ImageView) convertView .findViewById(R.id.image); listItemView.textView = (TextView) convertView .findViewById(R.id.title); // 将ListItemView对象传递给convertView convertView.setTag(listItemView); } else { // 从converView中获取ListItemView对象 listItemView = (ListItemView) convertView.getTag(); } // 获取到mList中指定索引位置的资源 Drawable img = mList.get(position).getImage(); String title = mList.get(position).getTitle(); // 将资源传递给ListItemView的两个域对象 listItemView.imageView.setImageDrawable(img); listItemView.textView.setText(title); // 返回convertView对象 return convertView; } } /** * 封装两个视图组件的类 */ class ListItemView { ImageView imageView; TextView textView; } /** * 封装了两个资源的类 */ class ListItem { private Drawable image; private String title; public Drawable getImage() { return image; } public void setImage(Drawable image) { this.image = image; } public String getTitle() { return title; } public void setTitle(String title) { this.title = title; } }}
右键执行一下android project。效果图例如以下:

      最后附上工程源代码下载链接:

转载于:https://www.cnblogs.com/xfgnongmin/p/10710049.html

你可能感兴趣的文章
网站搭建(一)
查看>>
Spring JDBCTemplate
查看>>
Radon变换——MATLAB
查看>>
Iroha and a Grid AtCoder - 1974(思维水题)
查看>>
gzip
查看>>
转负二进制(个人模版)
查看>>
LintCode-Backpack
查看>>
查询数据库锁
查看>>
[LeetCode] Palindrome Number
查看>>
我对于脚本程序的理解——百度轻应用有感
查看>>
SQL更新某列包含XX的所有值
查看>>
网易味央第二座猪场落户江西 面积超过3300亩
查看>>
面试时被问到的问题
查看>>
spring 事务管理
查看>>
VS2008 去掉msvcr90的依赖
查看>>
当前记录已被另一个用户锁定
查看>>
Bootstrap
查看>>
Node.js 连接 MySQL
查看>>
ACM-ICPC 2018 world final A题 Catch the Plane
查看>>
那些年,那些书
查看>>