- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我似乎无法理解这个 SimpleCursorAdapter
,每次我修复一个错误时,都会弹出另一个错误,如果我按照步骤修复那个错误,第一个错误又会出现。我觉得我在这里绕圈子,所以这是我要调试的代码块,请注意,第一部分只是创建数据库,但我认为任何事情都有助于解决这个问题。
SQLiteDatabase rpgDB = null;
String classFields = " (classID, className, classHP)";
try {
rpgDB = this.openOrCreateDatabase("RpgDB", MODE_PRIVATE, null);
rpgDB.execSQL("DROP TABLE IF EXISTS " + classTable);
rpgDB.execSQL("CREATE TABLE IF NOT EXISTS " + classTable + " (classID INT(3), className TEXT, classHP INT(4));");
rpgDB.execSQL("INSERT INTO " + classTable + classFields + " VALUES (1, 'Warrior', 10);");
rpgDB.execSQL("INSERT INTO " + classTable + classFields + " VALUES (2, 'Rogue', 7);");
rpgDB.execSQL("INSERT INTO " + classTable + classFields + " VALUES (3, 'Mage', 5);");
String query = "SELECT className AS _id FROM " + classTable;
Cursor cursor = rpgDB.rawQuery(query, null);
rpgDB.close();
int[] to = new int[] { R.id.classDropDown };
String[] spinnerFields = new String[] { "_id" };
/**
* Test code to check value of cursor
*/
int count = cursor.getCount();
cursor.moveToFirst();
while (cursor.isAfterLast() == false)
{
String test = cursor.getString(0);
cursor.moveToNext();
}
SimpleCursorAdapter cursorAdapter = new SimpleCursorAdapter(this, R.layout.main, cursor, spinnerFields, to);
int cursorcount = cursorAdapter.getCount();
// cursorAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
Spinner classDropDown = (Spinner) this.findViewById(R.id.classDropDown);
classDropDown.setAdapter(cursorAdapter);
} catch (Exception ex) {
System.out.println("Exception: " + ex);
}
从 SimpleCursorAdapter 填充 Spinner 似乎非常麻烦。
编辑:此代码的错误是
Invalid statement in fill window
如果我注释掉 rpgDB.close() 行
Spinner is not a view that can be bounds by this SimpleCursorAdapter
如果我将 select 语句和 spinnerfields 更改为(数据库被注释掉):
String query = "SELECT className FROM " + classTable;
String[] spinnerFields = new String[] { "className" };
我得到:
column '_id' does not exist
编辑 XML:这是 main.xml(也是 id main)XML
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/main"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical"
android:background="@color/white" >
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:textSize="11pt"
android:text="@string/hello"
android:textColor="@color/baseTextColor" />
<Spinner
android:id="@+id/classDropDown"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>
解释:因此,如果以后有人遇到这个问题,多亏了 Luksprog,我能更好地理解这一点(他向我展示了修复方法):
android.R.id 和 android.R.layout“ids/layouts”是 Android 组件的默认 xml 布局,例如 TextField 和 Spinner“列表”布局。 Spinner 对象本身基本上是不完整的。您需要另一个 XML 部分来定义列表本身的外观,另一个 XML 部分用于定义行(text1 是默认的 android TextField)。
简而言之,将您的“收件人”字段分配给 TextField 或使用默认的 Android 字段之一,例如 android.id.text1,但为了使用它,我相信您还必须使用包含默认的 android 字段,andoid.R.layout(在我的例子中,simple_spinner_item)。最后,将下拉资源设置为您自己的 xml 或 android 默认值(我的是 android.R.layout.simple_spinner_dropdown_item)。
最佳答案
检查这个:
String query = "SELECT _id, className FROM " + classTable;
Cursor cursor = rpgDB.rawQuery(query, null);
int[] to = new int[] { android.R.id.text1 };
String[] spinnerFields = new String[] { "className"};
SimpleCursorAdapter cursorAdapter = new SimpleCursorAdapter(this, android.R.layout.simple_spinner, cursor, spinnerFields, to);
cursorAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
Spinner classDropDown = (Spinner) this.findViewById(R.id.classDropDown);
classDropDown.setAdapter(cursorAdapter);
Invalid statement in fill window
如果您想从那个Cursor
中提取数据,您不能关闭数据库连接。
Spinner is not a view that can be bounds by this SimpleCursorAdapter
to
int 数组表示行布局文件中的 Views
的 ID,您传递给 SimpleCursorAdapter
以绑定(bind)来自from
数组(R.layout.main
,我希望你有一个布局文件,只传递 Activity 的布局)。您在那里使用的 id R.id.classDropDown
代表一个 Spinner
View 和一个 SimpleCursorAdapter
不知道如何将数据绑定(bind)到那个(它可以将数据绑定(bind)到 TextView
或 ImageView
)。如果你想在每一行上都有一个 Spinner
(你真的想要这个吗?还是你想要默认的 spinner 行布局?)然后使用自定义适配器或 SimpleCursorAdapter.ViewBinder
.
column '_id' does not exist
因为在表 classTable
中没有具有此名称的列。此列应声明如下:
INTEGER PRIMARY KEY AUTOINCREMENT
也许你可以查看this simple tutorial对于 Spinners
。
关于android - 在错误之间不断跳动,找不到 Spinner/Adapter 的良好修复,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10894970/
我正在制作一个 android 应用程序,它允许用户在 editText 中输入关键字,当他们点击提交时,下面的 recyclerview 将显示来自 API 请求的结果。 我的 recyclerVi
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我想在我的 Svelte Kit 应用程序中使用 @sveltejs/adapter-static(想把它变成一个 SPA)。 我使用 npm i @sveltejs/adapter-static 安
我有一个简单的表单,在提交重定向到 AuthController 内的 processAction 之后,在这个 action 中我想要创建一个简单的 table bar。 已编辑: 引用Zend f
当我使用 ListView 时,我扩展了 ArrayAdapter 并将数据(一个列表)存储在 ArrayAdapter 中,因此当数据更改时,我调用: adapter.add(item).; 还有另
我有一个使用 Webpack 捆绑的 commonjs 浏览器应用程序( typescript )。它使用 webrtc,所以我想使用 webrtc-adapter package from npm
在 “DesignPatterns: Elements of Reusable Object-Oriented Software” 一书中谈到 C++ 实现 Adapter 模式时,它是这样的这个:
只需要帮助理解 ZF2 中的一些简单数据库查询。在 ZF1 中,我有这样简单的方法: public function recordset() { // listing of all records $
当使用Spring的Java配置时,你一定会看到像WebMvcConfigurerAdapter这样的类& HandlerInterceptorAdapter它们实现单个接口(interface),并
我将 doctrine2 与 ZF2 一起使用,我的一些库与 Zend\Db\Adapter\Adapter 一起使用,其他的与 doctrine2 一起使用。现在,他们两次连接到数据库。是否可以在原
过去几天我一直在工作灯上工作,现在正在尝试制作连接到数据库的应用程序。以下是截图: 1) Worklight\server\conf\worklight.properties 2) mySQLAdap
几年前,我在 this tutorial 之后开始学习 Zend 框架。 .在那里,它显示映射器是使用 Zend\Db\Adapter\Adapter 创建的。类来获取数据库连接,这就是我使用数据库的
我正在学习 RecyclerView 并在 developer 中的站点 Adapter 类扩展 RecyclerView.Adapter 。实现显示: public class MyAdapter
查看文档:http://docs.spring.io/spring-integration/reference/html/ip.html#tcp-adapters我知道适配器仅用于单向通信。但是,这里
当我移动到另一个 fragment 时,我如何恢复分页适配器项状态?我试过下面的文章,但没有用。 https://medium.com/@florina.muntenescu private fun
我正在使用 capistrano 并收到此错误消息: Please install the pg adapter: `gem install activerecord-pg-adapter` (can
我正在尝试在本地主机上安装 Magento 2,当我想连接数据库时出现错误。 错误是: “Magento\Framework\DB\Adapter\Pdo\MysqlFactory”生成的源类“\Ma
我的 Rails 服务器通过正常的开发脚本运行良好,我计划使用 Netbeans for Rails。当我使用 Netbeans 启动我现有的项目并重新启动我的 Webrick 服务器时,它显示错误
运行 Ruby on Rails (RoR) 应用程序或使用 ActiveRecord 框架的 Ruby 代码,您会收到错误消息: Please install the postgresql adap
我在运行 Redmine2.3-stable 时遇到这个错误,随后无法成功安装 mysql2 适配器。 这是错误: Please install the mysql2 adapter: `ge
我是一名优秀的程序员,十分优秀!