Android: получить позицию от SimpleCursorAdapter - PullRequest
0 голосов
/ 09 августа 2011

Я хотел бы установить положение элемента счетчика, но счетчик заполняется простым курсором с данными из базы данных. Я хотел бы получить текущую строку из базы данных, а затем установить спиннер на это значение. Я знаю, что с помощью адаптера массива я могу получить позицию от адаптера следующим образом:

String myString = queryData.getString(queryData.getColumnIndex("myString"));

//cast to an ArrayAdapter
mySpinnerAdapter adapter = (mySpinnerAdapter) mySpinner.getAdapter(); 
int spinnerPosition = ?

//set the default according to value
mySpinner.setSelection(spinnerPosition);

Но есть ли способ получить позицию элемента из SimpleCursorAdapter? В прошлом я всегда строил массив данных моего счетчика рядом с курсором, но это кажется грязным способом сделать это. Если это единственный путь, хотя ...

Ответы [ 2 ]

0 голосов
/ 17 августа 2011

Даже я сталкиваюсь с той же проблемой.После нескольких часов разбивания головы я нашел это решение.Я надеюсь, что это поможет вам.

/// value is column name in DB. take value from                     
final String[] from = new String[] {"value"}; 
/// field in spinner. Put value into (keep "R.id.text1" as it is..)
final int[] to = new int[]{R.id.text1};

// Get Database Access Object to interact with DB

DataAccessObject dataAccessObject = new DataAccessObject(context);

final Cursor valueCursor = dataAccessObject.querySpinnerValues();

final SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(
        context, R.layout.spinner_row_layout, valueCursor,
        from , to );        

// when ever a field is selected in the spinner's "spinner.setOnItemSelectedListener" method will be called 
// and the primary key
// associted with that particular value will be saved into "someFieldPkMap" map or you can choose other collection..or some
// instance variable..
// 
// Note : Here i am fetching two columns fron DB. 
// 1. "_id" Primary key should always be "_id" otherwise it will not work
// 2. "value" which will be displayed in the spinner. this column can be anything. but you need to map it. The way i did eg..

// final String[] from = new String[] {"value"}; /// value is column name in DB. take value from
// final int[] to = new int[]{R.id.text1}; /// field in spinner. Put value into (keep "R.id.text1" as it is..)
//  
spinner.setOnItemSelectedListener(new OnItemSelectedListener() {
    public void onItemSelected(AdapterView<?> parent, View view, int position, long id)
    {           

        valueCursor.moveToPosition(position);                       

        // Get the primary Key associated with the value...  
        // Use "someFieldPkMap" map to get the primary key
        someFieldPkMap.put(fieldName, Integer.parseInt(valueCursor.getString(0)));                          
    }
    public void onNothingSelected(AdapterView<?> arg0) {}
});

spinner.setAdapter(simpleCursorAdapter);
0 голосов
/ 09 августа 2011

Вы можете получить позицию элемента, выполнив это:

ArrayList<View> views = new ArrayList<View>();
listView1.reclaimViews(views);
for (int i = 0; i < views.size(); i++)
{
    View v = views.get(i);
    // Get the view's text value and compare it with your string here
    // If the two strings match, store the position, which is 'i' in this case
    // If your view is a textview, you would do this:
    TextView tv = (TextView)v.findViewById(R.id.textView1);
    if (tv.getText().toString().toLowerCase().compareTo(textToCompare.toLowerCase()) == 0)
    {
        // Store position here
    }
}
...