Android高级控件----AdapterView与Adapter

原创作品,允许转载,转载时请务必以超链接形式标明文章  原始出处 、作者信息和本声明。否则将追究法律责任。 http://cinderella7.blog.51cto.com/7607653/1281696

        在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对象或者其他

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

       ◆数据源:只能为List>形式的数据

(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 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( 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 ;
             }
         });
     }
}

   结果:

Android高级控件----AdapterView与Adapter_第1张图片

   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> list =  new  ArrayList>();
     @Override
     protected  void  onCreate(Bundle savedInstanceState) {
         super .onCreate(savedInstanceState);
         setContentView(R.layout.activity_main);
         //找到Spinner
         sp = (Spinner) findViewById(R.id.spinner1);
         //将数据添加到List中,因为SimpleAdapter只能装这样的数据
         Map map;
         for  ( int  i =  0 ; i < data.length; i++) {
             map =  new  HashMap();
             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);
     }
}

   结果:

Android高级控件----AdapterView与Adapter_第2张图片

   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> 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 maps;
         for  ( int  i =  0 ; i < imageids.length; i++) {
             maps =  new  Hashtable();
             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);
                                                      
                                                      
                                                      
     }
}

  结果:

Android高级控件----AdapterView与Adapter_第3张图片

   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);
     }
}

   ◆结果


Android高级控件----AdapterView与Adapter_第4张图片

   还有一种SimpleCursorAdapter由于和数据库相关,我们以后在研究,这里只是介绍了AdapterView与Adapter之间的相互关系与使用,应该熟练掌握哦。。。Fighting


本文出自 “辛德瑞拉” 博客,请务必保留此出处http://cinderella7.blog.51cto.com/7607653/1281696

你可能感兴趣的:(界面,Android)