在ListView<1>中,简单的实现了List的效果,但是有很大弊病,UI界面是与用户交互的直接窗口,显然,list模板是一个单一的TextView过于单调,如果,这个模板我们可以集合android的UI组件自行设计,效果就会很好。
在这个例子中,新建了一个XML文件show.xml,专门用来设置list的每一条目显示的模板,在本例中,只是ImageView和TextView的结合,当然还可以有更复杂的,用ImageView,TextView,Button等等组件以RelativeLayout的布局可以创建出我们喜欢的list模板。
在activity_main.xml中创建一个标签,<ListView>,这样在MainActivity.java中拿到这个ListView,然后加入适配器,那么显示的内容就会显示在activity_main的ListView的位置,所以在activity_main的布局中我们可以让ListView放在一个合适的位置。
在本例中有一个比较重要的地方,在MyAdapter中的getView方法中如何将我们创建的show.xml表现的布局作为ListView的显示形式,代码如下:
View view = View.inflate(MainActivity.this, R.layout.show, null);
这一行代码可以看出它的作用是拿到show.xml模板的view,在前面的讲过将xml文件实例化为view对象,有三种形式,代码如下:
LayoutInflater inflater=(LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); View layout = inflater.inflate(R.layout.main, null); LayoutInflater inflater = LayoutInflater.from(context); View layout = inflater.inflate(R.layout.main, null); LayoutInflater inflater = getLayoutInflater(); View layout = inflater.inflate(R.layout.main, null);
其实这三种形式的源码都是一样的,看view的inflate函数的源码:
/** * Inflate a view from an XML resource. This convenience method wraps the {@link * LayoutInflater} class, which provides a full range of options for view inflation. * * @param context The Context object for your activity or application. * @param resource The resource ID to inflate * @param root A view group that will be the parent. Used to properly inflate the * layout_* parameters. * @see LayoutInflater */ public static View inflate(Context context, int resource, ViewGroup root) { LayoutInflater factory = LayoutInflater.from(context); return factory.inflate(resource, root); }
public class MainActivity extends Activity { private ListView listView; private int i=0; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); listView = (ListView)findViewById(R.id.list); listView.setAdapter(new MyAdapter()); } private class MyAdapter extends BaseAdapter{ @Override public int getCount() { return 50; } @Override public Object getItem(int arg0) { return null; } @Override public long getItemId(int position) { return 0; } @Override public View getView(int position, View convertView, ViewGroup parent) { View view = View.inflate(MainActivity.this, R.layout.show, null); ImageView image = (ImageView)view.findViewById(R.id.image); image.setImageResource(R.drawable.win); TextView textView = (TextView)view.findViewById(R.id.textView); textView.setTextSize(20); textView.setText("More effort,more fournate" + i++); return view; } } }