android.database.sqlite.SQLiteCursor@435b9ba0

时间:2010-01-16 00:54:29

标签: android android-widget spinner

我从spinner.getSelectedItem()。toString()调用返回文本'android.database.sqlite.SQLiteCursor@435b9ba0'。我不知道为什么。微调器绑定到SimpleCursorAdapter。

这是代码

    cCategories = (Cursor) myAdapter.getAllCategories();
    this.startManagingCursor(cCategories);

    SimpleCursorAdapter scaCategories = new SimpleCursorAdapter(this, R.layout.track_category_item,cCategories,new String[] {DBAdapter.KEY_CATEGORIES_NAME},new int[]{R.id.text1});
    scaCategories.setDropDownViewResource(R.layout.track_category_dropdown_item); 
    mCatSpinner = (Spinner) findViewById(R.id.thecategory);
    mCatSpinner.setAdapter(scaCategories);

    if(mCatSpinner.isSelected() != true) {
        mCatSpinner.setSelection(0);
    }

和xml track_category_item.xml

<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/text1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="@android:id/text1"
    style="?android:attr/spinnerItemStyle"
    android:ellipsize="marquee"
    android:singleLine="true">
</TextView>

track_category_dropdown_item.xml

<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"           
    android:id="@+id/text1"
    style="?android:attr/spinnerDropDownItemStyle"
    android:singleLine="true"
    android:layout_width="fill_parent"
    android:layout_height="?android:attr/listPreferredItemHeight"
    android:ellipsize="marquee" />

spinner xml看起来像这样

<Spinner
    android:id="@+id/thecategory"
    android:prompt="@string/SELECT_CATEGORY"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_x="15px"
    android:layout_y="133px" >
</Spinner>

并且返回的光标是

public Cursor getAllCategories() 
{
    return db.query(DATABASE_CATEGORIES_TABLE, new String[] {
            KEY_CATEGORIES_ROWID,
            KEY_CATEGORIES_NAME,
            KEY_CATEGORIES_DEFAULT}, 
            null, 
            null, 
            null, 
            null, 
            null);
}

微调器似乎正常工作。当我尝试保存时,这是使用spinner.getSelectedItem()。toString()作为所选项的值传递的内容。

任何人都会在这里看到任何错误的错误。不知道该怎么做。

感谢 帕特里克

2 个答案:

答案 0 :(得分:6)

您的代码在您编写时正常工作。 SpinnerAdapterView。您连接的适配器是SimpleCursorAdapter。这意味着所选项目是Cursor(位于Cursor结果集中与用户选择对应的项目)。 Cursor的默认实现为toString(),返回android.database.sqlite.SQLiteCursor@435b9ba0之类的内容。

由于您没有告诉我们您要做什么,因此无法准确地为您提供建议。但是,无论您想要保存什么,都需要从Cursor获得getSelectedItem()

答案 1 :(得分:1)

我可能会费心阅读你的背景,但只想简单地帮忙。 我有一个以DbHelper.KEY_COL命名的列,我正在检索特定行的DbHelper.KEY_COL值。 也许我的一些代码会有所帮助:

Cursor colCur=(Cursor)spCols.getSelectedItem();
String col=colCur.getString(colCur.getColumnIndex(DbHelper.KEY_COL));