InsetDrawable


public class InsetDrawable
extends DrawableWrapper

java.lang.Object
   ↳ android.graphics.drawable.Drawable
     ↳ android.graphics.drawable.DrawableWrapper
       ↳ android.graphics.drawable.InsetDrawable


A Drawable that insets another Drawable by a specified distance or fraction of the content bounds. This is used when a View needs a background that is smaller than the View's actual bounds.

It can be defined in an XML file with the <inset> element. For more information, see the guide to Drawable Resources.

Summary

XML attributes

android:drawable Reference to a drawable resource to use for the frame. 
android:insetBottom  
android:insetLeft  
android:insetRight  
android:insetTop  
android:visible Provides initial visibility state of the drawable; the default value is false. 

Public constructors

InsetDrawable(Drawable drawable, float inset)

Creates a new inset drawable with the specified inset.

InsetDrawable(Drawable drawable, float insetLeftFraction, float insetTopFraction, float insetRightFraction, float insetBottomFraction)

Creates a new inset drawable with the specified insets in fraction of the view bounds.

InsetDrawable(Drawable drawable, int inset)

Creates a new inset drawable with the specified inset.

InsetDrawable(Drawable drawable, int insetLeft, int insetTop, int insetRight, int insetBottom)

Creates a new inset drawable with the specified insets in pixels.

Public methods

void applyTheme(Resources.Theme t)

Applies the specified theme to this Drawable and its children.

int getIntrinsicHeight()

Returns the drawable's intrinsic height.

int getIntrinsicWidth()

Returns the drawable's intrinsic width.

int getOpacity()

This method is deprecated. This method is no longer used in graphics optimizations

Insets getOpticalInsets()

Return in insets the layout insets suggested by this Drawable for use with alignment operations during layout.

void getOutline(Outline outline)

Called to get the drawable to populate the Outline that defines its drawing area.

boolean getPadding(Rect padding)

Return in padding the insets suggested by this Drawable for placing content inside the drawable's bounds.

void inflate(Resources r, XmlPullParser parser, AttributeSet attrs, Resources.Theme theme)

Inflate this Drawable from an XML resource optionally styled by a theme.

Protected methods

void onBoundsChange(Rect bounds)

Override this in your subclass to change appearance if you vary based on the bounds.

Inherited methods

XML attributes

android:drawable

Reference to a drawable resource to use for the frame. If not given, the drawable must be defined by the first child tag.

May be a reference to another resource, in the form "@[+][package:]type/name" or a theme attribute in the form "?[package:]type/name".

android:insetBottom

android:insetLeft

android:insetRight

android:insetTop

android:visible

Provides initial visibility state of the drawable; the default value is false. See Drawable.setVisible(boolean, boolean).

May be a boolean value, such as "true" or "false".

Public constructors

InsetDrawable

Added in API level 26
public InsetDrawable (Drawable drawable, 
                float inset)

Creates a new inset drawable with the specified inset.

Parameters
drawable Drawable: The drawable to inset. This value may be null.

inset float: Inset in fraction (range: [0, 1)) of the inset content bounds.

InsetDrawable

Added in API level 26
public InsetDrawable (Drawable drawable, 
                float insetLeftFraction, 
                float insetTopFraction, 
                float insetRightFraction, 
                float insetBottomFraction)

Creates a new inset drawable with the specified insets in fraction of the view bounds.

Parameters
drawable Drawable: The drawable to inset. This value may be null.

insetLeftFraction float: Left inset in fraction (range: [0, 1)) of the inset content bounds.

insetTopFraction float: Top inset in fraction (range: [0, 1)) of the inset content bounds.

insetRightFraction float: Right inset in fraction (range: [0, 1)) of the inset content bounds.

insetBottomFraction float: Bottom inset in fraction (range: [0, 1)) of the inset content bounds.

InsetDrawable

Added in API level 1
public InsetDrawable (Drawable drawable, 
                int inset)

Creates a new inset drawable with the specified inset.

Parameters
drawable Drawable: The drawable to inset. This value may be null.

inset int: Inset in pixels around the drawable.

InsetDrawable

Added in API level 1
public InsetDrawable (Drawable drawable, 
                int insetLeft, 
                int insetTop, 
                int insetRight, 
                int insetBottom)

Creates a new inset drawable with the specified insets in pixels.

Parameters
drawable Drawable: The drawable to inset. This value may be null.

insetLeft int: Left inset in pixels.

insetTop int: Top inset in pixels.

insetRight int: Right inset in pixels.

insetBottom int: Bottom inset in pixels.

Public methods

applyTheme

Added in API level 21
public void applyTheme (Resources.Theme t)

Applies the specified theme to this Drawable and its children.

Parameters
t Resources.Theme: This value cannot be null.

getIntrinsicHeight

Added in API level 1
public int getIntrinsicHeight ()

Returns the drawable's intrinsic height.

Intrinsic height is the height at which the drawable would like to be laid out, including any inherent padding. If the drawable has no intrinsic height, such as a solid color, this method returns -1.

Returns
int the intrinsic height, or -1 if no intrinsic height

getIntrinsicWidth

Added in API level 1
public int getIntrinsicWidth ()

Returns the drawable's intrinsic width.

Intrinsic width is the width at which the drawable would like to be laid out, including any inherent padding. If the drawable has no intrinsic width, such as a solid color, this method returns -1.

Returns
int the intrinsic width, or -1 if no intrinsic width

getOpacity

Added in API level 1
public int getOpacity ()

This method is deprecated.
This method is no longer used in graphics optimizations

Return the opacity/transparency of this Drawable. The returned value is one of the abstract format constants in PixelFormat: PixelFormat.UNKNOWN, PixelFormat.TRANSLUCENT, PixelFormat.TRANSPARENT, or PixelFormat.OPAQUE.

An OPAQUE drawable is one that draws all all content within its bounds, completely covering anything behind the drawable. A TRANSPARENT drawable is one that draws nothing within its bounds, allowing everything behind it to show through. A TRANSLUCENT drawable is a drawable in any other state, where the drawable will draw some, but not all, of the content within its bounds and at least some content behind the drawable will be visible. If the visibility of the drawable's contents cannot be determined, the safest/best return value is TRANSLUCENT.

Generally a Drawable should be as conservative as possible with the value it returns. For example, if it contains multiple child drawables and only shows one of them at a time, if only one of the children is TRANSLUCENT and the others are OPAQUE then TRANSLUCENT should be returned. You can use the method resolveOpacity(int, int) to perform a standard reduction of two opacities to the appropriate single output.

Note that the returned value does not necessarily take into account a custom alpha or color filter that has been applied by the client through the setAlpha(int) or setColorFilter(ColorFilter) methods. Some subclasses, such as BitmapDrawable, ColorDrawable, and GradientDrawable, do account for the value of setAlpha(int), but the general behavior is dependent upon the implementation of the subclass.

Returns
int int The opacity class of the Drawable. Value is PixelFormat.UNKNOWN, PixelFormat.TRANSLUCENT, PixelFormat.TRANSPARENT, or PixelFormat.OPAQUE

getOpticalInsets

Added in API level 29
public Insets getOpticalInsets ()

Return in insets the layout insets suggested by this Drawable for use with alignment operations during layout.

Returns
Insets This value cannot be null.

getOutline

Added in API level 21
public void getOutline (Outline outline)

Called to get the drawable to populate the Outline that defines its drawing area.

This method is called by the default ViewOutlineProvider to define the outline of the View.

The default behavior defines the outline to be the bounding rectangle of 0 alpha. Subclasses that wish to convey a different shape or alpha value must override this method.

Parameters
outline Outline: This value cannot be null.

getPadding

Added in API level 1
public boolean getPadding (Rect padding)

Return in padding the insets suggested by this Drawable for placing content inside the drawable's bounds. Positive values move toward the center of the Drawable (set Rect.inset).

Parameters
padding Rect: This value cannot be null.

Returns
boolean true if this drawable actually has a padding, else false. When false is returned, the padding is always set to 0.

inflate

Added in API level 21
public void inflate (Resources r, 
                XmlPullParser parser, 
                AttributeSet attrs, 
                Resources.Theme theme)

Inflate this Drawable from an XML resource optionally styled by a theme. This can't be called more than once for each Drawable. Note that framework may have called this once to create the Drawable instance from XML resource.

Parameters
r Resources: This value cannot be null.

parser XmlPullParser: This value cannot be null.

attrs AttributeSet: This value cannot be null.

theme Resources.Theme: This value may be null.

Throws
IOException
XmlPullParserException

Protected methods

onBoundsChange

Added in API level 1
protected void onBoundsChange (Rect bounds)

Override this in your subclass to change appearance if you vary based on the bounds.

Parameters
bounds Rect: This value cannot be null.