适配器未显示正确的字符串

时间:2013-08-30 10:39:17

标签: android android-listview simplecursoradapter android-cursor

我正在开发一个Android应用程序,我想在ListView中使用标题和副标题显示数据库中的一些数据。我做了一个扩展SimpleCursorAdapter的适配器并且它正在工作,但它显示了2个第一个字段,而没有我在方法BindView中选择的内容。我试图找到错误,但我不能,可能是一些非常愚蠢的东西,但错误很难自己找到:-) 这就是适配器的代码:

package com.apeirons.apeironsdatabasemanager;

import android.content.Context;
import android.database.Cursor;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.SimpleCursorAdapter;
import android.widget.TextView;

public class MyListAdapter extends SimpleCursorAdapter {

    //private Context context;
    LayoutInflater inflater;

    @SuppressWarnings("deprecation")
    public MyListAdapter(Context context, int layout, Cursor c, String[] from,
            int[] to) {
        super(context, R.layout.consult, c, from, to);
        inflater = LayoutInflater.from(context);
    }


    public void bindview (View view, Context context, Cursor cursor){
        TextView titulo = (TextView)view.findViewById(R.id.Titulo);
        titulo.setText(cursor.getString(cursor.getColumnIndex("name")));

        TextView subtitulo = (TextView)view.findViewById(R.id.SubTitulo);   
        subtitulo.setText(cursor.getString(cursor.getColumnIndex("kind_place")));

        subtitulo.append(cursor.getString(cursor.getColumnIndex("score")));
    }


    @Override 
    public View newView (Context context, Cursor cursor, ViewGroup parent){

        View v = inflater.inflate(R.layout.entrys, parent, false);      
        return v;
    }
}

这是我使用适配器的地方:

package com.apeirons.apeironsdatabasemanager;

import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.util.Log;
import android.widget.ListView;

public class Consult extends Activity { 
    private ListView list;
    private SQLiteDatabase db;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.consult);

        list = (ListView)findViewById(R.id.list);

        this.getIntent();

        ApeironsSQLiteHelper apeironsdb = new ApeironsSQLiteHelper(this, "DBApeirons.DB", null, 1);

        db = apeironsdb.getReadableDatabase();

        String[] campos = new String[]{"_id", "name", "kind_place", "score"};

        Cursor c = db.query("Apeirons", campos, null, null, null, null, null);

        int cuenta = c.getCount();

        c.moveToFirst();

        Log.d("CONSULTA", Integer.toString(cuenta));

        Log.d("CURSOR", c.getString(c.getColumnIndex("score")));

        String[] from = new String[]{"name", "kind_place", "score"};

        int [] to = new int[] {R.id.Titulo, R.id.SubTitulo};

        //@SuppressWarnings("deprecation")
        MyListAdapter myadapter = new MyListAdapter (this, 
                R.layout.entrys, c, from, to);

        list.setAdapter(myadapter);

    }

}

真的非常感谢你的帮助。

1 个答案:

答案 0 :(得分:1)

您没有覆盖bindView的{​​{1}}方法,而是定义了一个名为SimpleCursorAdapter的新方法(不是大写!)。

因为您的新方法在公共类中是公共的,所以编译器不会警告您它未被使用。 如果您使用了bindview注释,那么编译器会警告您实际上没有覆盖方法......