public abstract class

AbsSavedState

extends java.lang.Object

 java.lang.Object

↳androidx.customview.view.AbsSavedState

Subclasses:

CoordinatorLayout.SavedState, DrawerLayout.SavedState, RecyclerView.SavedState, ViewPager.SavedState, Toolbar.SavedState

Gradle dependencies

compile group: 'androidx.customview', name: 'customview', version: '1.2.0-alpha02'

  • groupId: androidx.customview
  • artifactId: customview
  • version: 1.2.0-alpha02

Artifact androidx.customview:customview:1.2.0-alpha02 it located at Google repository (https://maven.google.com/)

Androidx artifact mapping:

androidx.customview:customview com.android.support:customview

Androidx class mapping:

androidx.customview.view.AbsSavedState android.support.v4.view.AbsSavedState

Overview

A Parcelable implementation that should be used by inheritance hierarchies to ensure the state of all classes along the chain is saved.

Summary

Fields
public static final <any>CREATOR

public static final AbsSavedStateEMPTY_STATE

Constructors
protectedAbsSavedState(Parcel source)

Constructor used when reading from a parcel.

protectedAbsSavedState(Parcelable superState)

Constructor called by derived classes when creating their SavedState objects

protectedAbsSavedState(Parcel source, java.lang.ClassLoader loader)

Constructor used when reading from a parcel.

Methods
public intdescribeContents()

public final ParcelablegetSuperState()

public voidwriteToParcel(Parcel dest, int flags)

from java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait

Fields

public static final AbsSavedState EMPTY_STATE

public static final <any> CREATOR

Constructors

protected AbsSavedState(Parcelable superState)

Constructor called by derived classes when creating their SavedState objects

Parameters:

superState: The state of the superclass of this view

protected AbsSavedState(Parcel source)

Constructor used when reading from a parcel. Reads the state of the superclass.

Parameters:

source: parcel to read from

protected AbsSavedState(Parcel source, java.lang.ClassLoader loader)

Constructor used when reading from a parcel. Reads the state of the superclass.

Parameters:

source: parcel to read from
loader: ClassLoader to use for reading

Methods

public final Parcelable getSuperState()

public int describeContents()

public void writeToParcel(Parcel dest, int flags)

Source

/*
 * Copyright 2018 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package androidx.customview.view;

import android.annotation.SuppressLint;
import android.os.Parcel;
import android.os.Parcelable;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;

/**
 * A {@link Parcelable} implementation that should be used by inheritance
 * hierarchies to ensure the state of all classes along the chain is saved.
 */
@SuppressLint("BanParcelableUsage")
public abstract class AbsSavedState implements Parcelable {
    public static final AbsSavedState EMPTY_STATE = new AbsSavedState() {};

    private final Parcelable mSuperState;

    /**
     * Constructor used to make the EMPTY_STATE singleton
     */
    private AbsSavedState() {
        mSuperState = null;
    }

    /**
     * Constructor called by derived classes when creating their SavedState objects
     *
     * @param superState The state of the superclass of this view
     */
    protected AbsSavedState(@NonNull Parcelable superState) {
        if (superState == null) {
            throw new IllegalArgumentException("superState must not be null");
        }
        mSuperState = superState != EMPTY_STATE ? superState : null;
    }

    /**
     * Constructor used when reading from a parcel. Reads the state of the superclass.
     *
     * @param source parcel to read from
     */
    protected AbsSavedState(@NonNull Parcel source) {
        this(source, null);
    }

    /**
     * Constructor used when reading from a parcel. Reads the state of the superclass.
     *
     * @param source parcel to read from
     * @param loader ClassLoader to use for reading
     */
    protected AbsSavedState(@NonNull Parcel source, @Nullable ClassLoader loader) {
        Parcelable superState = source.readParcelable(loader);
        mSuperState = superState != null ? superState : EMPTY_STATE;
    }

    @Nullable
    public final Parcelable getSuperState() {
        return mSuperState;
    }

    @Override
    public int describeContents() {
        return 0;
    }

    @Override
    public void writeToParcel(Parcel dest, int flags) {
        dest.writeParcelable(mSuperState, flags);
    }

    public static final Creator<AbsSavedState> CREATOR = new ClassLoaderCreator<AbsSavedState>() {
        @Override
        @SuppressWarnings("deprecation")
        public AbsSavedState createFromParcel(Parcel in, ClassLoader loader) {
            Parcelable superState = in.readParcelable(loader);
            if (superState != null) {
                throw new IllegalStateException("superState must be null");
            }
            return EMPTY_STATE;
        }

        @Override
        public AbsSavedState createFromParcel(Parcel in) {
            return createFromParcel(in, null);
        }

        @Override
        public AbsSavedState[] newArray(int size) {
            return new AbsSavedState[size];
        }
    };
}