小写转大写 : 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的更多相关文章

  1. C++基础 学习笔记五:重载之运算符重载

    C++基础 学习笔记五:重载之运算符重载 什么是运算符重载 用同一个运算符完成不同的功能即同一个运算符可以有不同的功能的方法叫做运算符重载.运算符重载是静态多态性的体现. 运算符重载的规则 重载公式 ...

  2. salesforce 零基础学习(五十二)Trigger使用篇(二)

    第十七篇的Trigger用法为通过Handler方式实现Trigger的封装,此种好处是一个Handler对应一个sObject,使本该在Trigger中写的代码分到Handler中,代码更加清晰. ...

  3. salesforce lightning零基础学习(十五) 公用组件之 获取表字段的Picklist(多语言)

    此篇参考:salesforce 零基础学习(六十二)获取sObject中类型为Picklist的field values(含record type) 我们在lightning中在前台会经常碰到获取pi ...

  4. java基础学习笔记五(抽象类)

    java基础学习总结——抽象类 抽象类介绍

  5. Java基础学习笔记(五) - 常用的API

    API介绍 概念:API 即应用编程程序接口.Java API是JDK中提供给我们使用的类说明文档,这些类将底层的代码实现封装.无需关心这些类是如何实现,只需要学习如何使用. 使用:通过API找到需要 ...

  6. python 的基础 学习 第五天 基础数据类型的操作方法

    1,列表的基本操作方法 1,列表是python中的基础数据类型之一,其他语言中也有类似于列表的数据类型,比如js中叫数组,他是以[ ]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如: ...

  7. salesforce 零基础学习(五十八)通过sObject的field返回其对应的基础类型

    项目中有时候会要求通过sObject的Field的type类型返回其对应的基本类型,然后对其进行相关的处理,创建sObject的field可以选择的type类型是固定多的. 上述类型可以转换成几种基本 ...

  8. salesforce 零基础学习(五十三)多个文件生成一个zip文件(使用git上封装的代码)

    此篇参考git代码:https://github.com/pdalcol/Zippex 学习salesforce可以访问一个朋友的网站:https://www.xgeek.net 首先感谢git上提供 ...

  9. javascript基础学习(五)

    javascript之函数 学习要点: 函数的介绍 函数的参数 函数的属性和方法 系统函数 一.函数的介绍 1.函数就是一段javascript代码.可以分为用户自定义函数和系统函数.   如果一个函 ...

  10. Java基础学习笔记五 Java基础语法之面向对象

    面向对象 理解什么是面向过程.面向对象 面向过程与面向对象都是我们编程中,编写程序的一种思维方式.面向过程的程序设计方式,是遇到一件事时,思考“我该怎么做”,然后一步步实现的过程.例如:公司打扫卫生( ...

随机推荐

  1. LeetCode41 First Missing Positive

    题目: Given an unsorted integer array, find the first missing positive integer. For example,Given [1,2 ...

  2. 中科院 2014年GCT考前辅导课程安排

    : 2014年GCT考前辅导课程安排 发布时间: 2014-07-14 阅读次数:1225                       默认字体                   9pt       ...

  3. double数值多时系统默认科学计数法解决方法

    比如 Double d = new Double("1234567890.12"); System.out.println("d:="+d); java.tex ...

  4. c#代码使用ResourceDictionary样式

    对于ResourceDictionary样式代码: <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006 ...

  5. Oracle 基础 数据库备份与恢复

    一.为什么需要数据备份 造成数据丢失的主要原因: 1.介质故障. 2.用户的错误操作. 3.服务器的彻底崩溃. 4.计算机病毒. 5.不可预料的因素. Oracle中故障类型分为以下4种. 1.语句故 ...

  6. 怒刷DP之 HDU 1024

    Max Sum Plus Plus Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u S ...

  7. hdu 4144 状态压缩dp

    #include<map> #include<set> #include<cmath> #include<queue> #include<cstd ...

  8. Codeforces Round #200 (Div. 1) D Water Tree 树链剖分 or dfs序

    Water Tree 给出一棵树,有三种操作: 1 x:把以x为子树的节点全部置为1 2 x:把x以及他的所有祖先全部置为0 3 x:询问节点x的值 分析: 昨晚看完题,马上想到直接树链剖分,在记录时 ...

  9. hdu 4612 Warm up 桥缩点

    4612Warm hdu up 题目:给出一个图,添加一条边之后,问能够在新图中得到的最少的桥的数量. 分析:我们可以双联通分量进行缩点,原图变成了一棵树.问题变成了:求树中添加一条边之后,使得不在圈 ...

  10. POJ 3164 Command Network 最小树形图模板

    最小树形图求的是有向图的最小生成树,跟无向图求最小生成树有很大的区别. 步骤大致如下: 1.求除了根节点以外每个节点的最小入边,记录前驱 2.判断除了根节点,是否每个节点都有入边,如果存在没有入边的点 ...