Как сохранить состояние выбранного элемента spinner/dropdown при изменении ориентации?
Я использую выпадающий список spinner в моем коде, в котором у меня есть от 4 до 5 динамически заполненных значений, скажем, если у меня есть "яблоки" по умолчанию, и я выбираю "апельсины" из выпадающего списка и поворачиваю экран в пейзаж из портрета, он возвращается к "яблокам" по умолчанию вместе с связанным с ним видом.Как сохранить состояние таким образом, чтобы при выборе "апельсины" и повороте в ландшафт оно заполняло выбранное значение / оставалось в том же выбранном состоянии и сохраняло вид нетронутым/заполняло вид, выбранный в портретном режиме, соответствующем выбранному значению. Вот код адаптера, который я использую для того же:
public class MarketsSpinnerAdapter extends CustomRowAdapter<AdapterRow> {
private List<AdapterRow> mRenderList;
public MarketsSpinnerAdapter(final Context context, final List<AdapterRow> renderList) {
super(context);
mRenderList = new ArrayList<AdapterRow>();
mRenderList.addAll(renderList);
}
@Override
protected void setEntries(final List<AdapterRow> renderList) {
mRenderList = renderList;
}
@Override
protected List<AdapterRow> getEntries() {
return mRenderList;
}
@Override
public View getDropDownView(final int position, final View convertView, final ViewGroup parent) {
return getEntries().get(position).getDropDownView(mContext, convertView);
}
}
соответствующее использование в соответствующем фрагменте:
private void populateCategoryRows(final Cursor cursor) {
mCategories.clear();
mAllCategories.clear();
cursor.moveToPosition(-1);
Map<String, String> categoryParentNames = new HashMap<String, String>();
int selectedPosition = 0;
String previousHeader = "";
String previousAllHeader = "";
while (cursor.moveToNext()) {
final int categoryLevel = cursor.getInt(cursor.getColumnIndex(MarketsCategory.Columns.LEVEL));
final String categoryName = cursor.getString(cursor.getColumnIndex(MarketsCategory.Columns.NAME));
final String categoryDisplayName = cursor.getString(cursor.getColumnIndex(MarketsCategory.Columns.DISPLAY_NAME));
if (categoryLevel == 1) {
categoryParentNames.put(categoryName, categoryDisplayName);
}
}
cursor.moveToPosition(-1);
while (cursor.moveToNext()) {
final int categoryLevel = cursor.getInt(cursor.getColumnIndex(MarketsCategory.Columns.LEVEL));
final boolean categoryIsDefault = cursor.getInt(cursor.getColumnIndex(MarketsCategory.Columns.IS_DEFAULT)) == 1;
final boolean categoryIsSelected = cursor.getInt(cursor.getColumnIndex(MarketsCategory.Columns.IS_SELECTED)) == 1;
final String categoryParent = cursor.getString(cursor.getColumnIndex(MarketsCategory.Columns.PARENT));
final String categoryName = cursor.getString(cursor.getColumnIndex(MarketsCategory.Columns.NAME));
final String categoryDisplayName = cursor.getString(cursor.getColumnIndex(MarketsCategory.Columns.DISPLAY_NAME));
if (categoryLevel == 2 ) {
String categoryParentDisplayName = categoryParentNames.get(categoryParent);
if (!categoryParent.equals(previousHeader)) {
if (categoryIsSelected) {
mCategories.add(new CategoryHeader(categoryParentDisplayName));
previousHeader = categoryParent;
}
}
if (!categoryParent.equals(previousAllHeader)) {
mAllCategories.add(new CategoryHeader(categoryParentDisplayName));
previousAllHeader = categoryParent;
}
if (categoryIsSelected) {
mCategories.add(new SpinnerMarketCategoryRow(categoryName, categoryDisplayName, categoryParent));
}
mAllCategories.add(new MarketsCategoryCheckableRow(categoryName, categoryDisplayName, categoryIsSelected, categoryIsDefault));
if(categoryIsDefault){
selectedPosition = mCategories.size()-1;
}
}
}
mSpinnerAdapter = new MarketsSpinnerAdapter(Application.getAppContext(), mCategories);
headerView.setSpinnerAdapter(mSpinnerAdapter);
headerView.setSpinnerSelectedItemPosition(selectedPosition);
}
if (selectedItem instanceof SpinnerMarketCategoryRow) {
selectedCategory = (SpinnerMarketCategoryRow) mSpinnerAdapter.getItem(position);
} else {
if (mSpinnerAdapter.getCount() - 1 >= position + 1) {
selectedCategory = (SpinnerMarketCategoryRow) mSpinnerAdapter.getItem(position + 1);
} else {
selectedCategory = (SpinnerMarketCategoryRow) mSpinnerAdapter.getItem(position - 1);
}
}
final MarketsFragment parentFragment = (MarketsFragment) getParentFragment();
parentFragment.onCategorySelected(selectedCategory.getCategoryName(), selectedCategory.getCategoryParentName());
}
@Override
public void showResults(final Uri uri) {
LayoutUtils.showResults(getView(), headerView.getSpinnerId());
headerView.setVisibility(View.VISIBLE);
}
@Override
public void showNoResults(final Uri uri) {
final MarketsFragment parentFragment = (MarketsFragment) getParentFragment();
parentFragment.hideSpinner();
//LayoutUtils.showNoResult(getView(), headerView.getSpinnerId());
}
@Override
public void onDismiss(DialogInterface dialog) {
headerView.setSelected(false);
}
@Override
public void onNothingSelected(IcsAdapterView<?> parent) {
}
какие идеи?
спасибо!
2 ответов
вы можете сделать это нравится...
@Override
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
outState.putInt("yourSpinner", yourSpinner.getSelectedItemPosition());
// do this for each or your Spinner
// You might consider using Bundle.putStringArray() instead
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// initialize all your visual fields
if (savedInstanceState != null) {
yourSpinner.setSelection(savedInstanceState.getInt("yourSpinner", 0));
// do this for each of your text views
}
}
надеюсь, что это помогает
если конфигурация устройства (как определено ресурсы.Конфигурация класс), то все, что отображает пользовательский интерфейс, необходимо будет обновить, чтобы соответствовать этой конфигурации и поэтому ваш Activity
если вы не укажете иначе, изменение конфигурации (например, изменение ориентации экрана, языка, устройств ввода и т. д.) приведет к уничтожению вашей текущей деятельности, проходящей через нормальный Activity lifecycle process
of onPause (), onStop () и onDestroy() по мере необходимости.
если действие было на переднем плане или видно пользователю, один раз onDestroy() вызывается в этом экземпляре, тогда будет создан новый экземпляр действия, с любым savedInstanceState предыдущий экземпляр был создан из onSaveInstanceState(Bundle)
.
это делается потому, что любой ресурс приложения, включая файлы макета, может изменяться на основе любого значения конфигурации. В каком-то особенном случаи (так же, как и ваш, если я прав, если у вас есть только spinner/dropdown на текущем UI, и вам не нужно проходить полный жизненный цикл активности), вы можете захотеть обойти перезапуск вашей деятельности на основе одного или нескольких типов изменений конфигурации. Это делается с помощью android: configChanges атрибут в манифесте и / или вы также можете использовать данные метода onsaveinstance(комплект) который является вызывающим, когда активность уничтожается и воссозданы из begening.
вы просто есть два пути для решения этой problem_
1_
- добавить android: configChanges= "ориентация" в файле манифеста ваш тег.
<?xml version="1.0" encoding="utf-8"?>
<manifest ...
>
<application ...
>
<activity
android:name="SpinnerActivity"
android:configChanges="orientation" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
- 2, переопределить onConfigurationChanged, который вызывается системой когда конфигурация устройства изменяется во время выполнения действия.
@Override
public void onConfigurationChanged(Configuration newConfig) {
super.onConfigurationChanged(newConfig);
int orientation = newConfig.orientation;
switch (orientation) {
case Configuration.ORIENTATION_LANDSCAPE:
// do what you want when user is in LANDSCAPE
break;
case Configuration.ORIENTATION_PORTRAIT:
// do what you want when user is in PORTRAIT
break;
}
}
2_
используйте методы, используемые для хранения значений в данные метода onsaveinstance():
protected void onSaveInstanceState(Bundle savedInstanceState) {
super.onSaveInstanceState(savedInstanceState);
//Put your spinner values to restore later...
savedInstanceState.putLong("yourSpinnerValKey", yourSpinner.getSelectedItemPosition());
}
и восстановить значения, в onCreate():
public void onCreate(Bundle savedInstanceState) {
if (savedInstanceState!= null) {
//get your values to restore...
value = savedInstanceState.getLong("param");
}
}
это, безусловно, решает вашу проблему, и он не будет обновлять ваш счетчик при изменении ориентации экрана. Надеюсь, это поможет вам и всем остальным! :)