基础学习总结(五)---baseAdapter、ContentProvider

时间:2023-03-09 00:25:13
基础学习总结(五)---baseAdapter、ContentProvider

小写转大写 : ctrl+shift+F

<ScrollView></ScrollView>滚动条显示视图

ListView与BaseAdapter:

 public class MainActivity extends Activity {
private List<Person> pList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); ListView mlistview=(ListView)findViewById(R.id.listview);
//把view与适配器关联
mlistview.setAdapter(new MyAdapter());
} class MyAdapter extends BaseAdapter{ //获取view数据的长度
@Override
public int getCount() {
return pList.size();
} @Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return null;
} @Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return 0;
} //获得ListView中的某一行的view对象
//postion返回当前索引的位置
//convertView 缓存对象
//parent是listView对象
@Override
public View getView(int position, View convertView, ViewGroup parent) {
TextView tv=null;
if(convertView!=null){//判断缓存对象是否为空
tv=(TextView)convertView;
}else{//等于null程序刚加载,则创建
tv=new TextView(MainActivity.this);//类名.this ==上下文
}
Person p=pList.get(position);//获得指定位置的数据,进行对TextView绑定
tv.setText(p.toString());
return tv; } public View getView2(int position, View convertView, ViewGroup parent){
View view=null; if(convertView==null){
//布局填充器对象,用于把xml布局转换成view对象
LayoutInflater inflator= MainActivity2.this.getLayoutInflater();
view=inflator.inflate(R.layout.listview2_item, null);
}else{
view=convertView;
} //赋值
//。。。
return view;
}
}
}

ArrayAdapter与simpleAdapter:

 public class MainActivity extends Activity {

     @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); ListView mlistview=(ListView)findViewById(R.id.list_view); // ArrayAdapter适配器实例
String[] textArr={"a","b","c","d","e","f","g","h","i","t","z"};
//定义数据适配器
//用于显示简单的文本内容
//android.R.layout.simple_list_item_1 listview的子条目显示布局的id
//textArr 显示在list列表中的数据
ArrayAdapter<String> adapter=new ArrayAdapter<String>(this,
android.R.layout.simple_list_item_1,textArr);
mlistview.setAdapter(adapter); //context 上下文
//data List<Map<String,Object>> data
//resource listview子条目布局的id
//from data数据中的map集合里的key
//to resource中的id
//SimpleAdapter adp=new SimpleAdapter(context,data,resource,from,to);
List<Map<String,Object>> data=new ArrayList<Map<String,Object>>();
Map<String,Object> map=new HashMap<String,Object>();
map.put("name", "zhangsan1");
map.put("age", "17");
SimpleAdapter adp=new SimpleAdapter(this,data,R.layout.listview_item,
new String[]{"name","age"},new int[]{R.id.tv_name,R.id.tv_ico});
mlistview.setAdapter(adp);
} }

ContentProvider:内容提供者抽象类

因为在Android系统里面,数据库是私有的。一般情况下外部应用程序是没有权限读取其它应用程序的数据。如果想公开你自己的数据,有两个选择:可以创建你自己的内容提供器(一个ContentProvider子类)或者你可以给已有的提供器添加数据-如果存在一个控制同样类型数据的内容提供器且你拥有写的权限。而外界根本看不到,也不用看到这个应用暴露的数据在应用当中是如何存储的,或者是用数据库存储还是用文件存储,还是通过网上获得,这些一切都不重要,重要的是外界可以通过这一套标准及统一的接口和程序里的数据打交道,可以读取程序的数据,也可以删除程序的数据,当然,中间也会涉及一些权限的问题。

实现ContentProvider抽象类需要在配置文件中声明:

//并赋读写权限
<provider android:name=".provider.PersonContentProvider"
android:authorities="包名+类名" android:readPermission="随便.read"
android:writePermission="随便2.write" >
</provider>

声明权限还需要在manifest节点下添加:
<manifest>
<permission android:name="随便.read"></permission>
<permission android:name="随便2.write"></permission>
</manifest>
并在对应访问的工程的Manifest.xml中注册(不然无法访问被拒绝):
<uses permission android:name="随便.read" />
<uses permission android:name="随便2.write" />

 public class PersonContentProvider extends ContentProvider{
private static final String AUTHORITY="包名+类名";
private static final int PERSON_INSERT_CODE=0; //操作person表添加的操作uri匹配码
private Static final int PERSON_DELETE_CODE=1;
private Static final int PERSON_UPDATE_CODE=2;
private Static final int PERSON_QUERYALL_CODE=3;
private static UriMatcher uriMatcher; //Person表的数据库帮助对象
private PersonSQLiteOpenHelper mOpenHelper; static{
uriMatcher =new uriMatcher(UriMatcher.NO_MATH); //添加一些uri(分机号)
//content://包名+类名/person/insert
uriMatcher.addURI(AUTHORITY,"person/insert",PEROSON_INSERT_CODE);
uriMatcher.addURI(AUTHORITY,"person/delete",PERSON_DELETE_CODE);
uriMatcher.addURI(AUTHORITY,"person/update",PERSON_UPDATE_CODE);
uriMatcher.addURI(AUTHORITY,"person/queryall",PERSON_QUERYALL_CODE);
}
@override
public boolean onCreate(){
mOpenHelper=new PersonSQLiteOpenHelper(getContext());
} @override
public String getType(Uri uri){ } @override
public Uri insert(Uri uri,ContentValues values){
switch(uriMatcher.match(uri)){
case PEROSON_INSERT_CODE:
SQLiteDatabase db= mOpenHelper.getWriteableDatabase();
if(db.isopen()){
long id = db.insert("person",null,values);
db.close();
return contentUris.withAppendedId(uri,id);
}
break; default:
throw new IllegalArgumentException("uri不匹配":+uri);
}
return null;
} @override
public int delete(Uri uri,String selection,String[] selectionArgs){
//..
} @override
public int update(Uri uri,ConentValues values,String selection,String[] selectionArgs){
//...
} @override
public Curos query(Uri uri,String[] projection,String selection,String[] selectionArgs,String sortOrder){
Switch(uriMatcher.match(uri)){
case PERSON_QUERYALL_CODE:
SQLiteDatabase db=mOpenHelper.getReadableDatabase();
if(db.isopen()){
Cusor cor=db.query("person",projection,selection,selectionArgs,null,null,sortOrder);
return cor;
//db.close();返回cusor结果集时不可以关闭数据库
}
break;
default:
throw new IllegalArgumentException("uri不匹配:"+uri);
}
} } public class PersonContentResolver{
public void PersonInsert(){
Uri uri=Uri.Parser.("content://包名+类名/person/Insert"); //内容提供者对象
ContentResolver resolver = getContext().getContentResolver();
ContentValues values=new ContentValues();
value.put("name","小风");
value.put("age","19"); uri=resolver.insert(uri,values);
long id=ContentUris.parseId(uri);
log.i(tag,id);
} }