如何在Android Spinner中设置数据?

7

我已经成功地从下拉列表中获取了一个值并将其存储在数据库中,但是当要返回时,我无法将 Text 设置到 Spinner 中。我该如何做才能像对待EditText 的其他函数一样呢?

这是我的代码:

public class MainActivity_spinner extends Activity
{
     Button save;
     Button show;
     public void onCreate(Bundle savedInstanceState)
     {
          super.onCreate(savedInstanceState);
          setContentView(R.layout.main);
          String[] items = new String[] {" ","Male","Female"};
          final Spinner gender =(Spinner)findViewById(R.id.sex);
          ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_spinner_item, items);
          adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
          gender.setAdapter(adapter);
          save=(Button)findViewById(R.id.save);
          show=(Button)findViewById(R.id.show);
           //----------------------------------------------------------------    
          save.setOnClickListener(new Button.OnClickListener() {
              public void onClick(View view){
                   ContentValues values = new ContentValues();
                   values.put("sex",gender.getSelectedItem().toString());
                   sql.Insert("db",null,values);
                   sql.Close();
              }
          });
          show.setOnClickListener(new Button.OnClickListener() {
              public void onClick(View view){
                   sql.open();
                   String query = "select sex from db where id=2";
                   Cursor c = sql.rawQuery(query,null);
                   c.moveToFirst();
                   (Error is here)it is my spinner i want show value >>>>>>          gender.setSelection(c.getString(0), true);     
              }
          });
    }
}

我从下拉列表中将第二项保存到了我的数据库中。现在我的下拉列表已重置。然后,我点击了“显示”按钮。我所保存的那一项将作为数据出现在下拉列表中。为什么会失败呢?


你想将数据从数据库设置到Spinner还是从EditText?你能详细解释一下吗? - Narendra Pal
请参考以下链接:http://developer.android.com/guide/topics/ui/controls/spinner.html。 - Akram
1个回答

11

如果我理解得没错的话,您想找到一种方法来将文本设置为 spinner 中的选定项,该 spinner 中包含您在列表中拥有的数据库项。

如果是这样,那么这可能会对您有所帮助:

示例:

  ArrayList<String> options=new ArrayList<String>();
    ...onCreate(){
      ...
      Cursor c=<your cursor with value>;
      for(loop for total records){
           options.add(<value from cursor>);
      }
      //now you have options with all values of your database

      ArrayAdapter<String> adapter = new ArrayAdapter<String>(getApplicationContext(), android.R.layout.simple_spinner_item,options);
      mSpinner.setAdapter(adapter); // this will set list of values to spinner

      mSpinner.setSelection(options.indexOf(<value you want to show selected>)));//set selected value in spinner
    }

这将会像这样:

你在数据库中有以下选项:

1.苹果

2.橙子

3.菠萝

4.草莓

5.葡萄

现在,你想要显示已选择的菠萝,则使用以下代码:

mSpinner.setSelection(options.indexOf("pineapple")));

这行代码将会相应地进行设置。

编辑 : 尝试使用以下代码:

public class MainActivity_spinner extends Activity
{
     Button save;
     Button show;
     ArrayList<String> items=new ArrayList<String>();
     Spinner gender;

     public void onCreate(Bundle savedInstanceState)
     {
          super.onCreate(savedInstanceState);
          setContentView(R.layout.main);
          items.add("Male");
          items.add("Female");

          gender =(Spinner)findViewById(R.id.sex);
          ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_spinner_item, items);              
          gender.setAdapter(adapter);

          save=(Button)findViewById(R.id.save);
          show=(Button)findViewById(R.id.show);
           //----------------------------------------------------------------    
          save.setOnClickListener(new Button.OnClickListener() {
              public void onClick(View view){
                   ContentValues values = new ContentValues();
                   values.put("sex",gender.getSelectedItem().toString());
                   sql.Insert("db",null,values);
                   sql.Close();
              }
          });
          show.setOnClickListener(new Button.OnClickListener() {
              public void onClick(View view){
                   sql.open();
                   String query = "select sex from db where id=2";
                   Cursor c = sql.rawQuery(query,null);
                   c.moveToFirst();
                   gender.setSelection(items.indexOf(c.getString(0)));     
              }
          });
    }
}

你只需要做以下操作:estado_instlacao.setSelection(options.indexOf("Adequada"))); - Hiral Vadodaria
如果我想这样使用,是因为没有特定的estado_instalcao.setSelection(options.index(c.getString(0)); - user1551503
我还没有理解你的问题。我无法弄清楚你对estado_instalcao的问题是什么。 - Hiral Vadodaria
Hiral,我的实际旋转器已经有了物品,我不知道这个物品是从数据库中来的,请现在检查我的代码。 - user1551503
很高兴能帮忙!! :) (顺便说一下,我是女生! :P) - Hiral Vadodaria

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接