覆盖onSaveInstanceState

时间:2013-09-25 12:19:06

标签: android override android-view parcelable instancestate

我正试图掌握onSaveInstanceState method in class View(不是the one in class Activity)。该方法确实返回Parcelable。我从View派生了我自己的ViewGroup并覆盖了该方法以保存我自己的状态。但是当国家被拯救时,我得到了一个例外:

java.lang.IllegalStateException:
Derived class did not call super.onSaveInstanceState()

这是真的,但简单地调用这种方法对我来说似乎不够。那我该怎么做呢?如果该方法将被传递Parcel来写入,我可以简单地将同一个包传递给超类,这样就可以按顺序写入。但这是一个回报值。

我是否应该将此返回的对象作为我自己的Parcelable表示的成员包含在内,如果需要,可以使用Parcel.writeParcelable将其与我自己的数据一起编组?或者是否有更好的方法来处理父调用和可分割对象的链接?如果是这样,我在加载超类的实例状态时应该使用哪个类加载器?

1 个答案:

答案 0 :(得分:4)

由于zapl没有将他的评论转化为答案,我正在这样做。

  

有没有更好的方法来处理父调用和可分配对象的链接?

实现此目标的规范方法是,为View.BaseSavedState派生的已保存数据创建自己的类,而后者又来自AbsSavedState。您可以调用父类的onSaveInstance处理程序,并将结果对象传递给您自己的类的构造函数。在恢复数据时,getSuperState会将实例定位到父类。

典型的代码示例如下所示:

static class SavedState extends View.BaseSavedState {
  // include own data members here
  public SavedState(Parcelable superState) {
    super(superState);
  }
  private SavedState(Parcel in) {
    super(in);
    // read own data here
  }
  @Override public void writeToParcel(Parcel out, int flags) {
    super.writeToParcel(out, flags);
    // write own data here
  }
  public static final Parcelable.Creator<SavedState> CREATOR =
      new Parcelable.Creator<SavedState>() {
    public SavedState createFromParcel(Parcel in) { return SavedState(in); }
    public SavedState[] newArray(int size) { return new SavedState[size]; }
  };
}

@Override public Parcelable onSaveInstanceState() {
  SavedState state = new SavedState(super.onSaveInstanceState());
  // set data members here
  return state;
}

@Override public void onRestoreInstanceState(Parcelable parcelable) {
  SavedState state = (SavedState)parcelable;
  super.onRestoreInstanceState(state.getSuperState());
  // restore from data members here
}

以上内容改编自Cyril Mottier的this presentation,但也应该与设计师一般打算如何使用这个类一致。

  

我是否应该将此返回的对象作为我自己的Parcelable表示的成员包含在内,如果需要,可以使用Parcel.writeParcelable将其与我自己的数据一起编组?

虽然上面提到的上述内容似乎更受欢迎,behind the scenes它也依赖于writeParcelable。因此,如果有理由不使用该基类,只需调用writeParcelable来存储超类的状态应该没问题。

  

在加载超类的实例状态时,我应该使用哪个类加载器?

current implementation of AbsSavedState确实使用null作为类加载器参数,导致使用默认的类加载器。但是,该行代码标有FIXME条评论,因此有一天可能会更改。