編輯:關於Android編程
其實很簡單,就是把我們的數據庫文件放到我們的手機裡,所以不必局限在哪個地方寫這個代碼,在第一次創建數據庫的時候可以,我覺得在軟件起動頁裡效果更好一點,首先我們應該把事先寫好的數據庫文件比如 test.db放到res文件夾裡的raw文件夾裡,也可以放到assets裡,因為這兩個文件夾不會在生成APK的時候不會被壓縮。
1,DataBaseUtil用於將raw中的db文件copy到手機中,代碼如下
復制代碼 代碼如下:
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import com.ata.app.R;
/**
* copy數據庫到apk包
*
* @author NGJ
*
*/
public class DataBaseUtil {
private Context context;
public static String dbName = "Kao.db";// 數據庫的名字
private static String DATABASE_PATH;// 數據庫在手機裡的路徑
public DataBaseUtil(Context context) {
this.context = context;
String packageName = context.getPackageName();
DATABASE_PATH="/data/data/"+packageName+"/databases/";
}
/**
* 判斷數據庫是否存在
*
* @return false or true
*/
public boolean checkDataBase() {
SQLiteDatabase db = null;
try {
String databaseFilename = DATABASE_PATH + dbName;
db = SQLiteDatabase.openDatabase(databaseFilename, null,SQLiteDatabase.OPEN_READONLY);
} catch (SQLiteException e) {
}
if (db != null) {
db.close();
}
return db != null ? true : false;
}
/**
* 復制數據庫到手機指定文件夾下
*
* @throws IOException
*/
public void copyDataBase() throws IOException {
String databaseFilenames = DATABASE_PATH + dbName;
File dir = new File(DATABASE_PATH);
if (!dir.exists())// 判斷文件夾是否存在,不存在就新建一個
dir.mkdir();
FileOutputStream os = new FileOutputStream(databaseFilenames);// 得到數據庫文件的寫入流
InputStream is = context.getResources().openRawResource(R.raw.kao);// 得到數據庫文件的數據流
byte[] buffer = new byte[8192];
int count = 0;
while ((count = is.read(buffer)) > 0) {
os.write(buffer, 0, count);
os.flush();
}
is.close();
os.close();
}
}
2,在需要的activity中加入如下方法用於具體的copy操作
復制代碼 代碼如下:
Java代碼
privatevoid copyDataBaseToPhone() {
DataBaseUtil util = new DataBaseUtil(this);
// 判斷數據庫是否存在
boolean dbExist = util.checkDataBase();
if (dbExist) {
Log.i("tag", "The database is exist.");
} else {// 不存在就把raw裡的數據庫寫入手機
try {
util.copyDataBase();
} catch (IOException e) {
thrownew Error("Error copying database");
}
}
}
3,檢測是否有SDCard,執行copy。(個人感覺可以不檢測SD卡是否存在,但不檢測似乎有個問題,程序原因?)
復制代碼 代碼如下:
boolean hasSDCard = Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED);
if(hasSDCard){
copyDataBaseToPhone();
}else{
showToast("未檢測到SDCard");
}
前言Snackbar 是一種針對操作的輕量級反饋機制,常以一個小的彈出框的形式,出現在手機屏幕下方或者桌面左下方。它們出現在屏幕所有層的最上方,包括浮動操作按鈕。Snac
(1) main.xml 代碼如下:(聲明四個按鈕控件) XML代碼: 復制代碼 代碼如下: <?xml version=1.0 encoding=utf-8?&g
本文實例為大家分享了Android自定義下拉刷新上拉加載的具體實現步驟,供大家參考,具體內容如下實現的方式是SwipeRefreshLayout + RecyclerVi
ActivityManager.RunningAppProcessInfo類與獲取正在運行的應用程序每一個應用程序都會運行在它獨立的進程裡,但是為了節省資源或者這些應用程