<p>ListView</p><p>  显示大量相同格式数据</p><p>  常用属性:</p><p>    listSelector listView每项在选中、按下等不同状态时的Drawable</p><p>    divider ListView每项间的间隔Drawable</p><p>    dividerHeight ListView每项间间隔的间隔高度</p><p> <img src="/up_pic/201812/171041081286.png" title="171041081286.png" alt="1.png"/>   </p><p></p><p>  常用方法:</p><p>    setAdapter() 设置数据适配器</p><p>    setOnItemClickListener() 设置每项点击事件监听</p><p>    addHeaderView() 添加头视图</p><p>    addFooterView() 添加脚视图</p><p>    setEmptyView() 设置数据项为0时的空数据视图</p><p>  监听事件</p><p>      这个监听的例子是设置了一个头视图 项的下标改变 所以用 position-listview.getHeaderViewsCount() 计算项的下标位置 获取正确的对象 </p><p> <img src="/up_pic/201812/171041163998.png" title="171041163998.png" alt="2.png"/>     </p><p></p><p></p><p></p><p></p><p>Adapter数据适配器 将各种数据以合适的形式绑定到控件上 像listview, gridview, spinner 等等等控件 都会用到Adapter绑定数据</p><p>介绍三种Adapter</p><p>ArrayAdapter:支持泛型操作,最简单的一个Adapter,只能展现一行文字</p><p>SimpleAdapter:同样具有良好扩展性的一个Adapter,可以自定义多种效果</p><p>BaseAdapter:抽象类,实际开发中我们会继承这个类并且重写相关方法,用得最多的一个Adapter</p><p></p><p>先从简单的介绍</p><p>1.ArrayAdapter</p><p>  <img src="/up_pic/201812/171041411604.png" title="171041411604.png" alt="1.png"/></p><p>参数1:当前上下文环境</p><p>参数2:android.R.layout.simple_list_item_1</p><p>    是android自带的一个简单布局 里面只包含一个id为text1的TextView 也就是参数3 ArrayAdapter只能显示一行数据 显示文本信息 使用这个系统提供的布局就可以</p><p>android系统还给我们提供了其他一些好用的模板</p><p>  simple_list_item_1 : 单独一行的文本框</p><p>  simple_list_item_2 : 两个文本框组成</p><p>  simple_list_item_checked : 每项都是由一个已选中的列表项</p><p>  imple_list_item_multiple_choice : 都带有一个复选框</p><p>  simple_list_item_single_choice : 都带有一个单选钮</p><p>参数4:绑定的数据 这里使用是string数组 上面提到过ArrayAdapter支持泛型 也可以绑定一个list</p><p>显示效果 绑定了listview</p><p><img src="/up_pic/201812/171041454555.png" title="171041454555.png" alt="2.png"/></p><p></p><p></p><p>2.SimpleAdapter</p><p>  simpleAdapter的扩展性最好,可以定义各种各样的布局出来,可以放上ImageView(图片),还可以放上Button(按钮),CheckBox(复选框)等等</p><p>  <img src="/up_pic/201812/171042055534.png" title="171042055534.png" alt="1.png"/></p><p>  显示结果</p><p> <img src="/up_pic/201812/171042083643.png" title="171042083643.png" alt="2.png"/> </p><p>  这里引用的布局是系统默认simple_list_item_2</p><p>  listView项显示的效果是根据你的布局显示的,你想写的多炫酷叼都可以</p><p></p><p>3.BaseAdapter</p><p>BaseAdapter是开发中最常用的适配器ArrayAdapter, SimpleAdapter 都继承于BaseAdapter。BaseAdapter可以完成自己定义的Adapter,可以将任何复杂组合的数据和资源,以任何你想要的显示效果展示给大家。</p><p>继承BaseAdapter之后,需要重写以下四个方法:getCount,getItem,getItemId,getView。</p><p>系统在绘制ListView之前,将会先调用getCount方法来获取Item的个数。每绘制一个Item就会调用一次getView方法,在getView中引用事先定义好的layout布局确定显示的效果并返回一个View对象作为一个Item显示出来。</p><p>这两个方法是自定ListView显示效果中最为重要的,同时只要重写好了这两个方法,ListView就能完全按开发者的要求显示。而getItem和getItemId方法将会在调用ListView的响应方法的时候被调用到。</p><p></p><p>自定义布局文件(listview的项的显示效果)</p><pre class="brush:xml;toolbar:false">&lt;?xmlversion=&quot;1.0&quot;encoding=&quot;utf-8&quot;?&gt; &lt;RelativeLayoutxmlns:android=&quot;http://schemas.android.com/apk/res/android&quot; android:layout_width=&quot;match_parent&quot; android:layout_height=&quot;match_parent&quot;&gt; &lt;ImageView android:id=&quot;@+id/image_photo&quot; android:layout_width=&quot;70dp&quot; android:layout_height=&quot;70dp&quot; android:padding=&quot;10dp&quot;/&gt; &lt;TextView android:id=&quot;@+id/name&quot; android:layout_width=&quot;wrap_content&quot; android:layout_height=&quot;wrap_content&quot; android:textSize=&quot;20dp&quot; android:layout_toRightOf=&quot;@id/image_photo&quot;/&gt; &lt;TextView android:id=&quot;@+id/age&quot; android:layout_width=&quot;wrap_content&quot; android:layout_height=&quot;wrap_content&quot; android:textSize=&quot;20dp&quot; android:layout_toRightOf=&quot;@id/image_photo&quot; android:layout_below=&quot;@id/name&quot; android:layout_marginTop=&quot;10dp&quot;/&gt; &lt;/RelativeLayout&gt;</pre><p></p><p>student学生类</p><pre class="brush:java;toolbar:false">publicclassStudent{ privateStringname; privateintage; privateintphoto; publicStringgetName(){ returnname; } publicvoidsetName(Stringname){ this.name=name; } publicintgetAge(){ returnage; } publicvoidsetAge(intage){ this.age=age; } publicintgetPhoto(){ returnphoto; } publicvoidsetPhoto(intphoto){ this.photo=photo; } }</pre><p></p><p>MainActivity</p><pre class="brush:java;toolbar:false">publicclassMainActivityextendsAppCompatActivity{ privateListViewlistView;   //自定义BaseAdapter privateMyAdapteradapter; @Override protectedvoidonCreate(BundlesavedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); listView=(ListView)findViewById(R.id.listview); List&lt;Student&gt;stuList=newArrayList&lt;&gt;(); for(inti=0;i&lt;10;i++){ Studentstu=newStudent(); stu.setAge(10+i); stu.setName(&quot;name&quot;+i); stu.setPhoto(R.mipmap.ic_launcher); stuList.add(stu); }        adapter=newMyAdapter(stuList,MainActivity.this); listView.setAdapter(adapter); }</pre><p></p><p>MyAdapter</p><pre class="brush:java;toolbar:false">publicclassMyAdapterextendsBaseAdapter{ privateList&lt;Student&gt;stuList; privateLayoutInflaterinflater; publicMyAdapter(){} publicMyAdapter(List&lt;Student&gt;stuList,Contextcontext){ this.stuList=stuList; this.inflater=LayoutInflater.from(context); } @Override publicintgetCount(){ returnstuList==null?0:stuList.size(); } @Override publicStudentgetItem(intposition){ returnstuList.get(position); } @Override publiclonggetItemId(intposition){ returnposition; } @Override publicViewgetView(intposition,ViewconvertView,ViewGroupparent){ //加载布局为一个视图 Viewview=inflater.inflate(R.layout.layout_student_item,null); Studentstudent=getItem(position); //在view视图中查找id为image_photo的控件 ImageViewimage_photo=(ImageView)view.findViewById(R.id.image_photo); TextViewtv_name=(TextView)view.findViewById(R.id.name); TextViewtv_age=(TextView)view.findViewById(R.id.age); image_photo.setImageResource(student.getPhoto()); tv_name.setText(student.getName()); tv_age.setText(String.valueOf(student.getAge())); returnview; }</pre><p>显示结果</p><p><img src="/up_pic/201812/171042256971.png" title="171042256971.png" alt="1.png"/></p><p></p>
T:0.007178s,M:252.05 KB
返回顶部 留言