2

欠点を見つけるために私を案内してくれる人が必要です。電話を受けたり、別のアクティビティに行ったりすると、戻ってきたときにすべてのグループが折りたたまれます。システムはアクティビティを破棄していないため、メソッドが呼び出されないため、onRestoreInstanceStateの状態を保存および復元できません(アクティビティは一時停止および停止されるだけで、破棄されません)。

アクティビティはExpandableListActivityを拡張し、私が使用するアダプターはSimpleCursorTreeAdapterです。

展開可能なリストが折りたたまれているのはどの場合ですか?私は頭がおかしくなり、解決策を見つけることができません。

前もって感謝します。

編集:これは、アクティビティ
が最初に開始されたときのアクティビティのライフサイクルです:
onCreate()-> onStart()-> onResume()
他のアクティビティに移動したとき:
onPause()-> onStop()
そして戻ってきたとき:
onRestart-> onStart()-> onResume()

4

2 に答える 2

2

残念ながら、フォーカスが失われると常に展開状態がリセットされ、再びフォーカスを取得したときにonCreate()が呼び出されず、onStart()が呼び出されます。したがって、今のところ私の回避策は、すべての展開されたアイテムのIDを手動で保存し、それらをonStart()で再度展開することです。動作を再利用するために、ExpandableListActivityのサブクラスを実装しました。

public class PersistentExpandableListActivity extends ExpandableListActivity {

private long[] expandedIds;

@Override
protected void onStart() {
    super.onStart();
    if (this.expandedIds != null) {
        restoreExpandedState(expandedIds);
    }
}

@Override
protected void onStop() {
    super.onStop();
    expandedIds = getExpandedIds();
}

@Override
protected void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
    this.expandedIds = getExpandedIds();
    outState.putLongArray("ExpandedIds", this.expandedIds);
}

@Override
protected void onRestoreInstanceState(Bundle state) {
    super.onRestoreInstanceState(state);
    long[] expandedIds = state.getLongArray("ExpandedIds");
    if (expandedIds != null) {
        restoreExpandedState(expandedIds);
    }
}

private long[] getExpandedIds() {
    ExpandableListView list = getExpandableListView();
    ExpandableListAdapter adapter = getExpandableListAdapter();
    if (adapter != null) {
        int length = adapter.getGroupCount();
        ArrayList<Long> expandedIds = new ArrayList<Long>();
        for(int i=0; i < length; i++) {
            if(list.isGroupExpanded(i)) {
                expandedIds.add(adapter.getGroupId(i));
            }
        }
        return toLongArray(expandedIds);
    } else {
        return null;
    }
}

private void restoreExpandedState(long[] expandedIds) {
    this.expandedIds = expandedIds;
    if (expandedIds != null) {
        ExpandableListView list = getExpandableListView();
        ExpandableListAdapter adapter = getExpandableListAdapter();
        if (adapter != null) {
            for (int i=0; i<adapter.getGroupCount(); i++) {
                long id = adapter.getGroupId(i);
                if (inArray(expandedIds, id)) list.expandGroup(i);
            }
        }
    }
}

private static boolean inArray(long[] array, long element) {
    for (long l : array) {
        if (l == element) {
            return true;
        }
    }
    return false;
}

private static long[] toLongArray(List<Long> list)  {
    long[] ret = new long[list.size()];
    int i = 0;
    for (Long e : list)  
        ret[i++] = e.longValue();
    return ret;
}
}

たぶん誰かがより良い解決策を持っています。

于 2012-04-04T16:46:06.647 に答える
0

アクティビティでonPause()とonResume()をオーバーライドすることにより、状態情報を保存できます。

選択したアイテムを永続化し、アクティビティが再開されたときにアイテムを再選択できるはずです。これをonStop()およびonStart()に追加することもできます。

ただし、アクティビティが一時停止/停止されているだけの場合は、Views破棄および再作成されていないため、すべてのがその状態を保持する必要があります。「大きな」ライフサイクルメソッドのそれぞれにログを追加してみてください。

 protected void onCreate(Bundle savedInstanceState);

 protected void onStart();

 protected void onRestart();

 protected void onResume();

 protected void onPause();

 protected void onStop();

 protected void onDestroy();

ライフサイクルの不整合を追跡するときの最初のステップは、拡張するロギングアクティビティを作成することです。

于 2012-04-04T15:58:38.200 に答える