在自定义列表视图中显示我的数组列表结果

发布于 2024-12-04 06:59:04 字数 462 浏览 3 评论 0原文

我想使用自定义列表视图显示我的数组列表结果。

现在我正在使用 android 布局显示我的结果。

setListAdapter(new StudentListAdapter(this,android.R.layout.simple_list_item_1, results));

我有两个字段来显示

  1. Locimage(来自 ImageUrl 的图像)
  2. Locname(并排)

文件位于: 错误/AndroidRuntime(335):引起:java.lang.NullPointerException

I want to display my arraylist results by using custom list view.

for now i'm displaying my results by using android layout.

setListAdapter(new StudentListAdapter(this,android.R.layout.simple_list_item_1, results));

I've two fields to display

  1. Locimage(Image from ImageUrl)
  2. Locname (side by side)

files are here: ERROR/AndroidRuntime(335): Caused by: java.lang.NullPointerException

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

没企图 2024-12-11 06:59:04

由于您使用的是自定义列表适配器并且您已覆盖 getView 方法,我认为以下行:

setListAdapter(new StudentListAdapter(this,android.R.layout.simple_list_item_1, results));

应该是:

setListAdapter(new StudentListAdapter(this, results));

Since you're using a custom list adapter and you have overridden the getView method I think the following line:

setListAdapter(new StudentListAdapter(this,android.R.layout.simple_list_item_1, results));

Should be:

setListAdapter(new StudentListAdapter(this, results));
战皆罪 2024-12-11 06:59:04

最终,您将需要重写您正在使用的适配器类的 getView() 方法。只需快速谷歌搜索即可找到大量示例。

这是非常基本的东西: http://sudarmuthu.com/blog/ using-arrayadapter-and-listview-in-android-applications

这是一个更复杂的:http://www.softwarepassion.com/android-series-custom-列表视图项目和适配器/

Ultimately, you're going to need to override the getView() method of the adapter class you're using. Just a quick google search found plenty of examples.

Here's something really basic: http://sudarmuthu.com/blog/using-arrayadapter-and-listview-in-android-applications

And here's a more complex one: http://www.softwarepassion.com/android-series-custom-listview-items-and-adapters/

幸福%小乖 2024-12-11 06:59:04

试试这个代码

import java.util.ArrayList;
import android.app.ListActivity;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;

public class FindPlaces extends Activity{

  private SQLiteDatabase DbLoc;
  ListView lv;
  private ArrayList<Fields> results = new ArrayList<Fields>();
  @Override
  public void onCreate(Bundle savedInstance) {
     super.onCreate(savedInstance);
    setContentView(R.layout.places);
    getallLocs();
    displayLocs();

}
private void displayLocs() {
    lv = (ListView)findViewById(R.id.listPlaces);
    lv.setAdapter(new StudentListAdapter(this,results));
}
class StudentListAdapter extends BaseAdapter<Fields>{
    private ArrayList<Fields> locationDetails;
    private Context mContext;

    public StudentListAdapter(Context context, ArrayList<Fields> results) {
        // TODO Auto-generated constructor stub
        System.out.println("Constructor StudentList Adapter...");
        this.locationDetails = results;
        this.mContext = context;
    }


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

    @Override
    public Fields getItem(int position) {
        // TODO Auto-generated method stub
        return locationDetails.get(position);
    }
    @Override
    public long getItemId(int position) {
        // TODO Auto-generated method stub
        return super.getItemId(position);
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // TODO Auto-generated method stub
        View v = convertView;
        if(v == null){
            LayoutInflater vl = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            v = vl.inflate(R.layout.placeslist, null);
        }
        Fields o = locationDetails.get(position);

        if (o != null) {

            TextView iv = (TextView)v.findViewById(R.id.toptext);
            TextView tv_sNo = (TextView)v.findViewById(R.id.toptext1);
            iv.setText(o.getLocationName());                            
            tv_sNo.setText(o.getLocationImage());   

        }
       return v;
    }       
}
static class ViewHolder
{
    TextView Locationname;
    ImageView Locationimage;
}
private void getallLocs() {
    // TODO Auto-generated method stub
    try {
        DatabaseHelper dbHelper = new DatabaseHelper(
                this.getApplicationContext());
        DbLoc = dbHelper.getWritableDatabase();
        Cursor c = DbLoc.rawQuery("SELECT " + DatabaseHelper.LocationName+ " , " + DatabaseHelper.LocationImage + " FROM "
                + DatabaseHelper.LOCATIONTABLE , null);
                        if (c != null) {
            if (c.moveToFirst()) {
                do {
                    String LocationName= c.getString(c.getColumnIndex("LocationName"));
                    String Mobile = c.getString(c
                            .getColumnIndex("LocationImage"));
                    Fields p = new Fields(LocationName, Mobile);
                    results.add(p);

                } while (c.moveToNext());
            }
        }
    } catch (SQLiteException se) {
        Log.e(getClass().getSimpleName(),
        "Could not create or Open the database");
    } 
    finally { if (DbLoc != null) DbLoc.execSQL("DELETE FROM " +
            DatabaseHelper.FRIENDTABLE); DbLoc.execSQL("DELETE FROM " +
                    DatabaseHelper.LOCATIONTABLE);  
            DbLoc.execSQL("DROP TABLE IF EXISTS tablename"+ DatabaseHelper.FRIENDTABLE);
            DbLoc.execSQL("DROP TABLE IF EXISTS tablename"+ DatabaseHelper.LOCATIONTABLE);
            DbLoc.close();
    }
}
}

try this code

import java.util.ArrayList;
import android.app.ListActivity;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;

public class FindPlaces extends Activity{

  private SQLiteDatabase DbLoc;
  ListView lv;
  private ArrayList<Fields> results = new ArrayList<Fields>();
  @Override
  public void onCreate(Bundle savedInstance) {
     super.onCreate(savedInstance);
    setContentView(R.layout.places);
    getallLocs();
    displayLocs();

}
private void displayLocs() {
    lv = (ListView)findViewById(R.id.listPlaces);
    lv.setAdapter(new StudentListAdapter(this,results));
}
class StudentListAdapter extends BaseAdapter<Fields>{
    private ArrayList<Fields> locationDetails;
    private Context mContext;

    public StudentListAdapter(Context context, ArrayList<Fields> results) {
        // TODO Auto-generated constructor stub
        System.out.println("Constructor StudentList Adapter...");
        this.locationDetails = results;
        this.mContext = context;
    }


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

    @Override
    public Fields getItem(int position) {
        // TODO Auto-generated method stub
        return locationDetails.get(position);
    }
    @Override
    public long getItemId(int position) {
        // TODO Auto-generated method stub
        return super.getItemId(position);
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // TODO Auto-generated method stub
        View v = convertView;
        if(v == null){
            LayoutInflater vl = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            v = vl.inflate(R.layout.placeslist, null);
        }
        Fields o = locationDetails.get(position);

        if (o != null) {

            TextView iv = (TextView)v.findViewById(R.id.toptext);
            TextView tv_sNo = (TextView)v.findViewById(R.id.toptext1);
            iv.setText(o.getLocationName());                            
            tv_sNo.setText(o.getLocationImage());   

        }
       return v;
    }       
}
static class ViewHolder
{
    TextView Locationname;
    ImageView Locationimage;
}
private void getallLocs() {
    // TODO Auto-generated method stub
    try {
        DatabaseHelper dbHelper = new DatabaseHelper(
                this.getApplicationContext());
        DbLoc = dbHelper.getWritableDatabase();
        Cursor c = DbLoc.rawQuery("SELECT " + DatabaseHelper.LocationName+ " , " + DatabaseHelper.LocationImage + " FROM "
                + DatabaseHelper.LOCATIONTABLE , null);
                        if (c != null) {
            if (c.moveToFirst()) {
                do {
                    String LocationName= c.getString(c.getColumnIndex("LocationName"));
                    String Mobile = c.getString(c
                            .getColumnIndex("LocationImage"));
                    Fields p = new Fields(LocationName, Mobile);
                    results.add(p);

                } while (c.moveToNext());
            }
        }
    } catch (SQLiteException se) {
        Log.e(getClass().getSimpleName(),
        "Could not create or Open the database");
    } 
    finally { if (DbLoc != null) DbLoc.execSQL("DELETE FROM " +
            DatabaseHelper.FRIENDTABLE); DbLoc.execSQL("DELETE FROM " +
                    DatabaseHelper.LOCATIONTABLE);  
            DbLoc.execSQL("DROP TABLE IF EXISTS tablename"+ DatabaseHelper.FRIENDTABLE);
            DbLoc.execSQL("DROP TABLE IF EXISTS tablename"+ DatabaseHelper.LOCATIONTABLE);
            DbLoc.close();
    }
}
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文