亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android Studio怎樣獲取SQLite數據并顯示到ListView上

發布時間:2021-02-01 10:42:48 來源:億速云 閱讀:801 作者:小新 欄目:移動開發

小編給大家分享一下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, null, null, null, null, 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, 0, bytes.length);
  }

二 引入ListView控件

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

 <ListView
    android:id="@+id/lv_expense"
    
    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 = new HashMap<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()
        , listitem
        , R.layout.fragment_one_item
        , new String[]{"expense_category", "expense_money", "image_expense"}
        , new int[]{R.id.tv_expense_category, R.id.tv_expense_money, 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, View view, int position, long id) {
        Map<String, Object> map = (Map<String, Object>) parent.getItemAtPosition(position);
        Toast.makeText(getActivity(), map.get("expense_category").toString(), Toast.LENGTH_LONG).show();
      }
    });

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

以上是“Android Studio怎樣獲取SQLite數據并顯示到ListView上”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

呈贡县| 静安区| 永康市| 蒙自县| 临夏县| 腾冲县| 旌德县| 宿松县| 巴林左旗| 桃源县| 富平县| 娱乐| 长岭县| 河曲县| 广水市| 庆阳市| 文成县| 婺源县| 防城港市| 莒南县| 思茅市| 综艺| 浙江省| 湖口县| 柳江县| 清新县| 吴堡县| 惠东县| 平潭县| 长治市| 禄劝| 阳新县| 双鸭山市| 尚志市| 博罗县| 云和县| 类乌齐县| 盐边县| 蚌埠市| 皋兰县| 同江市|