Android StudioはどのようにSQLiteデータを取得し、ListViewに表示しますか?
私たちはListViewを使う時にデータと紐付けする必要がありますが、問題が来ました。SQLiteデータベースのデータをどうやって取得してListViewに動的に表示しますか?実はプロセスは簡単です。まずSQLiteデータを取得します。(もちろん、まずSQLiteデータベースを作成して、いくつかのデータを記入します。)そしてListViewコントロールを導入して、最後にデータとListViewを紐付けたらいいです。
SQLiteデータベースのデータを取得すると
SQLiteは軽量級のデータベースです。データをあなたの携帯電話に保存することができますが、欠点はソフトウェアをアンインストールするとすべてのデータが一緒に破棄されます。だから自分のプロジェクトによって選択的に使う必要があります。SQLiteのデータを抽出するデモを行います。
最初にクラスを定義して、データベースを実用化します。
Listlist=new ArayList();
SQLiteの対応テーブルのデータを取得します。
ListViewの導入は比較的簡単で、ListViewコントロールを直接xmlファイルにドラッグしてもいいです。ここは紹介が多いだけです。
まず取得したデータを一つのループでmapオブジェクトに保存します。
締め括りをつける
ここではAndroid StudioについてSQLiteデータを取得し、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
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();//
}
base 64 ToBitmap方法は、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"
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();
}
});
fragmentone.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
.Cによって得られたものであり、データベースから得られた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に表示された記事を紹介します。これまでの記事を検索したり、次の関連記事を見たりしてください。これからもよろしくお願いします。