在"更新"下找到我的问题检查代码
好的,我在将Sqlite中的正确值加载到我的Spinner时遇到问题。这是我的应用程序的构建方式
我的onCreate()通过以下方式设置一个名为spinTypes的微调器:
public class MyClass extends Activity{
// local members . . .
.
.
.
//spinner
private Spinner spinTypes, spinNames = null;
// string array decl.
private String [] types, names1, names2, names3 = null;
// array adapters for string arrays
private ArrayAdapter<String> typesAdapter, names1Adapter,
names2Adapter, names3Adapter;
// create a Dbhelper object to access the db
private DbHelper mdbHelper = null;
// on create
@Override
public void onCreate(Bundle savedIstanceState){
// call to super class
// set my content view
// instantiate all members
// Dbhelper object to access the db
mdbHelper = new DbHelper(getBaseContext());
// spinners
spinTypes = (Spinner) findViewById(R.id.spin_types);
spinNames = (Spinner) findViewById(R.id.spin_names);
// get string arrays from resources and create a ArrayAdapter<string>
types = getResources().getStringArray(R.array.types);
typesAdapter = new ArrayAdapter<String>(getBaseContext(),
android.R.layout.simple_spinner_item, types);
typesAdapter. setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
// want to create a dynamic spinner based on these arrays
names1 = getResources().getStringArray(R.array.names_1);
names2 = getResources().getStringArray(R.array.names_2);
names3 = getResources().getStringArray(R.array.names_3);
// do this for all names++ arrays
names1Adapter = new ArrayAdapter<String>(getBaseContext(),
android.R.layout.simple_spinner_item, names1);
names1Adapter. setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
// etc . . . for the other two
// set the adapter for the types spinner
spinTypes.setAdapter(typesAdapter);
}
我有一个创建方法可以将我的所有数据插入到数据库中工作正常,我的问题是当我想尝试填充微调器以编辑条目时。
该应用程序的工作方式如下:按下添加按钮以弹出一个对话框,该对话框在调用视图中创建一个列表项。我使用两个微调器来创建它,一个用于根据类型动态填充第二个名称微调器的类型。
当我访问数据库对象时,我从微调器返回字符串但由于某种原因,当我创建我的if语句检查数组中字符串的位置时,第二个微调器每次都设置位置0。
包括上面提到的if语句的方法如下:
public void populate(){
mdbHelper.open();
// if there is an item create a cursor rowId != null
Cursor mTypes = mdbHelper.fetchItem(rowId);
if(mTypes.moveToFirst()){
String tType = mTypes.getString(mTypes.getColumnIndexOrThrow(DbAdapter.KEY_TYPE));
String tName = mTypes.getString(mTypes.getColumnIndexOrThrow(DbAdapter.KEY_NAME));
int t = spinTypes.getPosition(tType);
spinTypes.setSelection(t);
// ** this does not seem to do the job i want it to**
if(t == 0){
spinNames.setAdapter(names1Adapter); // set the adapter based on t value
int n1 = names1Adapter.getPosition(tName); // use name return from db to get pos
spinNames.setSelection(n1); // set the position
}else if(t ==1){
spinNames.setAdapter(names2Adapter);
int n2 = names1Adapter.getPosition(tName);
spinNames.setSelection(n2);
}else{
spinNames.setAdapter(names3Adapter);
int n3 = names3Adapter.getPosition(tName);
spinNames.setSelection(n3);
}
}// end populate
} // end class
微调器都可以工作但是它们不会以我返回的tName结束。
任何人都可以帮忙吗?
**我正在记录从db返回的名称并使用它来查找错误中项目的索引并返回正确的值,但是微调器仍然默认为0 **
任何人都知道我的错误可能是什么?请
更新(下面发布的最终代码) 为了理解我的所作所为,我做了相当多的改动,你应该读完这篇文章,这样你就不会错过任何东西!
在onCreate()
之前添加了一个变量
private int spinNamePos;
在onCreate()
// add a listener to the spinner
spinTypes.setOnItemSelectedListener(TypesListener);
并按原样创建了这个监听器
OnItemSelectedListener TypesListener = new OnItemSelectedListener(){
public void onItemSelected(AdapterView<?> parent, View view, int pos, long id){
// use the position of this spinner to set the second spinner
switch(pos){
case 0 :
spinNames.setAdapter(names1Adapter);
break;
//etc. . for the other two
case 1:
// etc
break;
}
case 2:
// etc
break;
}
// created an int for the position of the second spinner before calling onCreate()
// and use it to set this spinners position
spinNames.setSelection(spinNamePos);
// this value is grabbed in onSavedInstanceState() and used to set the pos when onRestoreInstanceState() is called to handle orientation changes and activity paused
}
};
然后我改变了我的onPopulate()
,因此调用了一种新的方法来设置第二个微调器的位置
public void populate(){
mdbHelper.open();
// if there is an item create a cursor rowId != null
Cursor mTypes = mdbHelper.fetchItem(rowId);
if(mTypes.moveToFirst()){
String tType = mTypes.getString(mTypes.getColumnIndexOrThrow(DbAdapter.KEY_TYPE));
String tName = mTypes.getString(mTypes.getColumnIndexOrThrow(DbAdapter.KEY_NAME));
int t = spinTypes.getPosition(tType);
spinTypes.setSelection(t);
// call to the new method
spinNamePos = setSpinNamesPos( t, tName);
// set the position
spinNames.setSelection(spinNamePos)
}// end populate
// new method to set the position when i want to update/change the list item
private int setSpinNamesPos(int m, String name){
int pos = 0;
switch(m){
case 0:
pos = names1Adapter.getPosition(name);
break;
case 1:
pos = names2Adapter.getPosition(name);
break;
case 2:
pos = names3Adapter.getPosition(name);
break;
}
return pos;
}
很高兴看到这项工作可以鼓励任何问题或评论
答案 0 :(得分:1)
好的,几周后我似乎已经找到了自己的答案!我遇到的问题是我不知道每次为OnItemSelectedListener()
设置adapter
时我的spinner
都会被调用。
现在意识到这一点,我在spinner
中设置了第一个OnItemSelectedListener()
,然后使用此spinner id
来设置我的第二个spinner
adapter
。(即基于id
我将第二个adapter
的{{1}}设置为3个选项中的1个。)
设置spinner
后,我使用adapter
返回的value
来查找此cursor
中的字符串,并将adapter
设置为{我spinner
中position
的{1}}。
现在一切都很好,我将把上面的最终代码放在 UPDATE 标题下。感谢您的帮助。