被這幾句困擾好久,不知道是什麼意思,先看一下所謂的這幾句

public class MainActivity extends Activity {
    TextView tv;
    ListView lv;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
          super.onCreate(savedInstanceState);
          LinearLayout ll = new LinearLayout(this);
          ll.setOrientation(LinearLayout.VERTICAL);
          setContentView(ll);

          tv = new TextView(this);
          tv.setText("歡迎光臨");

          lv = new ListView(this);
          String[] str = {"1號房","2號房","3號房","4號房","5號房","6號房"};
          ArrayAdapter<String> ad = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,str);
          lv.setAdapter(ad);

          ll.addView(tv);
          ll.addView(lv);

          lv.setOnItemClickListener(new ClickListener());
}

class ClickListener implements OnItemClickListener{
    public void onItemClick(AdapterView<?> parent, View v, int pos, long id){
         TextView tmp = (TextView) v;
         tv.setText(tmp.getText());
    }
}

其實主要就是黃色的這二行我對於ArrayAdapter<String>及onItemClick(AdapterView<?> parent, View v, int pos, long id)不知道是什麼意思,找了一下文件和大家分享

android reference http://developer.android.com/intl/zh-tw/reference/android/widget/AdapterView.OnItemClickListener.html

主要說明如下

onItemClick(AdapterView<?> parent, View view, int position, long id)

Parameters
parent The AdapterView where the click happened.
view The view within the AdapterView that was clicked (this will be a view provided by the adapter)
position The position of the view in the adapter.
id The row id of the item that was clicked.

另外找了一篇文章,有更深入的解說,轉載自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<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);
    }
}

   ◆结果

 

 

 

arrow
arrow
    創作者介紹
    創作者 痞客興 的頭像
    痞客興

    痞客興的部落格

    痞客興 發表在 痞客邦 留言(0) 人氣()