ListView自定义Adapter实现仿QQ界面
来源:互联网 发布:react.js api 编辑:程序博客网 时间:2024/05/22 00:38
源码下载:http://download.csdn.net/download/jjhahage/10039034
PS:listview中有一些简单使用的适配器,如:SimpleAdapter:构造方法SimpleAdapter(Context context,List<Map<String,?>> data,reString [] from,int [] to),但这种适配器过于单调,往往不能达到用户想要的效果,想要随心所欲,就用到了BaseAdapter,自定义适配器。
如图:
1:首先写布局文件
activity_layout.xml
<?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"> <ListView android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/id_lv"> </ListView></LinearLayout>没一个item的样式:itemstyle_layout.xml 其中的图片自己随便找个即可。
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:orientation="horizontal" android:layout_height="match_parent"> <ImageView android:layout_width="70dp" android:layout_height="80dp" android:src="@drawable/tou"/> <LinearLayout android:layout_width="0dp" android:layout_weight="0.9" android:layout_height="80dp" android:orientation="vertical"> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:textSize="35dp" android:text="11111" android:id="@+id/id_item_tv"/> <TextView android:layout_marginTop="5dp" android:layout_width="match_parent" android:layout_height="wrap_content" android:textSize="20dp" android:text="11111" android:id="@+id/id_item_tv2"/> </LinearLayout> <LinearLayout android:layout_width="0dp" android:layout_height="80dp" android:layout_weight="0.1" android:orientation="vertical"> <ImageView android:layout_width="match_parent" android:layout_height="50dp" android:src="@drawable/xin1"/> </LinearLayout></LinearLayout>
2:创建适配器MyAdapter.java (已优化)
申明一点,适配中有优化方法,如果不优化的话,有时也可以加载出来,但有时就会加载错乱,没调用一次就会多浪费创建一个view对象,如:
View item = LayoutInflater.from(context).inflate(R.layout.itemstyle_layout, null);// TextView info = (TextView)item.findViewById(R.id.id_item_tv);// info.setText(list.get(position)+"");
优化后(加入了Viewholder)
public class MyAdapter extends BaseAdapter{ // public List<Map<String,String>> list; public Context context; public MyAdapter (Context context,List<Map<String,String>> list){ this.context=context; this.list=list; }
@Override public int getCount() { return list.size();//返回个数 } @Override public Object getItem(int position) { return list.get(position);//返回项 } @Override public long getItemId(int position) { return position;//角标 } @Override public View getView(int position, View convertView, ViewGroup parent) {// View item = LayoutInflater.from(context).inflate(R.layout.itemstyle_layout, null);// TextView info = (TextView)item.findViewById(R.id.id_item_tv);// info.setText(list.get(position)+""); ViewHolder viewHolder; if(convertView ==null){ viewHolder= new ViewHolder(); convertView=LayoutInflater.from(context).inflate(R.layout.itemstyle_layout,null);//加载布局 viewHolder.tv1= (TextView) convertView.findViewById(R.id.id_item_tv); viewHolder.tv2= (TextView) convertView.findViewById(R.id.id_item_tv2); convertView.setTag(viewHolder); }else{ viewHolder= (ViewHolder) convertView.getTag(); } viewHolder.tv1.setText(list.get(position).get("tv1")+""); viewHolder.tv2.setText(list.get(position).get("tv2")+""); return convertView; } static class ViewHolder { ImageView iv; TextView tv1; TextView tv2; }
3:在MainActivity.java中加载listview控件并 把list赋值。
public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); ListView lv= (ListView) findViewById(R.id.id_lv); List<Map<String,String>> list=new ArrayList<Map<String,String>> (); for(int i=0;i<10;i++){ Map<String,String> map=new HashMap<>(); map.put("tv1","111111"); map.put("tv2","222222"); list.add(map); } MyAdapter ma=new MyAdapter(this,list); lv.setAdapter(ma); }}
完事。总结:代码优化加入Viewholder的好处:(官方翻译)
重用缓存convertView传递给getView()方法来避免填充不必要的视图
使用ViewHolder模式来避免没有必要的调用findViewById():因为太多的findViewById也会影响性能
ViewHolder模式通过getView()方法返回的视图的标签(Tag)中存储一个数据结构,这个数据结构包含了指向我们要绑定数据的视图的引用,从而避免每次调用getView()的时候调用findViewById())。
阅读全文
0 0
- ListView自定义Adapter实现仿QQ界面
- ListView仿QQ对话界面
- android仿qq实现自定义拍照界面CameraView
- 循序渐进实现仿QQ界面
- 仿qq界面的实现
- android 自定义listview实现仿微信/QQ设置界面的开发
- 仿QQ侧滑删除,自定义ListView
- 自定义控件之DragLayout仿QQ界面
- 自定义仿QQ主界面选项卡
- 自定义仿QQ主界面选项卡
- Qt实现QListView自定义Item界面——仿QQ好友界面
- 仿QQ的ListView:SpinnedHeaderExpandableListView实现
- Android仿QQ实现ListView滑动删除
- Android仿QQ实现ListView滑动删除
- 转一个仿QQ界面(VC实现)
- wxPython实现仿QQ登录界面
- Android 仿QQ界面的实现
- android实现仿QQ界面刷新
- Linux 下用命令修改mysql5.6 编码格式
- IntelliJ IDEA 创建maven web项目2(6)
- mysql无法启动
- leetcode 120
- 模式识别2-线性分类器(最小二乘法)
- ListView自定义Adapter实现仿QQ界面
- 纯干货|史上最全科技公司分级盘点
- mybatis高级映射(一对一,一对多,多对多)
- fast-rcnn练习资料整理
- Linux命令(文件编辑器)
- 我为什么辞职?
- 芯科通信管理体系变革
- csdn markdown写博客技巧
- 【贪心+线段树】Codeforces 557C Arthur and Table