第8章 Android的数据存储和IO_第1页
第8章 Android的数据存储和IO_第2页
第8章 Android的数据存储和IO_第3页
第8章 Android的数据存储和IO_第4页
第8章 Android的数据存储和IO_第5页
已阅读5页,还剩23页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

Android手机开发第8章Android的数据存储和IO第8章Android的数据存储和IOSharedPreference

保存程序的参数、选项

读写其它程序的SharedPreferenceAndroid的IO及SD卡的读写SQLite数据库

使用AndroidAPI操作SQLite数据库

使用sqlite3工具管理数据库SQLiteHelper类的功能与用法Android手势TTSAndroid数据存储的四种方式PreferenceFileSQLiteContentprovider8.1使用SharedPreference

该接口主要负责读写应用程序的Preference数据,其中数据为key-value对getSharedPreferences(Stringname,intmode)Context.MODE_PRIVATEContext.MODE_WORLD_READABLEContext.MODE_WORLD_WRITABLEbooleancontains(Stringkey)abstract

Map<String,?>getAll()booleangetXxx(Stringkey,XxxdefValue)8.1使用SharedPreferenceEditoredit()Editorclear()EditorputXxx(Stringkey,xxxvalue)Editorremove(Stringkey)booleancommit()8.1.3读写其它应用的SharedPreferences

其它应用SharedPreferences声明WORLD_READABLE或WORLD_WRITABLE权限

获取其它应用的Context对象ContextCreatePackageContext(Stringname,intmode)8.2File存储InputStreamOutputStreamFileInputStreamFileOutputStreamread()write()InputStreamReaderOutPutStreamWriterBufferedReader BufferedWriter8.2.1openFileInput,openFileOutputContext提供的方法(读写程序当前目录):FileInputStreamopenFileInput(Stringname)FileOutputStreamopenFileOutput(Stringname,intmode)MODE_PRIVATEMODE_APPENDMODE_WORLD_READABLEMODE_WORLD_WRITEABLEgetDir(Stringname,intmode)FilegetFilesDir()String[]fileList()deleteFile(String)8.2.2读写SD卡上的文件

配置SD卡的读写权限:android.permission.WRITE_EXTERNAL_STORAGEandroid.permission.MONT_UNMONT_FILESYSTEMS

设置模拟器启动时加载SD卡boolEnvironment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)FileEnvironment.getExternalStorageDirectory()/mnt/sdcard8.3SQLite数据库轻量级不需要“安装”单一文件

跨平台/可移植性弱类型的字段开源:

数据类型:null,VARCHAR(n),CHAR(n),INTEGER,REAL,TEXT,BLOB,DATE,TIME8.3SQLite数据库SQLiteDataBase:代表一个数据库

staticSQLiteDataBaseopenDataBase(Stringpath,SQLiteDataBase.CursorFactoryfactory,intflags)flags:OPEN_READONLY,OPEN_READWRITE,CREATE_IF_NECESSARY

staticSQLiteDataBaseopenOrCreateDataBase(Filefile,SQLiteDataBase.CursorFatoryfactory)

staticSQLiteDataBaseopenOrCreateDataBase(Stringpath,SQLiteDataBase.CursorFatoryfactory)openOrCreateDataBase(Stringpath,SQLiteDataBase.CursorFatoryfactory)openDataBase(Stringpath,SQLiteDataBase.CursorFactoryfactory,CREATE_IF_NECESSARY)8.3SQLite数据库获取SQLiteDataBase对象后,操作数据库的方法:execSQL(Stringsql)execSQL(Stringsql,object[]bindArgs)执行一条语句,无返回值。bindArgs:占位符参数列表longinsert(Stringtable,StringnullColumnHack,ContentValuesinitialValues)nullColumnHack:列名,SQLite不允许出现全是空的记录。当传入的initialValues值为空或者为0时,用nullColumnHack参数指定的列会被插入值为NULL的数据,然后再将此行插入到表中。

返回值为插入行的行号8.3SQLite数据库intupdate(Stringtable,ContentValuesvalues,StringwhereClause,String[]whereArgs)values,用来描述更新后的行数据的ContentValues对象,即列名和列值的映射。其中的值为键值对,其中key为列名。put(key,value);getAsXxx(key)whereClause,可选的where语句(不包括WHERE关键字),用来指定需要更新的行。若传入null则表中所有的行均会被更新。whereArgs,where语句中表达式的?占位参数列表,参数只能为String类型。返回值为更新过的记录的条数8.3SQLite数据库Cursorquery(booleandistinct,Stringtable,String[]columns,Stringselection,String[]selectionArgs,StringgroupBy,Stringhaving,StringorderBy,Stringlimit)distinct,如果希望结果集没有重复的行传入true,否则传入false。columns,由需要返回列的列名所组成的字符串数组,传入null会返回所有的列。selection,指定需要返回的行的where语句。传入null则返回所有行。selectionArgs,where语句中表达式的?占位参数列表,参数只能为String类型。groupBy,对结果集进行分组的groupby语句。传入null将不对结果集进行分组。limit,对返回的行数进行限制的limit语句。传入null将不限制返回的行数。

CursorrawQuerry(Stringsql,String[]selectionArgs)8.3SQLite数据库intdelete(Stringtable,StringwhereClause,String[]whereArgs)

满足whereClause子句的记录将被删除

返回值为被删除的记录的条数注意:数据库操作完成后,要调用close()方法将其关闭8.3SQLite数据库Cursor:一些行的集合move(intoffset)booleanmoveToFirst()booleanmoveToLast()booleanmoveToNext()booleanmoveToPrevious()booleanmoveToPosition(intindex)8.3SQLite数据库

使用SQLiteDataBase进行数据库操作的步骤:获取SQLiteDataBase对象,它代表了一个与数据库的连接;调用SQLiteDataBase中的方法执行SQL语句;

操作SQL语句执行的结果;

关闭SQLiteDataBase,回收资源。8.3.4使用Sqlite3工具adbshellsqlite3database_name.help.databases.table.schema8.3.6事务db.beginTransaction();try{ //执行数据库操作 ……db.setTransactionSuccessful();}finally{db.endTransaction();}8.3.7SQLiteOpenHelpersynchronizedSQLiteDatabasegetReadableDatabase()

synchronizedSQLiteDatabasegetWritableDatabase()

abstractvoidonCreate(SQLiteDatabasedb)

abstractvoidonUpgrade(SQLiteDatabasedb,intoldVersion,intnewVersion)8.4.1手势检测GestureDetctor(GestureDetector.onGestureListenerlistener)

boolonDown(MotionEvente)

boolonFling(MotionEvente1,MotionEvente2,floatvilocityX,floatvilocityY)

abstractvoidonLongPress(MotionEvente)

boolonScroll(MotionEvente1,MotionEvente2,floatdistX,floatdistY)

voidonShowPress(MotionEvente)

boolonSingleTapUp(MotionEvene)onDownonShowPressonLongPressonScroll()happensaftertheuserputshisfingerdownonthescreenandslideshisfingeracrossthescreenwithoutliftingit.onFling()happensiftheuserscrollsandthenliftshisfinger.Aflingistriggeredonlyifthemotionwasfastenough.8.4.1手势检测使用手势检测:

创建一个GestureDetctor对象,构造函数参数为GestureDetector.OnGestureListener监听器对象

复写Activity的onTouchEvent方法,将TouchEvent交给GestureDetector处理8.4.1手势检测MatrixsetTranslate(floatdx,floatdy)setRotate(floatdegree)setScale(floatsx,floatsy)8.4.2增加手势<android.getsture.GestureOverlayView android:id=“@+id/gesture” android:layout_width=“fill_parent”android:layout_height=“fill_parent” android:gestureStrokeType=“multiple”/>onGestureListeneronGesturePerformedListeneronGestureingListener8.4.2增加手势GetstureLibrary代表手势库,GestureLibraries工具类创建手势库:

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论