Когда я создаю свое действие, я настраиваю Spinner, назначаю ему слушателя и начальное значение. Я знаю, что обратный вызов onItemSelected
вызывается автоматически во время инициализации приложения. Что мне показалось странным, так это то, что это происходит дважды при повороте устройства, что вызывает у меня некоторые проблемы, которые мне придется как-то обойти. Этого не происходит, если начальный выбор счетчика равен нулю. Мне удалось изолировать проблему, вот простейшее действие, вызывающее ее:
public class MainActivity extends Activity implements OnItemSelectedListener {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.i("Test","Activity onCreate");
setContentView(R.layout.activity_main);
((Spinner)findViewById(R.id.spinner1)).setSelection(2);
((Spinner)findViewById(R.id.spinner1)).setOnItemSelectedListener(this);
}
@Override
public void onItemSelected(AdapterView<?> spin, View selview, int pos, long selId)
{
Log.i("Test","spin:"+spin+" sel:"+selview+" pos:"+pos+" selId:"+selId);
}
@Override
public void onNothingSelected(AdapterView<?> arg0) {}
}
А вот логарифм, отображаемый, когда приложение запускается, а затем устройство вращается:
I/Test( 9881): spin:android.widget.Spinner@4052f508 sel:android.widget.TextView@40530b08 pos:2 selId:2
I/Test( 9881): Activity onCreate
I/Test( 9881): spin:android.widget.Spinner@40535d80 sel:android.widget.TextView@40538758 pos:2 selId:2
I/Test( 9881): spin:android.widget.Spinner@40535d80 sel:android.widget.TextView@40538758 pos:2 selId:2
Это ожидаемое поведение? Я что-то упускаю?