1. 程式人生 > 程式設計 >Android Studio如何獲取SQLite資料並顯示到ListView上

Android Studio如何獲取SQLite資料並顯示到ListView上

我們在使用ListView的時候需要和資料進行繫結,那麼問題來了,如何獲取SQLite資料庫中的資料並動態的顯示到ListView當中呢?其實過程很簡單:首先要獲取SQLite資料(當然首先你要建立一個SQLite資料庫並填寫了一些資料),然後引入ListView控制元件,最後將資料和ListView繫結就好了。

一 獲取SQLite資料庫中的資料

SQLite是一個輕量級的資料庫,它能將資料儲存到你的手機,但缺點是一旦軟體解除安裝所有資料將一同被銷燬。所以要根據自己的專案需要選擇性的使用。下面要演示將SQLite中的資料提取出來。

首先定義一個類用來例項化資料庫

public class initdate {
  public Bitmap bitmap;
  public String content;
  public String data;
  public initdate (Bitmap bitmap,String context,String time){
    this.bitmap =bitmap;
    this.content =context;
    this.data =time;
  }
}

建立一個List物件用來儲存資料

List<initdate> list = new ArrayList<>();

獲取SQLite中對應表的資料

 DBOpenHelper helper = new DBOpenHelper(getActivity(),"資料庫的名稱",null,1);//建立物件
    SQLiteDatabase db = helper.getWritableDatabase();
    Cursor c = db.query("表名",null);
    if (c != null && c.getCount() >= 1) {
      while (c.moveToNext()) {
        list.add(new initdate(base64ToBitmap(c.getString(c.getColumnIndex("欄位名1"))),c.getString(c.getColumnIndex("欄位名2")),c.getString(c.getColumnIndex("欄位名3"))));
      }
      c.close();
      db.close();//關閉資料庫
    }

base64ToBitmap方法用於將String型別轉換成Bitmap

 public static Bitmap base64ToBitmap(String base64info) {
    byte[] bytes = Base64.decode(base64info,Base64.DEFAULT);
    return BitmapFactory.decodeByteArray(bytes,bytes.length);
  }

二 引入ListView控制元件

ListView的引入是比較簡單的,我們可以直接將ListView控制元件拖拽到xml檔案中即可。這裡不過多介紹

 <ListView
    android:id="@+id/lv_expense"
    style="@style/Animation.AppCompat.DropDownUp"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"/>

三 將資料和ListView繫結

首先將獲取到的資料通過一個迴圈存放到map物件中

 for (int i = 0; i < list.size(); i++) {
      Map<String,Object> map = new HashMap<String,Object>();
      map.put("image",list.get(i).bitmap);
      map.put("category",list.get(i).content);
      map.put("money",list.get(i).data);
      listitem.add(map);
    }

    SimpleAdapter adapter = new SimpleAdapter(getActivity(),listitem,R.layout.fragment_one_item,new String[]{"category","money","image"},new int[]{R.id.tv_expense_category,R.id.tv_expense_money,R.id.image_expense});
   
    ListView listView = (ListView) v.findViewById(R.id.lv_expense);
    listView.setAdapter(adapter);

    listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {//設定監聽器
      @Override
      public void onItemClick(AdapterView<?> parent,View view,int position,long id) {
        Map<String,Object> map = (Map<String,Object>) parent.getItemAtPosition(position);
        Toast.makeText(getActivity(),map.get("category").toString(),Toast.LENGTH_LONG).show();
      }
    });

fragment_one_item.xml

<?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">

  <ImageView
    android:id="@+id/image_expense"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:paddingTop="10dp"
    android:paddingRight="10dp"
    android:paddingBottom="10dp"
    android:adjustViewBounds="true"
    android:maxWidth="72dp"
    android:maxHeight="72dp"/>
  <TextView
    android:id="@+id/tv_expense_category"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_weight="1"
    android:padding="10dp"/>
  <TextView
    android:id="@+id/tv_expense_money"
    android:layout_width="wrap_content"
    android:layout_height="40dp"
    android:text="100yuan"/>
</LinearLayout>

此時我們已經將獲取到的資料和ListView進行了繫結,我們可以直接執行,發現除了小照片不能顯示外其他的資訊都正常顯示。這是由於SimpleAdapter 介面卡預設使用顯示的圖片資源都是程式內的本地資源就是能通過R.drawable.–得到的,如果我們想要把從資料庫中獲得的Bitmap型別的圖片顯示到ListView中就要自己實現ViewBinder()這個介面,在裡面定義資料和檢視的匹配關係 。

 for (int i = 0; i < list.size(); i++) {
      Map<String,Object>();
      map.put("image_expense",list.get(i).bitmap);
      map.put("expense_category",list.get(i).content);
      map.put("expense_money",list.get(i).data);
      listitem.add(map);
    }
     SimpleAdapter adapter = new SimpleAdapter(getActivity(),new String[]{"expense_category","expense_money","image_expense"},R.id.image_expense});
    adapter.setViewBinder(new SimpleAdapter.ViewBinder() {

      @Override
      public boolean setViewValue(View view,Object data,String textRepresentation) {
        if ((view instanceof ImageView) & (data instanceof Bitmap)) {
          ImageView iv = (ImageView) view;
          Bitmap bm = (Bitmap) data;
          iv.setImageBitmap(bm);
          return true;
        }
        return false;
      }
    });
    ListView listView = (ListView) v.findViewById(R.id.lv_expense);
    listView.setAdapter(adapter);

    listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {//設定監聽器
      @Override
      public void onItemClick(AdapterView<?> parent,map.get("expense_category").toString(),Toast.LENGTH_LONG).show();
      }
    });

此時照片資源也能正常顯示了。

總結

到此這篇關於Android Studio如何獲取SQLite資料並顯示到ListView上的文章就介紹到這了,更多相關android studio SQLite資料ListView內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!