BackgroundManager
public final class BackgroundManager
Supports background image continuity between multiple Activities.
An Activity should instantiate a BackgroundManager and attach
to the Activity's window. When the Activity is started, the background is initialized to the current background values stored in a continuity service. The background continuity service is updated as the background is updated.
At some point, for example when it is stopped, the Activity may release its background state.
When an Activity is resumed, if the BackgroundManager has not been released, the continuity service is updated from the BackgroundManager state. If the BackgroundManager was released, the BackgroundManager inherits the current state from the continuity service.
When the last Activity is destroyed, the background state is reset.
Backgrounds consist of several layers, from back to front:
- the background Drawable of the theme
- a solid color (set via
setColor
) - two Drawables, previous and current (set via
setBitmap
orsetDrawable
), which may be in transition
BackgroundManager holds references to potentially large bitmap Drawables. Call release
to release these references when the Activity is not visible.
Summary
Public methods |
|
---|---|
void |
Makes the background visible on the given Window. |
void |
attachToView(View sceneRoot) Adds the composite drawable to the given view. |
void |
Clears the Drawable set by |
final @ColorInt int |
getColor() Returns the current background color. |
Drawable |
This method is deprecated. No longer support dim layer. |
Drawable |
This method is deprecated. No longer support dim layer. |
Drawable |
Returns the current background |
static BackgroundManager |
getInstance(Activity activity) Returns the BackgroundManager associated with the given Activity. |
boolean |
Returns true if the background manager is currently attached; false otherwise. |
boolean |
|
void |
release() Release references to Drawable/Bitmap. |
void |
setAutoReleaseOnStop(boolean autoReleaseOnStop) Enable or disable call release() in Activity onStop(). |
void |
Sets the given bitmap into the background. |
void |
Sets the background to the given color. |
void |
This method is deprecated. No longer support dim layer. |
void |
setDrawable(Drawable drawable) Sets the given drawable into the background. |
void |
setThemeDrawableResourceId(int resourceId) Sets the resource id for the drawable to be shown when there is no background set. |
Public methods
attach
public void attach(Window window)
Makes the background visible on the given Window. The background manager must be attached when the background is set.
attachToView
public void attachToView(View sceneRoot)
Adds the composite drawable to the given view.
clearDrawable
public void clearDrawable()
Clears the Drawable set by setDrawable
or setBitmap
. BackgroundManager will show a solid color set by setColor
or theme drawable if color is not provided.
getInstance
public static BackgroundManager getInstance(Activity activity)
Returns the BackgroundManager associated with the given Activity.
The BackgroundManager will be created on-demand for each individual Activity. Subsequent calls will return the same BackgroundManager created for this Activity.
isAttached
public boolean isAttached()
Returns true if the background manager is currently attached; false otherwise.
isAutoReleaseOnStop
public boolean isAutoReleaseOnStop()
Returns | |
---|---|
boolean |
True if release() in Activity.onStop(), false otherwise. |
release
public void release()
Release references to Drawable/Bitmap. Typically called in Activity onStop() to reduce memory overhead when not visible. It's app's responsibility to restore the drawable/bitmap in Activity onStart(). The method is automatically called in onStop() when isAutoReleaseOnStop
is true.
See also | |
---|---|
setAutoReleaseOnStop |
setAutoReleaseOnStop
public void setAutoReleaseOnStop(boolean autoReleaseOnStop)
Enable or disable call release() in Activity onStop(). Default is true.
Parameters | |
---|---|
boolean autoReleaseOnStop |
True to call release() in Activity onStop(), false otherwise. |
setBitmap
public void setBitmap(Bitmap bitmap)
Sets the given bitmap into the background. When using setCoverImageBitmap to set the background, the provided bitmap will be scaled and cropped to correctly fit within the dimensions of the view. The timing for when this becomes visible in the app is undefined and may take place after a small delay.
setColor
public void setColor(@ColorInt int color)
Sets the background to the given color. The timing for when this becomes visible in the app is undefined and may take place after a small delay.
setDrawable
public void setDrawable(Drawable drawable)
Sets the given drawable into the background. The provided Drawable will be used unmodified as the background, without any scaling or cropping applied to it. The timing for when this becomes visible in the app is undefined and may take place after a small delay.
setThemeDrawableResourceId
public void setThemeDrawableResourceId(int resourceId)
Sets the resource id for the drawable to be shown when there is no background set. Overrides the window background drawable from the theme. This should be called before attaching.