我从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()作为所选项的值传递的内容。
任何人都会在这里看到任何错误的错误。不知道该怎么做。
感谢 帕特里克
答案 0 :(得分:6)
您的代码在您编写时正常工作。 Spinner
是AdapterView
。您连接的适配器是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));