zoukankan      html  css  js  c++  java
  • Android_适配器(adapter)之SimpleAdapter

    概述

    SimpleAdapter是一种 简单的适配器,将静态数据映射到布局xml对应的视图上。它也是BaseAdapter的子类。

    SimpleAdapter数据映射的组件有3类(从官网api或SimpleAdapter源码中的bindView方法中都能看出来):Checkable(e.g. CheckBox), TextView, ImageView。

    下面的例子中就包含了这3类

    构造说明

    SimpleAdapter只有一个构造方法:

    SimpleAdapter(Context context, List<? extends Map<String, ?>> data, int resource, String[] from, int[] to)

    context:上下文

    data:数据源,一个包含Map的数据集合

    resource:item的布局文件

    from:数据来源的key的数组,与data的Map里的key对应

    to:  from中的每一项数据源 对应到的 item布局中对应组件的 id。

    四个参数的关系及表明了这种数据映射到布局的关系(如下绘制的简单示意图):data是数据源,包含所有数据,data中的每一项 是一个map;from是数据源中map中的key数组;to是item布局要填充的组件id的数组(这里的组件只能是上面提到的3种)。

    通过SimpleAdapter,数据被映射到对应的组件中,显示出来。下一项具体示例中有更好的体现

     具体示例说明

    下面具体示例,很清晰的可以看出SimpleAdapter数据映射过程和效果。

    先看下示例的效果图:

    下面是具体的代码

     activity布局:simple_adapter_act.xml

    这里仅定义了一个ListView用于显示

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <ListView
            android:id="@+id/simple_adapter_lv"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    </RelativeLayout>

    文本资源:

    Strings:
        <array name="anime_name">
            <item>海贼王</item>
            <item>进击的巨人</item>
            <item>火影忍者</item>
            <item>斩赤红之瞳</item>
            <item>秦时明月</item>
            <item>西游记</item>
            <item>葫芦娃</item>
        </array>
    
        <array name="anime_author">
            <item>尾田荣一郎</item>
            <item>谏山创</item>
            <item>岸本齐史</item>
            <item>タカヒロ</item>
            <item>玄机科技</item>
            <item>央视</item>
            <item>上海美术电影</item>
        </array>
    
    Colors:/赤橙黄绿青蓝紫
        <color name="love_red">#FF0000</color>
        <color name="love_orange">#FF7F00</color>
        <color name="love_yellow">#FFFF00</color>
        <color name="love_green">#00FF00</color>
        <color name="love_blue_green">#00FFFF</color>
        <color name="love_blue">#0000FF</color>
        <color name="love_purple">#8B00FF</color>

    SimpleAdapter的resouce布局,及item layout:  sasimple_adapter_item.xml

    这里定义了5个组件,SimpleAdapter会将这些填充数据,2个TextView 2个ImageView 1个CheckBox.

    <?xml version="1.0" encoding="utf-8"?>
    <!--android:descendantFocusability 避免CheckBox抢占焦点添加-->
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:descendantFocusability="blocksDescendants"
        android:layout_width="match_parent"
        android:layout_height="70dp">
        <ImageView android:id="@+id/anime_cover_img"
            android:layout_alignParentLeft="true"
            android:layout_centerVertical="true"
            android:layout_marginLeft="10dp"
            android:layout_width="60dp"
            android:scaleType="fitCenter"
            android:layout_height="60dp" />
    
        <LinearLayout
            android:layout_toRightOf="@id/anime_cover_img"
            android:layout_width="150dp"
            android:layout_height="match_parent"
            android:layout_marginLeft="10dp"
            android:layout_marginRight="10dp"
            android:orientation="vertical" >
    
            <TextView
                android:id="@+id/anime_name_txt"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:gravity="center_vertical"
                android:textStyle="bold"
                android:layout_weight="1" />
    
            <TextView android:id="@+id/anime_author_txt"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:gravity="center_vertical"
                android:textStyle="italic"
                android:layout_weight="1"/>
        </LinearLayout>
    
        <ImageView
            android:id="@+id/anime_likecolor_img"
            android:layout_toLeftOf="@id/anime_checkbox"
            android:layout_width="60dp"
            android:layout_height="60dp"
            android:layout_centerVertical="true"
            android:layout_marginRight="10dp" />
    
        <CheckBox android:id="@+id/anime_checkbox"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:layout_centerVertical="true" />
    </RelativeLayout>

    最终的,SimpleAdapter的使用:SimpleAdapterActivity.java

    package com.flx.adaptertest.simpleadapter;
    
    import android.app.Activity;
    import android.content.res.Resources;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    import android.widget.AdapterView;
    import android.widget.CheckBox;
    import android.widget.ListView;
    import android.widget.SimpleAdapter;
    import com.flx.adaptertest.R;
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    
    public class SimpleAdapterActivity extends Activity {
        private static final String TAG = "SimpleAdapterActivity";
        private static final String ANIME_NAME = "anime_name";
        private static final String ANIME_AUTHOR = "anime_author";
        private static final String ANIME_COVERIMG = "anime_coverimg";
        private static final String ANIME_LIKECOLOR = "anime_likecolor";
        private static final String ANIME_CHECKBOX = "anime_checkbox";
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate( savedInstanceState );
            setContentView( R.layout.simple_adapter_act );
            ListView listView = findViewById( R.id.simple_adapter_lv );
            listView.setOnItemClickListener( new AdapterView.OnItemClickListener() {
                @Override
                public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                    Log.d( TAG, "onItemClick: position="+ position + ";text=" + parent.getItemAtPosition(position).toString()
                        +";CheckBox changed="+((CheckBox)view.findViewById(R.id.anime_checkbox)).isChecked());
                }
            } );
            
            List<Map<String, Object>> datas = new ArrayList<>();
            Resources resources = this.getResources();
            String[] anime_names = resources.getStringArray( R.array.anime_name );
            String[] anime_authors = resources.getStringArray( R.array.anime_author );
            int[] coverImgs = {R.drawable.hzw1, R.drawable.jjdjr1, R.drawable.hyrz1,
                    R.drawable.zchzt1, R.drawable.qsmy1, R.drawable.xyj1, R.drawable.hlw1};
            int[] senvenColors = {R.color.love_red, R.color.love_orange, R.color.love_yellow,R.color.love_green,
                    R.color.love_blue_green, R.color.love_blue,R.color.love_purple};
            boolean[] anime_checkbox = {true, true, false, false, true, false, true};
            for (int i = 0; i < anime_names.length; i++) {
                Map<String, Object> map = new HashMap<>();
                map.put(ANIME_COVERIMG, coverImgs[i]);
                map.put(ANIME_NAME, anime_names[i]);
                map.put(ANIME_AUTHOR, anime_authors[i]);
                map.put(ANIME_LIKECOLOR, senvenColors[i]);
                map.put(ANIME_CHECKBOX, anime_checkbox[i]);
                datas.add(map);
            }
            String[] from = {ANIME_COVERIMG, ANIME_NAME, ANIME_AUTHOR, ANIME_LIKECOLOR,ANIME_CHECKBOX};
            int[] to = {R.id.anime_cover_img, R.id.anime_name_txt, R.id.anime_author_txt, R.id.anime_likecolor_img, R.id.anime_checkbox};
            SimpleAdapter simpleAdapter = new SimpleAdapter( this, datas, R.layout.simple_adapter_item, from, to );
            listView.setAdapter(simpleAdapter);
        }
    }

     看下点击效果:

    点击第一项看到log

    2019-11-25 14:27:06.254 9363-9363/com.flx.adaptertest D/SimpleAdapterActivity: onItemClick: position=0;text={anime_name=海贼王, 
    anime_likecolor=2131034168, anime_checkbox=true, anime_author=尾田荣一郎, anime_coverimg=2131165272};CheckBox changed=true
    

    点击第一项中的checkbox,去掉勾选后,再点击第一项看到的log

    2019-11-25 14:29:02.631 9363-9363/com.flx.adaptertest D/SimpleAdapterActivity: onItemClick: position=0;text={anime_name=海贼王, 
    anime_likecolor=2131034168, anime_checkbox=true, anime_author=尾田荣一郎, anime_coverimg=2131165272};CheckBox changed=false
    

    注意到CheckBox值的变化了吗,整个item中看到的anime_checkbox值并没有变化。个人理解是 将静态数据映射到视图,绑定到视图时已经值已经确定了,点击checkbox,视图数据并没有刷新,所以可以通过view获取checkbox获取状态。

     

  • 相关阅读:
    #Responsive# 响应式图片//www.w3cplus.com/blog/tags/509.html 整个系列完结。
    用js实现帧动画
    js判断对象是否存在
    canvas
    函数的四种调用模式
    递归真的好难啊!!! 看完之后好多了
    词法作用域
    变量名提升
    ajax调用后台Java
    左图又文字自适应
  • 原文地址:https://www.cnblogs.com/fanglongxiang/p/11910455.html
Copyright © 2011-2022 走看看