在這個教程中將會建立一個簡單列表介面,允許使用者添加刪除,但是不能編輯。包括如下的內容:
◆ListActivities的基礎知識和如何建立功能表項目。
◆如何使用SQLite 資料庫訪問資料。
◆如何使用ArrayAdapter綁定資料到ListView (最簡單的一種方式)。
◆最基本的Layout,包括如何顯示一個ListView,如何向一個菜單插入功能表項目以及如何響應菜單
第一步 建立工程
使用Eclipse建立一個工程Notepad
第二步 如何使用Sqlite資料庫
和系統相關的介面調用都要用到Context類。
1開啟資料庫
程式碼片段:
| public DBHelper(Context ctx) { try { //開啟已經存在的資料庫 db = ctx.openDatabase(DATABASE_NAME, null); } catch (FileNotFoundException e) { try { //建立新的資料庫 db = ctx.createDatabase(DATABASE_NAME, DATABASE_VERSION, 0, null); //建立資料表 db.execSQL(DATABASE_CREATE); } catch (FileNotFoundException e1) { db = null; } } } |
Context類的openDatabase可以開啟一個已經存在的資料庫,如果資料庫不存在,將會拋出FileNotFoundException異常。可以通過Context類的createDatabase函數建立一個新的資料庫。通過調用SQLiteDatabase 的execSQL方法,執行一條SQL語句建立一個新的資料表。
2.擷取表中的資料
代碼如下:
| public List﹤Row﹥ fetchAllRows() { ArrayList﹤Row﹥ ret = new ArrayList﹤Row﹥(); try { Cursor c = db.query(DATABASE_TABLE, new String[] { "rowid", "title", "body"}, null, null, null, null, null); int numRows = c.count(); c.first(); for (int i = 0; i ﹤ numRows; ++i) { Row row = new Row(); row.rowId = c.getLong(0); row.title = c.getString(1); row.body = c.getString(2); ret.add(row); c.next(); } } catch (SQLException e) { Log.e("booga", e.toString()); } return ret; } |
建立一個遊標類Cursor 通過SQLiteDatabase 的query方法查詢一個表格。有了Cursor就可以遍曆所有的記錄了。
3添加新的記錄
| public void createRow(String title, String body) { ContentValues initialValues = new ContentValues(); initialValues.put("title", title); initialValues.put("body", body); db.insert(DATABASE_TABLE, null, initialValues); } |
構造一個ContentValues類,通過調用put方法,可以設定一條記錄的屬性。通過調用SQLiteDatabase的insert方法添加一條新的記錄。
4 刪除記錄
| public void deleteRow(String str) { db.delete(DATABASE_TABLE, "title=\'" + str+"\'", null); } |
直接調用SQLiteDatabase的delete方法,第二個參數是一個SQL條件運算式。
第三步 顯示方式和介面
大部分的介面都有一個Layout。我們的介面是顯示在整個螢幕中的List。還有其他的顯示方式,比如懸浮的視窗Dialog,Alert)。
開啟main.xml檔案。
這是一個定義介面顯示風格的資源檔。
a. 所有的介面資源檔都從這樣的一行開始: ﹤?xml version="1.0" encoding="utf-8"?﹥.
b. 一般的類型定義都是LinearLayout 並不是總是)
c. 關於XML的名稱空間的定義,總是下面一行:
| xmlns:android="http://schemas.android.com/apk/res/android" |