在J2EE中提供过一种非常好的框架--MVC框架,实现原理:数据模型M(Model)存放数据,利用控制器C(Controller)将数据显示在视图V(View)上。在Android中有这样一种高级控件,他的实现过程就类似于MVC框架。之所以称它高级,是因为他的使用不像其他控件一样,拖拽到界面上就能用,而是需要通过适配器将某些样式的数据或控件添加到其上而使用,这样的控件就是我们今天要说的AdapterView。

一:AdapterView-->V(视图)

  1:作用

  以列表的形式显示数据

  2: 内容

  AdapterView的内容一般是包含多项相同格式资源的列表

  3:特点

 (1)将前端显示和后端数据分离

 (2)内容不能通过ListView.add的形式添加列表项,需指定一个Adapter对象,通过它获得显示数据

 (3)ListView相当于MVC框架中的V(视图)

(4)Adapter相当于MVC框架中的C(控制器)

 (5)数据源相当于MVC框架中的M(模型)

(6)超出屏幕显示之后,自动加上滚动条

  4:分类

 (1)ListView:列表,其中只能含有一个控件TextView,

 (2)Spinner:下拉列表,给用户提供选择

 (3)Gallery:缩略图,已经被水平的ScrollView和ViewPicker取代,但也还算常用,是一个可以把子项以中心锁定,水平滚动的列表

 (4)GridView:网格图,以表格形式显示资源,可以左右滑动的

  5:事件

 (1)用户单击列表项事件

  ◆为列表加载setOnItemClieckListener监听,重写onItemClick(发生单击事件的列表对象ListView,被单击控件对象view,在列表中的位置position,被单击列表项的行ID)方法。

 (2)用户长按事件

  ◆为列表加载setOnItemLongClieckListener监听,重写onItemLongClick(发生单击事件的列表对象ListView,被单击控件对象view,在列表中的位置position,被单击列表项的行ID)方法。

  6:数据填充

  借助下面的Adapter适配器对象从数据源中进行适配

二:Adapter-->C(控制器)

  1:作用

  把数据源中数据以某种样式(xml文件)显示在视图中。

  2:分类

 (1)ArrayAdapter:他只能处理列表项内容全是文本的情况。

  ◆数据源:数组或者List<String>对象或者其他

 (2)SimpleAdapter: 他不仅可以处理列表项全是文本的情况,当列表项中还有其他控件时,同样可以处理。

   ◆数据源:只能为List<Map<“键”,“值”>>形式的数据

 (3)自定义Adapter:根据xml文件中定义的样式惊醒列表项的填充,适用性最强。

 (4)SimpleCursorAdapter:专门用于把游标中的数据映像到列表中(我们以后再来研究)

  3:自定义Adapter

  (1)创建类,继承自BaseAdapter

  (2)重写其中的四个方法

  ①int getCount():返回的是数据源对象的个数,即列表项数

  ②Object getItem(int position):返回指定位置position上的列表

  ③long getItemId(int position):返回指定位置处的行ID

  ④View getView():返回列表项对应的视图,方法体中

  ◆实例化视图填充器

  ◆用视图填充器,根据Xml文件,实例化视图

  ◆根据布局找到控件,并设置属性

  ◆返回View视图

三:数据填充

  1:声明AdapterView对象,根据ID利用findViewById方法找到此对象

  2:声明Adapter对象,根据构造方法实例化此对象。具体如下:

  (1)ArrayAdapter<数据类型> adapter = new ArrayAdapter<数据类型>(context:一般指当前Activity对象,layout:每个列表项显示的布局,data:数据源变量);

  (2)SimpleAdapter adapter = new SimpleAdapter(context:一般指当前Activity对象,data:数据源变量,layout:每个列表项显示的布局,new String[]{}:数据源中的“键”,new int[]{}:显示数据源的控件ID);

  (3)自定义Adapter类 adapter = new 自定义Adapter类构造方法;

  3:绑定Adapter对象到Adapter上

  AdapterView对象.setAdapter(Adapter对象);

四:具体应用

1:用ArrayAdapter填充ListView

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
public class MainActivity extends Activity {
    private ListView lv;// 适配器控件------->V视图
    private ArrayAdapter<String> adapter;// 适配器------>C控制器
    private String[] data = { "我是第1个列表项""我是第2个列表项""我是第3个列表项""我是第4个列表项",
            "我是第5个列表项""我是第6个列表项""我是第7个列表项" };// 数据源-->M
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //找到ListView
        lv = (ListView) findViewById(R.id.listView1);
        // 实现适配器,利用系统定义的样式,加载数据源
        adapter = new ArrayAdapter<String>(this,
                android.R.layout.simple_list_item_1, data);
        // R.layout.cell 自己定义视图
        // android.R.layout.simple_list_item_1 系统定义视图样式
        // 绑定适配器到适配器控件上
        lv.setAdapter(adapter);
        //处理单击事件:列表项被单击时给出提示信息
        lv.setOnItemClickListener(new OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view,
                    int position, long id) {
                Toast.makeText(MainActivity.this,
                        "第" + (position + 1) + "项被单击按下", Toast.LENGTH_LONG)
                        .show();
            }
        });
        //处理长时间按下事件:列表项被长时间按下时给出提示信息
        lv.setOnItemLongClickListener(new OnItemLongClickListener() {
            @Override
            public boolean onItemLongClick(AdapterView<?> parent, View view,
                    int position, long id) {
                Toast.makeText(MainActivity.this,
                        "第" + (position + 1) + "项被长时间按下", Toast.LENGTH_LONG)
                        .show();
                return true;
            }
        });
    }
}

结果:

2:用SimpleAdapter填充Spinner

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
public class MainActivity extends Activity {
    //声明Spinner
    private Spinner sp;
    //声明Adapter
    private SimpleAdapter adapter;
    //数据源
    private String[] data = { "我是第1个列表项""我是第2个列表项""我是第3个列表项""我是第4个列表项",
            "我是第5个列表项""我是第6个列表项""我是第7个列表项""我是第8个列表项""我是第9个列表项" };// 数据源-->M
    //存放数据源
    ArrayList<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //找到Spinner
        sp = (Spinner) findViewById(R.id.spinner1);
        //将数据添加到List<Map>中,因为SimpleAdapter只能装这样的数据
        Map<String, Object> map;
        for (int i = 0; i < data.length; i++) {
            map = new HashMap<String, Object>();
            map.put("data", data[i]);
            list.add(map);
        }
        //实例化Adapter
        adapter = new SimpleAdapter(this, list, R.layout.cell, new String[] {
                "data"},
                new int[] { R.id.textView1 });
        //绑定Adapter到Spinner上
        sp.setAdapter(adapter);
    }
}

结果:

3:用SimpleAdapter填充GridView

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
public class MainActivity extends Activity {
    //声明GridView
    private GridView gv;
    //声明SimpleAdapter
    private SimpleAdapter adapter;
    //数据源
    private int imageids[] = { R.drawable.item1, R.drawable.item2,
            R.drawable.item3, R.drawable.item4, R.drawable.item5,
            R.drawable.item6, R.drawable.item7, R.drawable.item8,
            R.drawable.item9, R.drawable.item10, R.drawable.item11,
            R.drawable.item12, R.drawable.item13, R.drawable.item14,
            R.drawable.item15 };
    private String data[] = { "1""2""3""4""5""6""7""8""9",
            "10""11""12""13""14""15" };
    //存放数据
    private List<Map<String, Object>> lists;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //找到GridView
        gv = (GridView) findViewById(R.id.gridView1);
        //封装数据到List上
        lists = new ArrayList<Map<String, Object>>();
        Map<String, Object> maps;
        for (int i = 0; i < imageids.length; i++) {
            maps = new Hashtable<String, Object>();
            maps.put("image", imageids[i]);
            maps.put("data", data[i]);
            lists.add(maps);
        }
        //适配数据到适配器上
        adapter = new SimpleAdapter(this, lists, R.layout.cell, new String[] {
                "image""data" },
                new int[] { R.id.imageView1, R.id.textView1 });
        //绑定适配器到GridView上
        gv.setAdapter(adapter);
                                                      
                                                      
                                                      
    }
}

结果:

4:自定义AdapterView填充Gallery

◆自定义Adapter

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
//自定义Adapter
public class MyAdapter extends BaseAdapter {
    //上下文
    private Context context;
    //资源
    private int imageids[];
    //构造方法
    public MyAdapter(Context context, int imageids[]) {
        this.context = context;
        this.imageids = imageids;
    }
    //返回数据源长度
    @Override
    public int getCount() {
        return imageids.length;
    }
    //返回对应位置处的数据
    @Override
    public Object getItem(int position) {
        return imageids[position];
    }
    //返回对应位置的行ID
    @Override
    public long getItemId(int position) {
        return position;
    }
    //返回列表项的显示样式视图
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        //ImageView控件
        ImageView iv = new ImageView(context);
        //添加资源到控件上
        iv.setImageResource(imageids[position]);
        //控件在父级控件的显示样式
        iv.setLayoutParams(new Gallery.LayoutParams(LayoutParams.FILL_PARENT,
                LayoutParams.FILL_PARENT));
        //返回视图
        return iv;
    }
}

◆主视图

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public class MainActivity extends Activity {
    //声明Gallery
    private Gallery gy;
    //声明自定义Adapter
    private MyAdapter adapter;
    //数据源
    private int imageids[] = { R.drawable.w1,R.drawable.q1, R.drawable.q2, R.drawable.q3,
            R.drawable.q4, R.drawable.q5, R.drawable.q6, R.drawable.q7, R.drawable.q8, R.drawable.q9 };
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //找到Gallery
        gy = (Gallery) findViewById(R.id.gy);
        //实例化适配器
        adapter = new MyAdapter(this, imageids);
        //绑定适配器到Gallery上
        gy.setAdapter(adapter);
    }
}

◆结果

本文转自:http://cinderella7.blog.51cto.com/7607653/1281696

Android高级控件--AdapterView与Adapter的更多相关文章

  1. Android高级控件(一)——ListView绑定CheckBox实现全选,增加和删除等功能

    Android高级控件(一)--ListView绑定CheckBox实现全选,增加和删除等功能 这个控件还是挺复杂的,也是项目中应该算是比较常用的了,所以写了一个小Demo来讲讲,主要是自定义adap ...

  2. Android高级控件(一)——ListView绑定CheckBox实现全选,添加和删除等功能

    Android高级控件(一)--ListView绑定CheckBox实现全选,添加和删除等功能 这个控件还是挺复杂的.也是项目中应该算是比較经常使用的了,所以写了一个小Demo来讲讲,主要是自己定义a ...

  3. Android 高级控件(七)——RecyclerView的方方面面

    Android 高级控件(七)--RecyclerView的方方面面 RecyclerView出来很长时间了,相信大家都已经比较了解了,这里我把知识梳理一下,其实你把他看成一个升级版的ListView ...

  4. Android高级控件(六)——自定义ListView高仿一个QQ可拖拽列表的实现

    Android高级控件(六)--自定义ListView高仿一个QQ可拖拽列表的实现 我们做一些好友列表或者商品列表的时候,居多的需求可能就是需要列表拖拽了,而我们选择了ListView,也是因为使用L ...

  5. Android高级控件(五)——如何打造一个企业级应用对话列表,以QQ,微信为例

    Android高级控件(五)--如何打造一个企业级应用对话列表,以QQ,微信为例 看标题这么高大上,实际上,还是运用我么拿到listview去扩展,我们讲什么呢,就是研究一下QQ,微信的这种对话列表, ...

  6. Android高级控件(四)——VideoView 实现引导页播放视频欢迎效果,超级简单却十分的炫酷

    Android高级控件(四)--VideoView 实现引导页播放视频欢迎效果,超级简单却十分的炫酷 是不是感觉QQ空间什么的每次新版本更新那炫炫的引导页就特别的激动,哈哈,其实他实现起来真的很简单很 ...

  7. Android高级控件(三)—— 使用Google ZXing实现二维码的扫描和生成相关功能体系

    Android高级控件(三)-- 使用Google ZXing实现二维码的扫描和生成相关功能体系 摘要 现在的二维码可谓是烂大街了,到处都是二维码,什么都是二维码,扫一扫似乎已经流行到习以为常了,今天 ...

  8. Android高级控件(二)——SurfaceView实现GIF动画架包,播放GIF动画,自己实现功能的初体现

    Android高级控件(二)--SurfaceView实现GIF动画架包,播放GIF动画,自己实现功能的初体现 写这个的原因呢,也是因为项目中用到了gif动画,虽然网上有很多的架包可以实现,不过我们还 ...

  9. Android高级控件(三)——&#160;使用Google ZXing实现二维码的扫描和生成相关功能体系

    Android高级控件(三)-- 使用Google ZXing实现二维码的扫描和生成相关功能体系 摘要 如今的二维码可谓是烂大街了.到处都是二维码.什么都是二维码,扫一扫似乎已经流行到习以为常了,今天 ...

随机推荐

  1. Android 自定义View (五)——实践

    前言: 前面已经介绍了<Android 自定义 view(四)-- onMeasure 方法理解>,那么这次我们就来小实践下吧 任务: 公司现有两个任务需要我完成 (1)监测液化天然气液压 ...

  2. Python快速建站系列-Part.Six-文章内容浏览

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 其实到这里网站的基本功能已经完成一半了,第六节就完成文章内容的阅读功能. 完成blogview.html↓ {% extends "m ...

  3. 数据绑定控件之Repeater

    引言 前几篇的文章在说AJAX的内容,利用AJAX技术能够开发出高效运行的网站应用程序,不过在进行B/S项目开发时只拥有AJAX技术是远远不够的,踏入到B/S要学的东西会更多,但相较C/S的复杂逻辑结 ...

  4. js和jq添加新表格

    javascript动态实现表格: function createTable(rowCount,cellCount){ var table = document.createElement('tabl ...

  5. [Silverlight]监听指定控件(FrameworkElement)的依赖属性(DependencyProperty)的更改

    前言 转载请注明出处:http://www.cnblogs.com/ainijiutian 最近在silverlight项目使用Telerik的控件,遇到一个问题.就是使用RadBusyIndicat ...

  6. include与require的区别?

    require()语句的性能与include()相类似,都是包括并运行指定文件.不同之处在于:对include()语句来说,在执行文件时每次都要进行读取和评估:而对于require()来说,文件只处理 ...

  7. SQL常用语句整理

    有次笔试最后一页的三个数据库连接查询,没有写出来,被考官暗讽了下.现在想来,实习初,确实很LOW.现公司刚入职的时候,负责过ETL方面,所以和数据库打了不少交道,五十行的联合查询.上百行的存储过程很常 ...

  8. DNS

  9. if语句的一个小技巧

    也就是说选中类型的时候边框属性的选择项是不能选择的一般用if else 在类型的CHANGE方法中,现在一句话就能搞定看代码 private void m_rdbtnProID2_CheckedCha ...

  10. MVC5路由系统机制详细讲解

    请求一个ASP.NET mvc的网站和以前的web form是有区别的,ASP.NET MVC框架内部给我们提供了路由机制,当IIS接受到一个请求时,会先看是否请求了一个静态资源(.html,css, ...