Adapter(自定义适配器)Listview

Android系统中自带的SimpleAdapter,有很多局限,所以很多用自定义的

//系统的SimpleAdapter

a.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">
<ListView
    android:id="@+id/list_view"
    android:scrollbars="none"
    android:listSelector="#00000000"
    android:divider="@null"
    android:dividerHeight="40dp"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"></ListView>
</LinearLayout>

listview.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <ImageView
        android:layout_centerVertical="true"
        android:id="@+id/listview_tx_iv"
        android:src="@mipmap/ic_launcher"
        android:layout_marginLeft="20dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <TextView
        android:id="@+id/listview_name_tv"
        android:text="姓名:"
        android:layout_marginLeft="35dp"
        android:layout_alignTop="@+id/listview_tx_iv"
        android:layout_toRightOf="@+id/listview_tx_iv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <TextView
        android:id="@+id/listview_na_tv"
        android:text="123"
        android:layout_alignBottom="@+id/listview_name_tv"
        android:layout_alignParentRight="true"
        android:layout_marginRight="20dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <TextView
        android:id="@+id/listview_age_tv"
        android:text="年龄:"
        android:layout_alignLeft="@+id/listview_name_tv"
        android:layout_toRightOf="@+id/listview_tx_iv"
        android:layout_alignBottom="@+id/listview_tx_iv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <TextView
        android:id="@+id/listview_ag_tv"
        android:text="123"
        android:layout_alignLeft="@+id/listview_na_tv"
        android:layout_alignBottom="@+id/listview_age_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        />

</RelativeLayout>

UIUU.java

package com.example.shuai.listview;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.Toast;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * Created by shuai on 2016/5/6.
 */
public class UIUU extends Activity {
    List<Map<String,String>> list=new ArrayList<>();
    ListView lv;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        inview();
        setContentView(R.layout.a);
        lv= (ListView) findViewById(R.id.list_view);
        SimpleAdapter adapter=new SimpleAdapter(this,list,R.layout.listview,new String[]{"name","age"},new int[]{R.id.listview_na_tv,R.id.listview_ag_tv});
        lv.setAdapter(adapter);
        lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                Toast.makeText(UIUU.this,  list.get(position).toString(),Toast.LENGTH_SHORT).show();
            }
        });
    }
    void inview(){
        for(int i=0;i<20;i++){
            Map<String,String> map = new HashMap<>();
            map.put("name","lili"+i);
            map.put("age","12"+i);
            list.add(map);
        }
    }
}

//自定义Adapter

list.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <ListView
        android:id="@+id/list_view"
        android:dividerHeight="40dp"
        android:scrollbars="none"
        android:divider="#00000000"
        android:layout_width="match_parent"
        android:layout_height="match_parent"></ListView>
</LinearLayout>

a.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">
<ImageView
    android:id="@+id/a_tx_iv"
    android:background="@mipmap/ic_launcher"
    android:layout_width="50dp"
    android:layout_centerVertical="true"
    android:layout_marginLeft="20dp"
    android:layout_height="50dp" />
    <TextView
        android:id="@+id/a_name_tv"
        android:text="姓名:"
        android:layout_toRightOf="@+id/a_tx_iv"
        android:layout_alignTop="@+id/a_tx_iv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <TextView
        android:id="@+id/a_nameshow_tv"
        android:text="123"
        android:layout_alignParentRight="true"
        android:layout_marginRight="20dp"
        android:layout_alignBottom="@+id/a_name_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <TextView
        android:id="@+id/a_age_tv"
        android:text="年龄:"
        android:layout_width="wrap_content"
        android:layout_alignLeft="@+id/a_name_tv"
        android:layout_alignBottom="@+id/a_tx_iv"
        android:layout_height="wrap_content" />
    <TextView
        android:id="@+id/a_agshow_tv"
        android:text="123"
        android:layout_alignBottom="@+id/a_age_tv"
        android:layout_alignLeft="@+id/a_nameshow_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
</RelativeLayout>

MyAdapter.java

package com.example.shuai.adapter;

import android.content.Context;
import android.support.v4.view.LayoutInflaterFactory;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Adapter;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;

import java.util.List;

/**
 * Created by shuai on 2016/5/6.
 */
public class MyAdapter extends BaseAdapter {
    Context context;
    List<User> list;

    public MyAdapter(Context context, List<User> list) {
        this.context = context;
        this.list = list;
    }

    @Override
    public int getCount() {
        return list.size();
    }

    @Override
    public Object getItem(int position) {
        return position;
    }

    @Override
    public long getItemId(int position) {
        return 0;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder viewHolder = null;
        if (convertView == null) {
            convertView = LayoutInflater.from(context).inflate(R.layout.a, null);
            viewHolder = new ViewHolder();
            viewHolder.name = (TextView) convertView.findViewById(R.id.a_nameshow_tv);
            viewHolder.age = (TextView) convertView.findViewById(R.id.a_agshow_tv);
            viewHolder.iv = (ImageView) convertView.findViewById(R.id.a_tx_iv);
            convertView.setTag(viewHolder);
        } else {
            viewHolder = (ViewHolder) convertView.getTag();
        }
        User u = list.get(position);
        viewHolder.name.setText(u.getName());
        viewHolder.age.setText(u.getAge());
        viewHolder.iv.setBackgroundResource(u.getImg());
        return convertView;
    }

    class ViewHolder {
        TextView name;
        TextView age;
        ImageView iv;
    }
}

MainActivity.java

package com.example.shuai.adapter;

import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.AdapterView;
import android.widget.ListView;
import android.widget.Toast;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {

    ListView lv;
    List<User> list;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.list);
        inview();
        lv= (ListView) findViewById(R.id.list_view);
        MyAdapter myAdapter=new MyAdapter(this,list);
        lv.setAdapter(myAdapter);
        lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                Toast.makeText(MainActivity.this,list.get(position).toString(),Toast.LENGTH_SHORT).show();
            }
        });
    }

    void inview(){
        list=new ArrayList<>();
        for(int i=0;i<2;i++){
            User u=new User("lili","2"+i,R.mipmap.ic_launcher);
            list.add(u);
    }
        for(int i=0;i<2;i++){
            User u=new User("lvlv","1"+i,R.mipmap.bigtree);
            list.add(u);
        }
        for(int i=0;i<5;i++){
            User u=new User("kk","3"+i,R.mipmap.star);
            list.add(u);
        }
    }
}

小Demo自用

时间: 2024-12-23 03:53:33

Adapter(自定义适配器)Listview的相关文章

详解Adapter(适配器)结合ListView

不是我针对谁,我只想针对新手玩家. (括号里的内容都是我主观添加的,感觉还是不好理解请帮忙指出来谢谢!) UI控件都是跟Adapter(适配器)打交道的 Adapter: 是用来帮助控件填充数据的中间桥梁 (在开发中大多数Textview控件的内容是依靠数据库传递并显示的如:新闻类) Adapter: 将各种数据以合适的形式显示到view上 (我是显示图片的控件,你给我传文字是不是不想好了,分手!) Adapter: 需要结合ListView, GridView等等集合类控件 (List 在学习

ListView和Adapter数据适配器的简单介绍

ListView 显示大量相同格式数据 常用属性: listSelector            listView每项在选中.按下等不同状态时的Drawable divider                ListView每项间的间隔Drawable dividerHeight        ListView每项间间隔的间隔高度 常用方法: setAdapter()                设置数据适配器 setOnItemClickListener()        设置每项点击事件

ListView使用自定义适配器的情况下实现适配器的文本和图标控件点击事件执行Activity界面中的方法

ListView使用的是自定义适配器,列表项的布局文件中含有文本和图标,实现文本区域和图标区域的点击事件. 实现思路:在自定义适配器MyArrayAdapter 类型中自定义接口和接口方法,分别设置文本区域和图标区域的OnClickListener,然后在activity界面中MyArrayAdapter实例实现这个接口. 1.listitem布局文件 <?xml version="1.0" encoding="utf-8"?> <LinearLa

ListView使用自定义适配器的情况下实现适配器的控件点击事件执行Activity界面中的方法

如果ListView使用的是自定义的适配器,比如MyArrayAdapter extends ArrayAdapter<String> 那么,如何实现适配器中的点击事件执行activity界面中的方法呢? 实现思路:在自定义适配器MyArrayAdapter 类型中自定义接口和接口方法,然后在activity界面中MyArrayAdapter实例实现这个接口. 较为完整的代码见上文. 1.MyArrayAdapter 关键代码 自定义接口和方法的代码如下: //列表项的单击事件监听接口 pub

Android自定义适配器和ListView的点击事件相结合的使用

下边演示一个使用ListView和自定义适配器的案例,点击ListView中的条目会出现一个对话框,进行成绩的修改,修改之后会立即通知适配器进行数据的重新加载,如下: (1).用于显示listView的布局文件: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" andro

Android -- ListView(SimpleAdapter) 自定义适配器

2.  代码 MainActivity package com.himi; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.widget.AdapterVie

细解ListView之自定义适配器

下面我们将以一个例子来讲述ListView之自定义适配器 首先我们看一下效果图: [分析] 首先:需要创建一个ListView控件,自定义适配器是为了实现自定义ListView的ListView_Item,所以我们应该在创建一个Item 然后书写自定义适配器,自定义适配器的时候需要继承BaseAdapter,然后实现它的未实现的4个方法,然后在实现自定义适配器的构造方法,其构造方法的参数为山下文对象,数据源,必须实现的4个方法主要是对数据源进行过操作, 然后考虑优化方面,我们使用了ViewHol

安卓开发_浅谈ListView(自定义适配器)

ListView作为一个实际开发中使用率非常高的视图,一般的系统自带的适配器都无法满足开发中的需求,这时候就需要开发人员来自定义适配器使得ListView能够有一个不错的显示效果 有这样一个Demo ,实现图片文字混合列表 1 package com.example.work; 2 3 import java.util.ArrayList; 4 import java.util.HashMap; 5 import java.util.List; 6 7 8 import android.R.in

自定义适配器视图getview实现方法比较

Android开发之中,listview是一个非常重要的组件,它以列表的形式显示用户的数据,用户可以自由的定义LsitView每一列的内容,样式,很多时候使用ListView都需要使用自定义Adapter,自定义Adapter之中最重要的莫过于getView方法了. getView方法实现主要的三种方法: 1.第一种就是每次都给adapter new一个View载入布局. 例如: public View getView(int position, View convertView, ViewGr

Android ListFragment实例Demo(自定义适配器)

上一篇文章介绍了ListFragment,其中的ListView并没有自定义适配器,实际上在实际开发中常会用到自定义适配器,是实现更复杂的列表数据展示.所以这篇文章增加了自定义适配器,来进行ListView数据的展示. 实现效果图: 左边是Activity中的一个按钮,点击按钮会出现右边的Fragment相应的数据列表. 代码展示: 布局文件: activity_main: <LinearLayout xmlns:android="http://schemas.android.com/ap