我有从 sqlite 检索数据并在 BaseAdapter 中显示数据的 android 应用程序 .. 最好的方法是啥?

Posted

技术标签:

【中文标题】我有从 sqlite 检索数据并在 BaseAdapter 中显示数据的 android 应用程序 .. 最好的方法是啥?【英文标题】:i have android app that retrieve data from sqlite and display the data in BaseAdapter .. what is the best way ??我有从 sqlite 检索数据并在 BaseAdapter 中显示数据的 android 应用程序 .. 最好的方法是什么? 【发布时间】:2014-06-12 07:59:44 【问题描述】:

我有一个 android 应用程序,它从 sqlite 数据库中检索数据并将这些数据显示在扩展 BaseAdapter 的 listView 中。

在这个应用程序中,我在可绘制文件夹中有图像,并且我在 sqlite 中有一个包含这些图像名称的字段。

我的问题是如何检索这些数据并将其显示在 listView 中??

我读了这个教程:(http://www.androidhub4you.com/2012/09/hello-friends-today-i-am-going-to-share.html)。

我的问题是有没有其他方法可以做到这一点??

我将不胜感激。

row_list_match_schedulle.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/RelativeLayout1"
    android:layout_
    android:layout_
    android:orientation="vertical" >

    <TextView
        android:id="@+id/textGroup"
        android:layout_
        android:layout_
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:text="Group"
        android:textAppearance="?android:attr/textAppearanceMedium" />

    <TextView
        android:id="@+id/txtDate"
        android:layout_
        android:layout_
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:text="Date"
        android:textAppearance="?android:attr/textAppearanceSmall" />



    <TextView
        android:id="@+id/textName1"
        android:layout_
        android:layout_
        android:layout_alignBottom="@+id/imageView1"
        android:layout_alignParentLeft="true"
        android:text="name1" />

    <TextView
        android:id="@+id/textName2"
        android:layout_
        android:layout_
        android:layout_alignBottom="@+id/imageView2"
        android:layout_alignParentRight="true"
        android:text="Name2" />

    <ImageView
        android:id="@+id/imageView1"
        android:layout_
        android:layout_
        android:layout_below="@+id/textLocation"
        android:layout_toRightOf="@+id/textName1"
        android:adjustViewBounds="true"
        android:maxHeight="40dp"
        android:maxWidth="40dp"
        android:scaleType="fitCenter"
        android:src="@drawable/algeria_flag" />

    <ImageView
        android:id="@+id/imageView2"
        android:layout_
        android:layout_
        android:layout_alignTop="@+id/imageView1"
        android:layout_toLeftOf="@+id/textName2"
        android:adjustViewBounds="true"
        android:maxHeight="40dp"
        android:maxWidth="40dp"
        android:scaleType="fitCenter"
        android:src="@drawable/algeria_flag" />

    <TextView
        android:id="@+id/textLocation"
        android:layout_
        android:layout_
        android:layout_below="@+id/textGroup"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="18dp"
        android:text="Location" />

</RelativeLayout>

ItemDetails.java

package com.devleb.expandablelistdemo3;

public class ItemDetails 

    String stad_name;
    String team1;
    String team2;
    String match_date;
    String flags1;
    String flags2;
    String group;


    public String getStad_name() 
        return stad_name;
    
    public void setStad_name(String stad_name) 
        this.stad_name = stad_name;
    
    public String getTeam1() 
        return team1;
    
    public void setTeam1(String team1) 
        this.team1 = team1;
    
    public String getTeam2() 
        return team2;
    
    public void setTeam2(String team2) 
        this.team2 = team2;
    
    public String getMatch_date() 
        return match_date;
    
    public void setMatch_date(String match_date) 
        this.match_date = match_date;
    
    public String getFlags1() 
        return flags1;
    
    public void setFlags1(String flags1) 
        this.flags1 = flags1;
    
    public String getFlags2() 
        return flags2;
    
    public void setFlags2(String flags2) 
        this.flags2 = flags2;
    
    public String getGroup() 
        return group;
    
    public void setGroup(String group) 
        this.group = group;
    



这是我迄今为止在 BaseAdapter

中所写的

CustomAdapterMatchSchedule.java

package com.devleb.expandablelistdemo3;

import java.util.ArrayList;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

public class CustomAdapterMatchSchedule extends BaseAdapter 

    LayoutInflater layoutInflater;
    ArrayList<ItemDetails> itemdetailList;
    Context context;

    public CustomAdapterMatchSchedule(Context c, ArrayList<ItemDetails> listOfItem)
        this.context = c;
        itemdetailList = listOfItem;
    

    @Override
    public int getCount() 
        // TODO Auto-generated method stub
        return itemdetailList.size();
    

    @Override
    public Object getItem(int position) 
        // TODO Auto-generated method stub
        return itemdetailList.get(position);
    

    @Override
    public long getItemId(int position) 
        // TODO Auto-generated method stub
        return position;
    

    @Override
    public View getView(int position, View convertView, ViewGroup arg2) 
        // TODO Auto-generated method stub

        ItemDetails itemListDetails = itemdetailList.get(position);

        if(convertView == null)
            LayoutInflater inflater =  (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            convertView = inflater.inflate(R.layout.row_list_match_schedule, null);
        
        //Stad_name
        TextView txtStadName = (TextView)convertView.findViewById(R.id.textLocation);
        txtStadName.setText(itemListDetails.getStad_name());
        //team1
        TextView txtTeam1 = (TextView)convertView.findViewById(R.id.textName1);
        txtTeam1.setText(itemListDetails.getTeam1());
        //team2
        TextView txtTeam2 = (TextView)convertView.findViewById(R.id.textName2);
        txtTeam2.setText(itemListDetails.getTeam2());
        //flag1
        TextView txtflag1 = (TextView)convertView.findViewById(R.id.imageView1);
        txtflag1.setText(itemListDetails.getTeam1());

        //flag2

        return null;
    


【问题讨论】:

【参考方案1】:

这是最合适的方式,特别是因为每个列表视图行包含很多项目。如果你想在点击的行上获取项目,它就变成了一个步行,不到 10 行代码。至于我担心,这是最好的方法。不用担心,我也是用的。

【讨论】:

好的,我将继续以这种方式工作,希望能够奏效。谢谢你的回答 不客气,如果遇到困难,请随时向我提问。 我编辑我的代码你能帮我吗? this is the link

以上是关于我有从 sqlite 检索数据并在 BaseAdapter 中显示数据的 android 应用程序 .. 最好的方法是啥?的主要内容,如果未能解决你的问题,请参考以下文章

检索在 sqlite 数据库中插入的所有行,并在包含标签的表视图单元格中显示为具有不同部分的子视图

是否有从 Google Play 商店检索应用产品收入的 API? [关闭]

Python tkinter - 从 ttk.combobox 中检索 SQLite ID。

c# sqlite - 从数据库中检索 BLOB 文本

无法从带有意外字符的 sqlite3 文件中检索数据

在 AsyncTask 上尝试使用 SQLite 检索数据的奇怪行为