`

Android学习笔记2012年(上)

阅读更多


Android学习笔记2012年

一、Android应用的目录结构

src
package
bin
apk
gen
R
res

AndroidManifest.xml

二、Android发布和运行

1、发布: .java--编译-->>.class--转换-->>.dex--打包(签名)-->>.apk--adb(install)命令-->>安装到Android系统

2、运行:操作系统创建进程--->>创建主线程--->>主线程实例化Activity(操作系统会把应用的有关信息Context放入到Activity中然后调用onCreate()方法)

三、开发拨号程序
1、调用已经有的拨号API

Intent intent=new Intent();//定义意图对象
intent.setAction("android.intent.action.CALL");
intent.setData(Uri.parse("tel:"+phone));
startActivity(intent);//会自动添加:android.intent.category.DEFAULT,故不用intent.setCategory("android.intent.category.DEFAULT");
添加拨号权限:在AndrionManifest.xml中添加:<uses-permission android:name="android.permission.CALL_PHONE"/>给软件添加拨号功能

2、性能考虑:
a)定义一个EditText类型的成员变量,对于EditText控件的查找,放在onCreate()方法中,onCreate()只加载一次,即只查找一次。
b)大量使用内部类,对于类不是很长的内部类可以采用匿名的内部类,原因是在Android虚拟机加载类的时候需要将所有类文件,类文件数量会影响加载速度。故内部类来处理。

四、开发短信发送程序

1、调用系统自带的短信发送器API
SmsManager sms=SmsManager.getDefault();//短信发送的管理类
ArrayList<String> msgs=sms.divideMessage(shortMsg);
for(String text:msgs){
sms.sendTextMessage(phone, null, text, null, null);
}
Toast.makeText(HelloActivity.this, R.string.success,Toast.LENGTH_LONG).show();//吐司提示

2、配置短信发送权限:<uses-permission android:name="android.permission.SEND_SMS"/>

五、文件的读写:

1、写:
FileOutputStream outStream = null;
try {
outStream = context.openFileOutput(fileName, Context.MODE_PRIVATE);
outStream.write(fileContent.getBytes());
} catch (Exception e) {
throw e;
} finally {
if (outStream != null) {
outStream.close();
}
}
2、读:
public String read(String fileName) throws Exception{
String result="";
FileInputStream inStream=context.openFileInput(fileName);
ByteArrayOutputStream outStream =new ByteArrayOutputStream();
byte[] buffer=new byte[1024];
int len=0;
while((len=inStream.read(buffer))!=-1){
outStream.write(buffer,0,len);
}

byte[] data=outStream.toByteArray();
result=new String(data);
inStream.close();
outStream.close();
return result;
}

3、读写模式:
Context.MODE_PRIVATE//私有----仅供本应用读写
Context.MODE_APPEND//追加-----仅供本应用读写,追加模式增加数据
Context.MODE_WORLD_READABLE//外界可读
Context.MODE_WORLD_WRITEABLE//外界可写


除此以外,四种模式还可以组合使用:例如:Context.MODE_WORLD_READABLE+Context.MODE_WORLD_WRITEABLE
表示文件可以对外被读写

六、读写SDCard

1、读写之前判断SDcard是否存在或者写保护
try {//判断sdcard是否存在或被写保护
if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){
fileService.writeFileToSDCard(fileName, fileContent);
}else{
Log.e(ETAG, "SDCard不存在或被写保护!");
}
} catch (Exception e) {
Log.e(ETAG, "保存文件失败!");
}
2、写入到SDCard代码
File file= new File(Environment.getExternalStorageDirectory(),fileName);
FileOutputStream outStream = new FileOutputStream(file);
outStream.write(fileContent.getBytes());
outStream.close();
3、添加读写的权限
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

七、Pull存取XML数据
1、读数据:主要应用XmlPullParser类
public static List<Person> getDataFromXML(InputStream xmlStream) throws XmlPullParserException, IOException{
List<Person> persons=null;
Person person =null;
XmlPullParser pullParser=Xml.newPullParser();//初始化实例
pullParser.setInput(xmlStream,"UTF-8");//设置输入流
int event=pullParser.getEventType();//事件状态
while(event!=XmlPullParser.END_DOCUMENT){
switch(event){
case XmlPullParser.START_DOCUMENT://文档开始
persons=new ArrayList<Person>();
break;
case XmlPullParser.START_TAG://标签开始
if("person".equals(pullParser.getName())){//判断标签名获取属性值
Long id=new Long(pullParser.getAttributeValue(0));
person =new Person();
person.setId(id);
}
if("name".equals(pullParser.getName())){//判断标签名获取标签内置
String name=pullParser.nextText();
person.setName(name);
}
if("age".equals(pullParser.getName())){
Integer age=new Integer(pullParser.nextText());
person.setAge(age);
}
break;

case XmlPullParser.END_TAG://标签结束
if("person".equals(pullParser.getName())){
persons.add(person);
person=null;
}
break;
}

event=pullParser.next();
}
return persons;
}

2、存数据:主要应用XmlSerializer类

public static void saveDateToXML(List<Person> persons,OutputStream os ) throws Exception{
XmlSerializer xmlSeriallizer=Xml.newSerializer();
xmlSeriallizer.setOutput(os, "UTF-8");
xmlSeriallizer.startDocument("UTF-8", true);
xmlSeriallizer.startTag(null, "root");

for(Person person:persons){
xmlSeriallizer.startTag(null, "person");
xmlSeriallizer.attribute(null, "id", person.getId().toString());
xmlSeriallizer.startTag(null, "name");
xmlSeriallizer.attribute(null, "name", person.getName());
xmlSeriallizer.endTag(null, "name");
xmlSeriallizer.startTag(null, "age");
xmlSeriallizer.attribute(null, "age",person.getAge()+"");
xmlSeriallizer.endTag(null, "age");
xmlSeriallizer.endTag(null, "person");
}

xmlSeriallizer.endTag(null, "root");
xmlSeriallizer.endDocument();

}

八、参数SharedPreference的设置

读写:主要应用:SharedPreferences、Editor类


public void savePreferences(String name,int grade){
SharedPreferences sharedPreference=context.getSharedPreferences("preference", Context.MODE_PRIVATE);
Editor editor=sharedPreference.edit();
editor.putString("nikename", name);
editor.putInt("grade", grade);
editor.commit();
}
public HashMap<String,String> getPreferences(){
HashMap<String,String> params=new HashMap<String,String>();
SharedPreferences sharedPreference=context.getSharedPreferences("preference", Context.MODE_PRIVATE);
params.put("grade", String.valueOf(sharedPreference.getInt("grade", 0)));
params.put("name",sharedPreference.getString("nikename",""));
return params;
}

九、sqlite数据库操作

1、创建数据库


public class DBOpenHelper extends SQLiteOpenHelper {//创建一个操作类继承SQLiteOpenHelper数据库操作类

public DBOpenHelper(Context context) {
super(context, "sqlit.db", null, 2);(Context上下文对象,数据库名称,CursorFactory工厂,数据版本版本号,不能为0,刚开始一般为1 )
}

@Override
public void onCreate(SQLiteDatabase db) {//数据库第一次创建时调用的方法,在数据库中生成数据库表
db.execSQL("CREATE TABLE USER(UID INTEGER PRIMARY KEY AUTOINCREMENT,UNAME VARCHAR(20)NOT NULL) ");
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {//数据库版本升级时候调用
db.execSQL("ALTER TABLE USER ADD PHONE VARCHAR(20) NULL");
}


}
//调用方法
public void createDbTest(){
DBOpenHelper dBOpenHelper=new DBOpenHelper(this.getContext());//创建DBOpenHelper实例
dBOpenHelper.getWritableDatabase();//获取数据库读写对象,创建数据库
}

2、使用标准SQL实现增删改查


this.dbOpenHelper=new DBOpenHelper(context);
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();//获取读取数据的实例
db.execSQL(sql)//执行增删改sql语句
Cursor cursor= db.rawQuery(sql)//执行查询的sql语句,cursor为游标对象

=============================================
private DBOpenHelper dbOpenHelper;//数据库操作对象

public UserService(Context context){//初始化数据库操作对象
this.dbOpenHelper=new DBOpenHelper(context);
}

public void add(User user){
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();
db.execSQL("insert into user(uname,phone) values(?,?)",
new Object[]{user.getUname(),user.getPhone()});
}
public void delete(Long uid){
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();
db.execSQL("delete from user where uid=?",new Object[]{uid});
}
public void update(User user){
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();
db.execSQL("update user set uname=?,phone=? where uid=?",
new Object[]{user.getUname(),user.getPhone(),user.getUid()});
}
public User findById(Long uid){
User user=new User();
SQLiteDatabase db=dbOpenHelper.getReadableDatabase();
Cursor curser= db.rawQuery("select * from user where uid=?",new String[]{uid.toString()});
if(curser.moveToFirst()){
user.setUid(curser.getLong(curser.getColumnIndex("UID")));
user.setUname(curser.getString(curser.getColumnIndex("UNAME")));
user.setPhone(curser.getString(curser.getColumnIndex("PHONE")));
}
return user;
}
public List<User> findList(int offset,int pageSize){
SQLiteDatabase db=dbOpenHelper.getReadableDatabase();
Cursor curser= db.rawQuery("select * from user order by uid asc limit ?,?",
new String[]{offset+"",""+pageSize});
List<User> users=new ArrayList<User>();
User user=null;
while(curser.moveToNext()){
user=new User();
user.setUid(curser.getLong(curser.getColumnIndex("UID")));
user.setUname(curser.getString(curser.getColumnIndex("UNAME")));
user.setPhone(curser.getString(curser.getColumnIndex("PHONE")));
users.add(user);
}

return users;
}
public long findCount(){
SQLiteDatabase db=dbOpenHelper.getReadableDatabase();
Cursor curser= db.rawQuery("select count(*) as total from user",null);
curser.moveToFirst();
long total=curser.getLong(curser.getColumnIndex("total"));
return total;
}

3、使用android的数据库操作API操作
主要有:insert、delete、update、query四个操作方法
参数传递:ContentValues对象和String[]{}字符数组对象
查询结果:Cursor对象


public void add(User user){//增加
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();
ContentValues values =new ContentValues();
values.put("uname", user.getUname());
values.put("phone", user.getPhone());
db.insert("USER", null, values);//参数(表名,空字段名,字段值)
}
public void delete(Long uid){//删除
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();
db.delete("USER", "uid=?", new String[]{uid.toString()});
}
public void update(User user){//更新
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();
ContentValues values= new ContentValues();
values.put("uname", user.getUname());
values.put("phone", user.getPhone());
db.update("USER", values, "uid=?", new String[]{user.getUid().toString()});
}
public User findById(Long uid){//用id查询
User user=new User();
SQLiteDatabase db=dbOpenHelper.getReadableDatabase();
Cursor curser= db.query("user", null, "uid=?", new String[]{uid.toString()}, null, null, null);
if(curser.moveToFirst()){
user.setUid(curser.getLong(curser.getColumnIndex("UID")));
user.setUname(curser.getString(curser.getColumnIndex("UNAME")));
user.setPhone(curser.getString(curser.getColumnIndex("PHONE")));
}
return user;
}
public List<User> findList(int offset,int pageSize){//查询分页
SQLiteDatabase db=dbOpenHelper.getReadableDatabase();
Cursor curser= db.query("user", null, null, null, null, null, "uid asc", offset+","+pageSize);
ArrayList<User> users=new ArrayList<User>();
User user=null;
while(curser.moveToNext()){
user=new User();
user.setUid(curser.getLong(curser.getColumnIndex("UID")));
user.setUname(curser.getString(curser.getColumnIndex("UNAME")));
user.setPhone(curser.getString(curser.getColumnIndex("PHONE")));
users.add(user);
}

return users;
}
public long findCount(){//查询数量
SQLiteDatabase db=dbOpenHelper.getReadableDatabase();
Cursor curser= db.query("user", new String[]{"count(*)"}, null,null, null, null, null);
curser.moveToFirst();
long total=curser.getLong(0);
return total;
}

4、事务的管理

SQLiteDatabase db=dbOpenHelper.getReadableDatabase();

db.beginTransaction();
try{
db.execSQL("Update User set amount=amount-? where uid=?",new Object[]{amount,payer.getUid()});
//int i=Integer.parseInt("error");
db.execSQL("Update User set amount=amount+? where uid=?",new Object[]{amount,accepter.getUid()});
db.setTransactionSuccessful();//设置事务标志
/**
* 注意:事务的结束有两种:commit(提交)和rollback(回滚)两种方式
* 事务的结束方式是事务的标志决定的,默认结束标志是false
* 该情况下事务默认是回滚方式结束的,
* db.setTransactionSuccessful()方法设置事务的提交方式为提交方式
*/
}catch(Exception e){
Log.i("UerServiceTest", "事务中出现异常,数据回滚!");
}
finally{
db.endTransaction();
}
*********************************************2012-11-20****************************************************
十、ListView控件绑定数据库

1、作用:ListView是一种常用的显示数据的控件

2、展示数据的时候一般先定义数据行模板, 实例如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" >

<TextView
android:layout_width="100dp"
android:layout_height="wrap_content"
android:id="@+id/name"
android:textSize="16dp"
/>
<TextView
android:layout_width="120dp"
android:layout_height="wrap_content"
android:id="@+id/phone"
android:textSize="16dp"

/>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/amount"
android:textSize="16dp"
/>
</LinearLayout>
3、

 

分享到:
评论

相关推荐

    Android学习笔记

    在深入探讨Android开发之前,我们先来了解一下这个标题——"Android学习笔记",这表明了本文档是作者在阅读《Professional Android 4 Application Development》这本书时所作的笔记,旨在帮助读者理解Android应用...

    Python学习笔记第二版

    - **更新记录**:详细记录了每一章节完成的时间,从2012年12月15日开始至2013年3月30日,涵盖了多个章节的编写过程,包括对标准库的不断补充和完善。 - **目录**:本书分为两大部分,第一部分涉及Python语言的基础...

    go学习笔记

    - 2012年3月29日,Go 1.0版本正式发布,这是一个重要的里程碑,标志着Go语言从实验阶段走向了成熟稳定。 - 在后续几年中,Go语言经历了多个版本的迭代更新,每个版本都带来了新特性和性能改进。 - 例如,Go 1.4版本...

    2012年最有价值的Android开发精品文章荟萃【800篇】

    ### Android学习笔记 **作者:tracytheron** **主要内容:** tracytheron撰写的14篇文章记录了他在学习Android开发过程中的心得体会。这些笔记不仅包含了技术细节,还包括了一些个人感悟和建议,对于正在学习的...

    WebRTC学习笔记_Demo收集 .docx

    2012年,Google在最新的Chrome for Android版本中正式支持WebRTC,这标志着WebRTC技术开始走向成熟,并且吸引了越来越多开发者和企业的关注。如今,WebRTC不仅被集成到主流浏览器中,还被广泛应用于各类应用场景,...

    电脑爱好者2012年第7期 官方电子版

    - 报名截止时间是2012年5月31日。 - 杂志定价为8元/半月,全年共24期。杂志正常通过平寄方式邮寄,邮费由杂志社承担。 - 订阅活动不适用于邮局订阅等渠道,读者可以选择在杂志社邮购、网上商城或现场订购。 3. ...

    易信 QQ 微信 陌陌 表情 Android版

    这可能是为特定日期(2012年5月17日)更新的表情库。此外,“新建文本文档 (2).txt”可能包含了关于表情包的说明、更新历史或者开发者笔记。 “FaceDemo”这个文件名可能指向一个演示程序或测试工具,用于展示如何...

    Windows 8与Surface携手,iOS、Android还能自信多久.pdf

    首先,Windows 8是微软在2012年推出的一款全新操作系统,旨在整合桌面与移动设备体验,引入了现代UI(以前称为Metro UI)和触控优化的功能。这一设计目标直接挑战了iOS和Android在移动市场的主导地位。Windows 8的...

    安卓入门教程及环境搭建(附笔记)

    2012年时的推荐版本为installer_r20-windows,下载地址:[http://developer.android.com/sdk/index.html](http://developer.android.com/sdk/index.html) 3. **Eclipse IDE**:早期的安卓开发常用Eclipse作为集成...

    QT学习文档(带书签、超详细)

    2012年,QT又被Digia公司收购。2014年,QT实现了对iOS、Android、WP等各平台的全面支持。 3. QT支持的平台 QT支持多种平台,包括Windows、Unix/X11、Macintosh、Embedded等。其中,Windows平台支持XP、Vista、Win...

    互联网软件应用于开发课件

    本课程包是2012年由杨云教授编著的“互联网软件应用于开发”的教学资料,主要针对成人教育领域。在这个信息化高度发达的时代,互联网软件开发已经成为各行各业不可或缺的一部分,因此,这样的课程对于提升成年人的...

    电脑报 2013年第1期

    2. **操作系统**:Windows 8在2012年底发布,2013年是其普及初期,因此可能会有大量关于Windows 8新特性的介绍,包括其全新的Metro界面、触控支持和Windows Store。此外,Windows 7仍然是主流,对于它的优化和使用...

    Beginning PhoneGap

    出版,版权日期为2012年。PhoneGap是一种允许开发者使用HTML、CSS和JavaScript等Web技术来构建跨平台移动应用程序的框架。本书从安装配置到高级功能的实现,系统地介绍了PhoneGap的核心概念和技术要点。 #### 二、...

    tableau server

    - **移动支持**:可在多种移动设备上使用,如iPad、Android平板电脑等。 2. **核心优势** - **替代传统BI方案**:相比于传统的商业智能工具,Tableau Server 提供更直观的操作界面,降低了学习曲线。 - **即时...

    Windows 8可能让企业受益的10个方面

    Windows 8是微软公司在2012年推出的一款操作系统,它针对企业用户进行了特别优化,尽管在初期遭受了市场的抵触,主要是因为取消了经典的“开始”按钮和引入了与传统桌面操作有所区别的磁贴式界面,但是当企业愿意...

Global site tag (gtag.js) - Google Analytics