由于 zapl 没有将他的评论转化为答案,所以我这样做了。
有没有更好的方法来处理父调用和可分割对象的链接?
实现此目的的规范方法是使用自己的类来保存派生的数据View.BaseSavedState http://developer.android.com/reference/android/view/View.BaseSavedState.html,这又源自AbsSavedState http://developer.android.com/reference/android/view/AbsSavedState.html。您可以致电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
}
以上内容改编自这个演示文稿 https://speakerdeck.com/cyrilmottier/crafting-custom-android-views?slide=38由 Cyril Mottier 编写,但也应该与设计者一般如何使用此类的意图非常匹配。
我是否应该将此返回的对象包含为我自己的成员Parcelable
表示和使用Parcel.writeParcelable https://developer.android.com/reference/android/os/Parcel.html#writeParcelable%28android.os.Parcelable,%20int%29如果需要的话将其与我自己的数据一起整理?
虽然上面提到的似乎是优选的,幕后 https://android.googlesource.com/platform/frameworks/base/+/5fceada31f0dc8f8e003e9c1d0a0ed0363711343/core/java/android/view/AbsSavedState.java它确实依赖于writeParcelable
以及。因此,如果有理由不使用该基类,只需调用writeParcelable
存储超类的状态应该没问题。
加载超类的实例状态时应该使用什么类加载器?
The 目前的实施AbsSavedState https://android.googlesource.com/platform/frameworks/base/+/5fceada31f0dc8f8e003e9c1d0a0ed0363711343/core/java/android/view/AbsSavedState.java确实使用null
作为类加载器参数,导致使用默认类加载器。但是,该行代码标有FIXME
评论,所以有一天它可能会改变。