1

SQliteandroidでを使用してテーブルを正常に作成しました。データベースには性別(男性/女性)の列があります。私がやりたいのは、性別のタイプを確認し、タイプに応じて男性/女性のアイコンを表示することです。setViewBinder()列インデックス(正確にはわからない列)を渡すものを使用しましたが、これを使用して性別列を確認できると思います。これを行うためのより良い方法はありますか?

        ListView lv=(ListView)findViewById(R.id.mylist);


         dbh = new DatabaseHelper(this);

           c = dbh.getReadableDatabase().rawQuery("SELECT _id, " + 
                   DatabaseHelper.NAME + 
           ", " + DatabaseHelper.LASTNAME + 
           ", " + DatabaseHelper.ans2 + ", " + DatabaseHelper.SEX + 
           " FROM " +
           DatabaseHelper.TABLE_NAME, null); // initializing 


  String[] dataFrom ={DatabaseHelper.NAME, DatabaseHelper.LASTNAME, DatabaseHelper.ans2, DatabaseHelper.SEX};
  int[] dataTo = {R.id.name, R.id.value1, R.id.value2, R.id.icon};

  SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, 
               R.layout.row, c, dataFrom, dataTo);
  adapter.setViewBinder(new ViewBinder(){


       public boolean setViewValue(View view, Cursor cursor,
               int columnIndex) {
           if (view.getId() == R.id.icon) {
               int sex = cursor.getInt(columnIndex);
               String s = String.valueOf(sex);
               if (s == "male") {
                   ((ImageView) view).setImageResource(R.drawable.male);
               } else if (s == "female"){
                   ((ImageView) view).setImageResource(R.drawable.female);
               }

               return true;    
           } else {
               return false;
           }

       }

   });
lv.setAdapter(adapter);
4

2 に答える 2

2

メソッド bindView を使用すると、次を受け取るため、データを簡単に設定/確認できます。

  • カーソルを実際の位置に配置します
  • データを配置できるビュー
于 2012-04-16T00:14:01.277 に答える
2
 if (s == "male")

それを変更してください

if (s.equals("male"))
于 2012-04-30T11:32:34.043 に答える