public final class

Insets

extends java.lang.Object

 java.lang.Object

↳androidx.core.graphics.Insets

Gradle dependencies

compile group: 'androidx.core', name: 'core', version: '1.15.0-alpha02'

  • groupId: androidx.core
  • artifactId: core
  • version: 1.15.0-alpha02

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

Androidx artifact mapping:

androidx.core:core com.android.support:support-compat

Overview

An Insets instance holds four integer offsets which describe changes to the four edges of a Rectangle. By convention, positive values move edges towards the centre of the rectangle.

Insets are immutable so may be treated as values.

Summary

Fields
public final intbottom

public final intleft

public static final InsetsNONE

public final intright

public final inttop

Methods
public static Insetsadd(Insets a, Insets b)

Add two Insets.

public booleanequals(java.lang.Object o)

Two Insets instances are equal if they belong to the same class and their fields are pairwise equal.

public inthashCode()

public static Insetsmax(Insets a, Insets b)

Returns the component-wise maximum of two Insets.

public static Insetsmin(Insets a, Insets b)

Returns the component-wise minimum of two Insets.

public static Insetsof(int left, int top, int right, int bottom)

Return an Insets instance with the appropriate values.

public static Insetsof(Rect r)

Return an Insets instance with the appropriate values.

public static Insetssubtract(Insets a, Insets b)

Subtract two Insets.

public static InsetstoCompatInsets(android.graphics.Insets insets)

Return a copy of the given instance, converted to be an Insets instance from AndroidX.

public android.graphics.InsetstoPlatformInsets()

Return a copy this instance, converted to be an instance from the platform.

public java.lang.StringtoString()

public static Insetswrap(android.graphics.Insets insets)

from java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait

Fields

public static final Insets NONE

public final int left

public final int top

public final int right

public final int bottom

Methods

public static Insets of(int left, int top, int right, int bottom)

Return an Insets instance with the appropriate values.

Parameters:

left: the left inset
top: the top inset
right: the right inset
bottom: the bottom inset

Returns:

Insets instance with the appropriate values

public static Insets of(Rect r)

Return an Insets instance with the appropriate values.

Parameters:

r: the rectangle from which to take the values

Returns:

an Insets instance with the appropriate values

public static Insets add(Insets a, Insets b)

Add two Insets.

Parameters:

a: The first Insets to add.
b: The second Insets to add.

Returns:

a + b, i. e. all insets on every side are added together.

public static Insets subtract(Insets a, Insets b)

Subtract two Insets.

Parameters:

a: The minuend; the value from which b will be subtracted.
b: The subtrahend; the value which will be subtracted from a.

Returns:

a - b, i. e. all insets on every side are subtracted from each other.

public static Insets max(Insets a, Insets b)

Returns the component-wise maximum of two Insets.

Parameters:

a: The first Insets.
b: The second Insets.

Returns:

an Insets instance where the inset on each side is the larger of the insets on that side from a and b.

public static Insets min(Insets a, Insets b)

Returns the component-wise minimum of two Insets.

Parameters:

a: The first Insets.
b: The second Insets.

Returns:

an Insets instance where the inset on each side is the smaller of the insets on that side from a and b.

public boolean equals(java.lang.Object o)

Two Insets instances are equal if they belong to the same class and their fields are pairwise equal.

Parameters:

o: the object to compare this instance with.

Returns:

true iff this object is equal o

public int hashCode()

public java.lang.String toString()

public static Insets wrap(android.graphics.Insets insets)

Deprecated: Use Insets.toCompatInsets(android.graphics.Insets) instead.

public static Insets toCompatInsets(android.graphics.Insets insets)

Return a copy of the given instance, converted to be an Insets instance from AndroidX.

public android.graphics.Insets toPlatformInsets()

Return a copy this instance, converted to be an instance from the platform.

Source

/*
 * Copyright 2019 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.core.graphics;

import static androidx.annotation.RestrictTo.Scope.LIBRARY_GROUP_PREFIX;

import android.graphics.Rect;

import androidx.annotation.NonNull;
import androidx.annotation.RequiresApi;
import androidx.annotation.RestrictTo;

/**
 * An Insets instance holds four integer offsets which describe changes to the four
 * edges of a Rectangle. By convention, positive values move edges towards the
 * centre of the rectangle.
 * <p>
 * Insets are immutable so may be treated as values.
 */
public final class Insets {
    @NonNull
    public static final Insets NONE = new Insets(0, 0, 0, 0);

    public final int left;
    public final int top;
    public final int right;
    public final int bottom;

    private Insets(int left, int top, int right, int bottom) {
        this.left = left;
        this.top = top;
        this.right = right;
        this.bottom = bottom;
    }

    // Factory methods

    /**
     * Return an Insets instance with the appropriate values.
     *
     * @param left   the left inset
     * @param top    the top inset
     * @param right  the right inset
     * @param bottom the bottom inset
     * @return Insets instance with the appropriate values
     */
    @NonNull
    public static Insets of(int left, int top, int right, int bottom) {
        if (left == 0 && top == 0 && right == 0 && bottom == 0) {
            return NONE;
        }
        return new Insets(left, top, right, bottom);
    }

    /**
     * Return an Insets instance with the appropriate values.
     *
     * @param r the rectangle from which to take the values
     * @return an Insets instance with the appropriate values
     */
    @NonNull
    public static Insets of(@NonNull Rect r) {
        return of(r.left, r.top, r.right, r.bottom);
    }

    /**
     * Add two Insets.
     *
     * @param a The first Insets to add.
     * @param b The second Insets to add.
     * @return a + b, i. e. all insets on every side are added together.
     */
    @NonNull
    public static Insets add(@NonNull Insets a, @NonNull Insets b) {
        return Insets.of(a.left + b.left, a.top + b.top, a.right + b.right, a.bottom + b.bottom);
    }

    /**
     * Subtract two Insets.
     *
     * @param a The minuend; the value from which {@code b} will be subtracted.
     * @param b The subtrahend; the value which will be subtracted from {@code a}.
     * @return a - b, i. e. all insets on every side are subtracted from each other.
     */
    @SuppressWarnings("unused")
    @NonNull
    public static Insets subtract(@NonNull Insets a, @NonNull Insets b) {
        return Insets.of(a.left - b.left, a.top - b.top, a.right - b.right, a.bottom - b.bottom);
    }

    /**
     * Returns the component-wise maximum of two Insets.
     *
     * @param a The first Insets.
     * @param b The second Insets.
     * @return an {@code Insets} instance where the inset on each side is the larger of
     *         the insets on that side from {@code a} and {@code b}.
     */
    @NonNull
    public static Insets max(@NonNull Insets a, @NonNull Insets b) {
        return Insets.of(Math.max(a.left, b.left), Math.max(a.top, b.top),
                Math.max(a.right, b.right), Math.max(a.bottom, b.bottom));
    }

    /**
     * Returns the component-wise minimum of two Insets.
     *
     * @param a The first Insets.
     * @param b The second Insets.
     * @return an {@code Insets} instance where the inset on each side is the smaller of
     *         the insets on that side from {@code a} and {@code b}.
     */
    @NonNull
    public static Insets min(@NonNull Insets a, @NonNull Insets b) {
        return Insets.of(Math.min(a.left, b.left), Math.min(a.top, b.top),
                Math.min(a.right, b.right), Math.min(a.bottom, b.bottom));
    }

    /**
     * Two Insets instances are equal if they belong to the same class and their fields are
     * pairwise equal.
     *
     * @param o the object to compare this instance with.
     * @return true iff this object is equal {@code o}
     */
    @SuppressWarnings("RedundantIfStatement")
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;

        Insets insets = (Insets) o;

        if (bottom != insets.bottom) return false;
        if (left != insets.left) return false;
        if (right != insets.right) return false;
        if (top != insets.top) return false;

        return true;
    }

    @Override
    public int hashCode() {
        int result = left;
        result = 31 * result + top;
        result = 31 * result + right;
        result = 31 * result + bottom;
        return result;
    }

    @NonNull
    @Override
    public String toString() {
        return "Insets{left=" + left + ", top=" + top
                + ", right=" + right + ", bottom=" + bottom + '}';
    }

    /**
     * @deprecated Use {@link #toCompatInsets(android.graphics.Insets)} instead.
     */
    @RequiresApi(api = 29)
    @NonNull
    @Deprecated
    @RestrictTo(LIBRARY_GROUP_PREFIX)
    public static Insets wrap(@NonNull android.graphics.Insets insets) {
        return toCompatInsets(insets);
    }

    /**
     * Return a copy of the given {@link android.graphics.Insets} instance, converted to be an
     * {@link Insets} instance from AndroidX.
     */
    @RequiresApi(api = 29)
    @NonNull
    public static Insets toCompatInsets(@NonNull android.graphics.Insets insets) {
        return Insets.of(insets.left, insets.top, insets.right, insets.bottom);
    }

    /**
     * Return a copy this instance, converted to be an {@link android.graphics.Insets} instance
     * from the platform.
     */
    @RequiresApi(29)
    @NonNull
    public android.graphics.Insets toPlatformInsets() {
        return Api29Impl.of(left, top, right, bottom);
    }

    @RequiresApi(29)
    static class Api29Impl {
        private Api29Impl() {
            // This class is not instantiable.
        }

        static android.graphics.Insets of(int left, int top, int right, int bottom) {
            return android.graphics.Insets.of(left, top, right, bottom);
        }
    }
}