小写转大写 : 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. js字符串的各种格式的转换 ToString,Format

    1.转换钱的格式,仅限int型,float型,double型 double d = 400; d.ToString("C"); //¥400.00 2.10进制数,仅限int型的数 ...

  2. Python笔记(二)

    在昨天学习Python之后,感觉它的的确确挺简洁,也挺容易学习.在昨天的学习中我们了解到了Python中while循环语句以及if...else语句的使用,while语句的使用格式是这样的:while ...

  3. ScrollView嵌套ListView的滑动冲突问题,是看大神的方法的,作为学习以后用的到

    在工作中,曾多次碰到ScrollView嵌套ListView的问题,网上的解决方法有很多种,但是杂而不全.我试过很多种方法,它们各有利弊. 在这里我将会从使用ScrollView嵌套ListView结 ...

  4. SQL中Len与DataLength区别

    SQL中求字符串长度问题 一.LEN(Param) 求字符串的长度 DataLength(param) 求字符串所占的字节长度 二.LEN不返回文本之后的空格长度 而DataLenth则不同 三.针对 ...

  5. [Javascript]jquery $(document).ready() 与window.onload的区别

    引用:http://www.jb51.net/article/21628.htm Jquery中$(document).ready()的作用类似于传统JavaScript中的window.onload ...

  6. MVC+easyui 完整实现

    学习mvc半月有余,趁几天假期,没事做就动手做一个完整的网站玩玩,顺便和上家公司的方法做个比较.页面引擎采用mvc自带的功能,建立视图,交给.net自带渲染出页面(对比:上家公司采用的第三方组件渲染的 ...

  7. 【Linux/Ubuntu学习 12】ubuntu下对/etc/profile误修改导致系统不能登录

    etc/profile里设置环境变量导致无法登录解决   1,因为不小心在 etc/profile里设在环境变量导致无法登录    不要在 etc/profile里设置 export PATH这样会导 ...

  8. iOS - UI - UIPageControl

    1.UIPageControl 分页控件 //分页控件初始化 UIPageControl * pageControl = [[UIPageControl alloc] init]; //分页页数 pa ...

  9. 单例模式——Singleton

    模式分类: 从目的来看: 1.创建型(Creational)模式:负责对象创建. 2.结构型(Structural)模式:处理类于对象间的组合. 3.行为型(Behavioral)模式:类与对象交互中 ...

  10. VS2013 添加文件头部注释模板

    在看视频的时候发现,视频中每次新建一个类文件 都会自动生成一串 头部的注释: