基础学习总结(五)---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);
}
}
基础学习总结(五)---baseAdapter、ContentProvider的更多相关文章
- C++基础 学习笔记五:重载之运算符重载
C++基础 学习笔记五:重载之运算符重载 什么是运算符重载 用同一个运算符完成不同的功能即同一个运算符可以有不同的功能的方法叫做运算符重载.运算符重载是静态多态性的体现. 运算符重载的规则 重载公式 ...
- salesforce 零基础学习(五十二)Trigger使用篇(二)
第十七篇的Trigger用法为通过Handler方式实现Trigger的封装,此种好处是一个Handler对应一个sObject,使本该在Trigger中写的代码分到Handler中,代码更加清晰. ...
- salesforce lightning零基础学习(十五) 公用组件之 获取表字段的Picklist(多语言)
此篇参考:salesforce 零基础学习(六十二)获取sObject中类型为Picklist的field values(含record type) 我们在lightning中在前台会经常碰到获取pi ...
- java基础学习笔记五(抽象类)
java基础学习总结——抽象类 抽象类介绍
- Java基础学习笔记(五) - 常用的API
API介绍 概念:API 即应用编程程序接口.Java API是JDK中提供给我们使用的类说明文档,这些类将底层的代码实现封装.无需关心这些类是如何实现,只需要学习如何使用. 使用:通过API找到需要 ...
- python 的基础 学习 第五天 基础数据类型的操作方法
1,列表的基本操作方法 1,列表是python中的基础数据类型之一,其他语言中也有类似于列表的数据类型,比如js中叫数组,他是以[ ]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如: ...
- salesforce 零基础学习(五十八)通过sObject的field返回其对应的基础类型
项目中有时候会要求通过sObject的Field的type类型返回其对应的基本类型,然后对其进行相关的处理,创建sObject的field可以选择的type类型是固定多的. 上述类型可以转换成几种基本 ...
- salesforce 零基础学习(五十三)多个文件生成一个zip文件(使用git上封装的代码)
此篇参考git代码:https://github.com/pdalcol/Zippex 学习salesforce可以访问一个朋友的网站:https://www.xgeek.net 首先感谢git上提供 ...
- javascript基础学习(五)
javascript之函数 学习要点: 函数的介绍 函数的参数 函数的属性和方法 系统函数 一.函数的介绍 1.函数就是一段javascript代码.可以分为用户自定义函数和系统函数. 如果一个函 ...
- Java基础学习笔记五 Java基础语法之面向对象
面向对象 理解什么是面向过程.面向对象 面向过程与面向对象都是我们编程中,编写程序的一种思维方式.面向过程的程序设计方式,是遇到一件事时,思考“我该怎么做”,然后一步步实现的过程.例如:公司打扫卫生( ...
随机推荐
- Xcode 8 用处不大的新特性:CLANG_WARN_INFINITE_RECURSION
来源:酷酷的哀殿 链接:http://www.jianshu.com/p/067f4674f75f Xcode 8 的 clang 新的警告控制,当所有路径都通过一个函数都调用自身时,会产生一个警告 ...
- C#面向对象(三)接口实现多态
一.如何用接口实现多态? 1.定义一个接口. using System; using System.Collections.Generic; using System.Linq; using Syst ...
- ios 画圆环进度条
#import <UIKit/UIKit.h> @interface SNCircleProgressView : UIView /** * 进度值0-1.0之间 */ @property ...
- 测试 IE 浏览器兼容性 VirtualBox + modern.ie
VirtualBox 是开源的虚拟机软件,常用的虚拟机软件还有 VMware / Hyper-V / Paralles Desktop . modern.ie 是微软官方提供的用于测试网页在各版本 I ...
- TFS 2010 使用手册(三)权限管理
本文参考了 蔚蓝的宁静 http://www.cnblogs.com/tymo/archive/2011/03/21/1990550.html 等文章. 1.权限说明 1.1 权限关联 TFS的权限与 ...
- MongoDB - MongoDB CRUD Operations, Query Documents, Project Fields to Return from Query
By default, queries in MongoDB return all fields in matching documents. To limit the amount of data ...
- UI设计之PS界面初始化设置
一.PS界面初始化 1.新建设置 web设计的基础标准:宽度为1920px,高度自定义,分辨率72px,背景模式RGB 8位.(提示:可以“存为预设”以便以后直接调用) 注意:背景内容为透明!!! ...
- CSS之上边栏
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- jQuery简介<思维导图>
jQuery是继prototype之后有一个优秀的Javascript库,它由John Resig创建于2006年1月.它简化了遍历HTML文档.操作DOM.处理事件.执行动画和Ajax的操作.它独特 ...
- 如何用ASP.NET实现bosh模拟http双向长连接请求
在做研究之前先简单说一下之前公司的通讯模块.最早的时候公司开发的web管理系统是需要配合c++桌面客户端进行一些系统底层操作,并非普通的b/s架构,或者c/s架构,因为需求是可以通过web管理系统向客 ...