Android中的Adapter 详解(四)

下面的列表显示了两个最有用和最通用的本地Adapter:

❑ ArrayAdapter
ArrayAdapter是一个绑定View到一组对象的通用类。默认情况下,ArrayAdapter绑定每个对象的toString值到在layout中预先定义的TextView控件上。可变通的,构造函数允许你使用更加复杂的layout或者通过重写getView方法来扩展类从而使用TextView的替代物(如ImageView或嵌套的layout)。

❑ SimpleCursorAdapter
SimpleCursorAdapter绑定View到Content Provider查询返回的游标上。指定一个XML layout定义,然后将数据集中的每一列的值绑定到layout中的一个View上。

下面演示一下SimpleAdapter的用法:

package com.wt.app;  
  
import java.util.ArrayList;  
import java.util.HashMap;  
  
import android.app.Activity;  
import android.os.Bundle;  
import android.view.ContextMenu;  
import android.view.MenuItem;  
import android.view.View;  
import android.view.ContextMenu.ContextMenuInfo;  
import android.view.View.OnCreateContextMenuListener;  
import android.widget.AdapterView;  
import android.widget.ListView;  
import android.widget.SimpleAdapter;  
import android.widget.AdapterView.OnItemClickListener;  
  
public class App extends Activity {  
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.main);  
        //绑定Layout里面的ListView  
        ListView list = (ListView) findViewById(R.id.ListView01);  
          
        //生成动态数组,加入数据  
        ArrayList<HashMap<String, Object>> listItem = new ArrayList<HashMap<String, Object>>();  
        int[] images=new int[]{android.R.drawable.ic_menu_add,android.R.drawable.ic_menu_delete,android.R.drawable.ic_menu_edit,android.R.drawable.ic_menu_view};  
        for(int i=0;i<4;i++)  
        {  
            HashMap<String, Object> map = new HashMap<String, Object>();  
            map.put("itemImage", images[i]);//图像资源的ID  
            map.put("itemTitle", "Title "+i);  
            map.put("itemText", "this is Text "+i);  
            listItem.add(map);  
        }  
        //生成适配器的Item和动态数组对应的元素  
        SimpleAdapter listItemAdapter = new SimpleAdapter(this,listItem,//数据源   
            R.layout.row,//ListItem的XML实现  
            //动态数组与ImageItem对应的子项          
            new String[] {"itemImage","itemTitle", "itemText"},   
            //ImageItem的XML文件里面的一个ImageView,两个TextView ID  
            new int[] {R.id.itemImage,R.id.itemTitle,R.id.itemText}  
        );  
         <span id="transmark"></span>
        //添加并且显示  
        list.setAdapter(listItemAdapter);  
        //添加点击  
        list.setOnItemClickListener(new OnItemClickListener() {  
  
            public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,  
                    long arg3) {  
                setTitle("点击第"+arg2+"个项目");  
            }  
        });  
          
      //添加长按点击  
        list.setOnCreateContextMenuListener(new OnCreateContextMenuListener() {  
              
            public void onCreateContextMenu(ContextMenu menu, View v,ContextMenuInfo menuInfo) {  
                menu.setHeaderTitle("长按菜单-ContextMenu");     
                menu.add(0, 0, 0, "弹出长按菜单0");  
                menu.add(0, 1, 0, "弹出长按菜单1");     
            }  
        });   
    }  
      
    //长按菜单响应函数  
    @Override  
    public boolean onContextItemSelected(MenuItem item) {  
        setTitle("点击了长按菜单里面的第"+item.getItemId()+"个项目");   
        return super.onContextItemSelected(item);  
    }  
}  


整体布局文件,一个简单的ListView:
XML文件:
<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"  
    >  
    <ListView android:layout_width="wrap_content"     
          android:layout_height="wrap_content"     
          android:id="@+id/ListView01"    
    />    
</LinearLayout>  

ListView中每行(row)怎么显示的布局文件:
XML文件:

<?xml version="1.0" encoding="utf-8"?>  
<RelativeLayout   
    android:id="@+id/RelativeLayout01"   
    android:layout_width="fill_parent"   
    xmlns:android="http://schemas.android.com/apk/res/android"   
    android:layout_height="wrap_content"   
    android:paddingTop="4dip"   
    android:paddingBottom="4dip"   
    android:paddingLeft="12dip"  
    android:paddingRight="12dip">  
<ImageView   
    android:paddingTop="12dip"  
    android:layout_alignParentRight="true"  
    android:layout_width="wrap_content"   
    android:layout_height="wrap_content"   
    android:id="@+id/itemImage"  
    />   
<TextView   
    android:layout_height="wrap_content"   
    android:textSize="20dip"   
    android:layout_width="fill_parent"   
    android:id="@+id/itemTitle"  
    />  
<TextView   
    android:layout_height="wrap_content"   
    android:layout_width="fill_parent"   
    android:layout_below="@+id/itemTitle"   
    android:id="@+id/itemText"  
    />  
</RelativeLayout>  


下面演示了BaseExpandableListAdapter的用法:
JAVA代码:
/* 
 * Copyright (C) 2007 The Android Open Source Project 
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"); 
 * you may not use this file except in compliance with the License. 
 * You may obtain a copy of the License at 
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0 
 * 
 * Unless required by applicable law or agreed to in writing, software 
 * distributed under the License is distributed on an "AS IS" BASIS, 
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
 * See the License for the specific language governing permissions and 
 * limitations under the License. 
 */  
  
package com.example.android.apis.view;  
  
import android.app.ExpandableListActivity;  
import android.os.Bundle;  
import android.view.ContextMenu;  
import android.view.Gravity;  
import android.view.MenuItem;  
import android.view.View;  
import android.view.ViewGroup;  
import android.view.ContextMenu.ContextMenuInfo;  
import android.widget.AbsListView;  
import android.widget.BaseExpandableListAdapter;  
import android.widget.ExpandableListAdapter;  
import android.widget.ExpandableListView;  
import android.widget.TextView;  
import android.widget.Toast;  
import android.widget.ExpandableListView.ExpandableListContextMenuInfo;  
  
import com.example.android.apis.R;  
  
/** 
 * Demonstrates expandable lists using a custom {@link ExpandableListAdapter} 
 * from {@link BaseExpandableListAdapter}. 
 */  
public class ExpandableList1 extends ExpandableListActivity {  
  
    ExpandableListAdapter mAdapter;  
  
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
  
        // Set up our adapter  
        mAdapter = new MyExpandableListAdapter();  
        setListAdapter(mAdapter);  
        registerForContextMenu(getExpandableListView());  
    }  
  
    @Override  
    public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) {  
        menu.setHeaderTitle("Sample menu");  
        menu.add(0, 0, 0, R.string.expandable_list_sample_action);  
    }  
      
    @Override  
    public boolean onContextItemSelected(MenuItem item) {  
        ExpandableListContextMenuInfo info = (ExpandableListContextMenuInfo) item.getMenuInfo();  
  
        String title = ((TextView) info.targetView).getText().toString();  
          
        int type = ExpandableListView.getPackedPositionType(info.packedPosition);  
        if (type == ExpandableListView.PACKED_POSITION_TYPE_CHILD) {  
            int groupPos = ExpandableListView.getPackedPositionGroup(info.packedPosition);   
            int childPos = ExpandableListView.getPackedPositionChild(info.packedPosition);   
            Toast.makeText(this, title + ": Child " + childPos + " clicked in group " + groupPos,  
                    Toast.LENGTH_SHORT).show();  
            return true;  
        } else if (type == ExpandableListView.PACKED_POSITION_TYPE_GROUP) {  
            int groupPos = ExpandableListView.getPackedPositionGroup(info.packedPosition);   
            Toast.makeText(this, title + ": Group " + groupPos + " clicked", Toast.LENGTH_SHORT).show();  
            return true;  
        }  
          
        return false;  
    }  
  
    /** 
     * A simple adapter which maintains an ArrayList of photo resource Ids.  
     * Each photo is displayed as an image. This adapter supports clearing the 
     * list of photos and adding a new photo. 
     * 
     */  
    public class MyExpandableListAdapter extends BaseExpandableListAdapter {  
        // Sample data set.  children[i] contains the children (String[]) for groups[i].  
        private String[] groups = { "People Names", "Dog Names", "Cat Names", "Fish Names" };  
        private String[][] children = {  
                { "Arnold", "Barry", "Chuck", "David" },  
                { "Ace", "Bandit", "Cha-Cha", "Deuce" },  
                { "Fluffy", "Snuggles" },  
                { "Goldy", "Bubbles" }  
        };  
          
        public Object getChild(int groupPosition, int childPosition) {  
            return children[groupPosition][childPosition];  
        }  
  
        public long getChildId(int groupPosition, int childPosition) {  
            return childPosition;  
        }  
  
        public int getChildrenCount(int groupPosition) {  
            return children[groupPosition].length;  
        }  
  
        public TextView getGenericView() {  
            // Layout parameters for the ExpandableListView  
            AbsListView.LayoutParams lp = new AbsListView.LayoutParams(  
                    ViewGroup.LayoutParams.MATCH_PARENT, 64);  
  
            TextView textView = new TextView(ExpandableList1.this);  
            textView.setLayoutParams(lp);  
            // Center the text vertically  
            textView.setGravity(Gravity.CENTER_VERTICAL | Gravity.LEFT);  
            // Set the text starting position  
            textView.setPadding(36, 0, 0, 0);  
            return textView;  
        }  
          
        public View getChildView(int groupPosition, int childPosition, boolean isLastChild,  
                View convertView, ViewGroup parent) {  
            TextView textView = getGenericView();  
            textView.setText(getChild(groupPosition, childPosition).toString());  
            return textView;  
        }  
  
        public Object getGroup(int groupPosition) {  
            return groups[groupPosition];  
        }  
  
        public int getGroupCount() {  
            return groups.length;  
        }  
  
        public long getGroupId(int groupPosition) {  
            return groupPosition;  
        }  
  
        public View getGroupView(int groupPosition, boolean isExpanded, View convertView,  
                ViewGroup parent) {  
            TextView textView = getGenericView();  
            textView.setText(getGroup(groupPosition).toString());  
            return textView;  
        }  
  
        public boolean isChildSelectable(int groupPosition, int childPosition) {  
            return true;  
        }  
  
        public boolean hasStableIds() {  
            return true;  
        }  
  
    }  
}  

SimpleCursorTreeAdapter用法:
JAVA代码:

/* 
 * Copyright (C) 2007 The Android Open Source Project 
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"); 
 * you may not use this file except in compliance with the License. 
 * You may obtain a copy of the License at 
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0 
 * 
 * Unless required by applicable law or agreed to in writing, software 
 * distributed under the License is distributed on an "AS IS" BASIS, 
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
 * See the License for the specific language governing permissions and 
 * limitations under the License. 
 */  
  
package com.example.android.apis.view;  
  
import android.app.ExpandableListActivity;  
import android.content.ContentUris;  
import android.content.Context;  
import android.database.Cursor;  
import android.net.Uri;  
import android.os.Bundle;  
import android.provider.Contacts.People;  
import android.widget.ExpandableListAdapter;  
import android.widget.SimpleCursorTreeAdapter;  
  
  
/** 
 * Demonstrates expandable lists backed by Cursors 
 */  
public class ExpandableList2 extends ExpandableListActivity {  
    private int mGroupIdColumnIndex;   
      
    private String mPhoneNumberProjection[] = new String[] {  
            People.Phones._ID, People.Phones.NUMBER  
    };  
  
      
    private ExpandableListAdapter mAdapter;  
      
  
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
  
        // Query for people  
        Cursor groupCursor = managedQuery(People.CONTENT_URI,  
                new String[] {People._ID, People.NAME}, null, null, null);  
  
        // Cache the ID column index  
        mGroupIdColumnIndex = groupCursor.getColumnIndexOrThrow(People._ID);  
  
        // Set up our adapter  
        mAdapter = new MyExpandableListAdapter(groupCursor,  
                this,  
                android.R.layout.simple_expandable_list_item_1,  
                android.R.layout.simple_expandable_list_item_1,  
                new String[] {People.NAME}, // Name for group layouts  
                new int[] {android.R.id.text1},  
                new String[] {People.NUMBER}, // Number for child layouts  
                new int[] {android.R.id.text1});  
        setListAdapter(mAdapter);  
    }  
  
    public class MyExpandableListAdapter extends SimpleCursorTreeAdapter {  
  
        public MyExpandableListAdapter(Cursor cursor, Context context, int groupLayout,  
                int childLayout, String[] groupFrom, int[] groupTo, String[] childrenFrom,  
                int[] childrenTo) {  
            super(context, cursor, groupLayout, groupFrom, groupTo, childLayout, childrenFrom,  
                    childrenTo);  
        }  
  
        @Override  
        protected Cursor getChildrenCursor(Cursor groupCursor) {  
            // Given the group, we return a cursor for all the children within that group   
  
            // Return a cursor that points to this contact's phone numbers  
            Uri.Builder builder = People.CONTENT_URI.buildUpon();  
            ContentUris.appendId(builder, groupCursor.getLong(mGroupIdColumnIndex));  
            builder.appendEncodedPath(People.Phones.CONTENT_DIRECTORY);  
            Uri phoneNumbersUri = builder.build();  
  
            // The returned Cursor MUST be managed by us, so we use Activity's helper  
            // functionality to manage it for us.  
            return managedQuery(phoneNumbersUri, mPhoneNumberProjection, null, null, null);  
        }  
  
    }  
}  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值