展会信息港展会大全

Android实现带图标的ListView
来源:互联网   发布日期:2015-11-26 13:03:50   浏览:2054次  

导读:Android实现带图标的ListView已经成为每一个android应用开发初学者的必学知识,熟练掌握此知识点,对我们以后的开发工作会大有好处,今天我们就来一步一步实现一个Android带图...

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,效果图如下:

下载链接:

Android实现带图标的ListView

赞助本站

人工智能实验室

相关热词: android开发

AiLab云推荐
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港