如何使用自定义适配器从图像数据库获取特定记录

时间:2013-05-16 16:51:52

标签: android android-listview android-asynctask nullpointerexception custom-adapter

嗨我自己新手到android,我已经完成了从数据库中搜索特定记录的代码并使用简单的光标适配器显示它的列表,以获取图像也使用我开始使用自定义适配器的数据,代码工作得非常好我尝试从db检索所有数据但是当我将参数传递给db中的方法以搜索特定记录并在列表中显示错误时出现

这是我的代码 用户选择要显示的数据时传递的代码

    Intent i= new Intent(SearchByBed.this,SearchBedView.class);
    Bundle bbed= new Bundle();
    bbed.putString("bedValue", spinn_Bed.getSelectedItem().toString());
    i.putExtras(bbed);
    startActivity(i);

在这部分中,从前一个类传递的参数是catch然后传递给db并想要检索记录并将其绑定到自定义适配器

my asynctask code


public class loadSomeStuff extends AsyncTask<String, Integer, String> {
    ProgressDialog dialog;

    @Override
    protected void onPreExecute() {
        // TODO Auto-generated method stub
        dialog = new ProgressDialog(SearchBedView.this);
        dialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
        dialog.setMax(100);
        dialog.setMessage("Loading Data");
        dialog.show();

    }

    @Override
    protected void onProgressUpdate(Integer... values) {
        // TODO Auto-generated method stub
        dialog.incrementProgressBy(values[0]);
    }

    @Override
    protected String doInBackground(String... params) {
        // TODO Auto-generated method stub
        for (int i = 0; i < 20; i++) {
            publishProgress(5);
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }

        }
        dialog.dismiss();

        return null;
    }

    @Override
    protected void onPostExecute(String result) {
        // TODO Auto-generated method stub
        displaydemo();

    }


}

public void displaydemo() {
    // TODO Auto-generated method stub

    Bundle bbedview = this.getIntent().getExtras();

     name = bbedview.getString("name").toString();    
     //data.setText(name);   //as per log here i was getting null pointer exception but  

     //know commented as it was line from my previous code 

    info = new PropertyInfo(this);
    info.open();
    cursor = info.getBed(name);
    String[] from = new String[] { PropertyInfo.KEY_ROWID,
            PropertyInfo.KEY_TYPE, PropertyInfo.KEY_BEDROOMS,
            PropertyInfo.KEY_STATUS, PropertyInfo.KEY_CITY,
            PropertyInfo.KEY_FURNISHING, PropertyInfo.KEY_TOTPRICE };
    int[] to = new int[] { R.id.rowId, R.id.rowtype, R.id.rowBed,
            R.id.rowStatus, R.id.rowCity, R.id.rowFurnish,
            R.id.rowTotalPrice };
    custAdapter = new CustomContactsAdapterBedView(this, R.layout.row, cursor,
            from, to);

    this.setListAdapter(custAdapter);
           }

虽然这是mycustomadapter类

 public class CustomContactsAdapterBedView extends SimpleCursorAdapter {

    private int layout;
    LayoutInflater inflator;
    TextView tid,ttype,tbed,tstatus,tcity,tfurnish,ttotprice;

    public CustomContactsAdapterBedView(Context context, int layout, Cursor                    c,
            String[] from, int[] to) {
        super(context, layout, c, from, to, 0);
        this.layout = layout;
        inflator = LayoutInflater.from(context);
    }


    public View newView(Context context, Cursor cursor, ViewGroup parent) {
        View v = inflator.inflate(layout, parent, false);
        return v;
    }


    @Override
    public void bindView(View v, final Context context, Cursor c) {
        final String id = c.getString(c.getColumnIndex(PropertyInfo.KEY_ROWID));
        final String type = c
                .getString(c.getColumnIndex(PropertyInfo.KEY_TYPE));
        final String bed = c.getString(c
                .getColumnIndex(PropertyInfo.KEY_BEDROOMS));
        final String status = c.getString(c
                .getColumnIndex(PropertyInfo.KEY_STATUS));
        final String city = c
                .getString(c.getColumnIndex(PropertyInfo.KEY_CITY));
        final String furnish = c.getString(c
                .getColumnIndex(PropertyInfo.KEY_FURNISHING));
        final String totprice = c.getString(c
                .getColumnIndex(PropertyInfo.KEY_TOTPRICE));
        final byte[] image = c.getBlob(c.getColumnIndex(PropertyInfo.IMAGE));
        ImageView iv = (ImageView) v.findViewById(R.id.photo);

        if (image != null) {
            if (image.length > 3) {
                iv.setImageBitmap(BitmapFactory.decodeByteArray(image, 0,
                        image.length));
            }
        }

        tid = (TextView) v.findViewById(R.id.rowId);
        tid.setText(id);

        ttype = (TextView) v.findViewById(R.id.rowtype);
        ttype.setText(type);

        tbed = (TextView) v.findViewById(R.id.rowBed);
        tbed.setText(bed);

        tstatus = (TextView) v.findViewById(R.id.rowStatus);
        tstatus.setText(status);

        tcity = (TextView) v.findViewById(R.id.rowCity);
        tcity.setText(city);

        tfurnish = (TextView) v.findViewById(R.id.rowFurnish);
        tfurnish.setText(furnish);

        ttotprice = (TextView) v.findViewById(R.id.rowTotalPrice);
        ttotprice.setText(totprice);

    }
}

db中的方法如下

         public Cursor getBed(String l) {
    String[] columns = new String[] { KEY_ROWID, KEY_TITLE, KEY_TYPE,
            KEY_BEDROOMS, KEY_STATUS, KEY_CITY, KEY_LOCALITY, KEY_PRICE,
            KEY_TOTPRICE, KEY_FURNISHING, KEY_BALCONIES, KEY_BATHROOM,
            IMAGE };
    Cursor c = ourDatabase.query(DATABASE_TABLE, columns, KEY_BEDROOMS
            + "=" + l, null, null, null, null);
    return c;

}

logcat中的错误是

          05-16 20:33:43.803: E/AndroidRuntime(31444): FATAL EXCEPTION: main
          05-16 20:33:43.803: E/AndroidRuntime(31444): java.lang.NullPointerException
          05-16 20:33:43.803: E/AndroidRuntime(31444):  at 

          com.project.realestate.SearchBedView.displaydemo(SearchBedView.java:299)
          05-16 20:33:43.803: E/AndroidRuntime(31444):  at 

        com.project.realestate.SearchBedView$loadSomeStuff.onPostExecute(SearchBedView.java:281)
         05-16 20:33:43.803: E/AndroidRuntime(31444):   at 

      com.project.realestate.SearchBedView$loadSomeStuff.onPostExecute(SearchBedView.java:1)
         05-16 20:33:43.803: E/AndroidRuntime(31444):   at 
         android.os.AsyncTask.finish(AsyncTask.java:631)
         05-16 20:33:43.803: E/AndroidRuntime(31444):   at   
         android.os.AsyncTask.access$600(AsyncTask.java:177)
         05-16 20:33:43.803: E/AndroidRuntime(31444):   at  
         android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
         05-16 20:33:43.803: E/AndroidRuntime(31444):   at  
         android.os.Handler.dispatchMessage(Handler.java:99)
         05-16 20:33:43.803: E/AndroidRuntime(31444):   at  
         android.os.Looper.loop(Looper.java:137)
         05-16 20:33:43.803: E/AndroidRuntime(31444):   at   
         android.app.ActivityThread.main(ActivityThread.java:5041)
         05-16 20:33:43.803: E/AndroidRuntime(31444):   at
         java.lang.reflect.Method.invokeNative(Native Method)
         05-16 20:33:43.803: E/AndroidRuntime(31444):   at 
         java.lang.reflect.Method.invoke(Method.java:511)
         05-16 20:33:43.803: E/AndroidRuntime(31444):   at  
        com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
        05-16 20:33:43.803: E/AndroidRuntime(31444):    at
        com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
        05-16 20:33:43.803: E/AndroidRuntime(31444):    at 
        dalvik.system.NativeStart.main(Native Method)

请帮我处理我的代码

2 个答案:

答案 0 :(得分:0)

data.setText(name);

我猜数据是EditText或者是textView,你有findViewById

的引用吗?

你必须用单引号和转义序列包含字符串值我修改了行

Cursor c = ourDatabase.query(DATABASE_TABLE, columns, KEY_BEDROOMS
        + "=\'" +l+"\'", null, null, null, null);

答案 1 :(得分:0)

你已经为TextView(或者它的任何小部件)定义了“数据”?

应该定义如下:

TextView data =(TextView)findViewById(R.id。 yourTextView );