public
final
class
ShadowOverlayHelper
extends Object
java.lang.Object | |
↳ | android.support.v17.leanback.widget.ShadowOverlayHelper |
ShadowOverlayHelper is a helper class for shadow, overlay color and rounded corner. There are many choices to implement Shadow, overlay color. Initialize it with ShadowOverlayHelper.Builder and it decides the best strategy based on options user choose and current platform version.
ShadowOverlayHelper mHelper = new ShadowOverlayHelper.Builder().
.needsOverlay(true).needsRoundedCorner(true).needsShadow(true)
.build();
mHelper.prepareParentForShadow(parentView); // apply optical-bounds for 9-patch shadow.
mHelper.setOverlayColor(view, Color.argb(0x80, 0x80, 0x80, 0x80));
mHelper.setShadowFocusLevel(view, 1.0f);
...
View initializeView(View view) {
if (mHelper.needsWrapper()) {
ShadowOverlayContainer wrapper = mHelper.createShadowOverlayContainer(context);
wrapper.wrap(view);
return wrapper;
} else {
mHelper.onViewCreated(view);
return view;
}
}
...
Nested classes | |
---|---|
class |
ShadowOverlayHelper.Builder
Builder for creating ShadowOverlayHelper. |
class |
ShadowOverlayHelper.Options
Option values for ShadowOverlayContainer. |
Constants | |
---|---|
int |
SHADOW_DYNAMIC
Shadows depend on the size, shape, and position of the view. |
int |
SHADOW_NONE
No shadow. |
int |
SHADOW_STATIC
Shadows are fixed. |
Public methods | |
---|---|
ShadowOverlayContainer
|
createShadowOverlayContainer(Context context)
Create ShadowOverlayContainer for this helper. |
int
|
getShadowType()
|
boolean
|
needsOverlay()
|
boolean
|
needsRoundedCorner()
|
boolean
|
needsWrapper()
Returns true if a "wrapper" ShadowOverlayContainer is needed. |
void
|
onViewCreated(View view)
Must be called when view is created for cases |
void
|
prepareParentForShadow(ViewGroup parent)
|
static
void
|
setNoneWrapperOverlayColor(View view, int color)
Set overlay color for view other than ShadowOverlayContainer. |
static
void
|
setNoneWrapperShadowFocusLevel(View view, float level)
Set shadow focus level (0 to 1). |
void
|
setOverlayColor(View view, int color)
Set overlay color for view, it can be a ShadowOverlayContainer if needsWrapper() is true, or other view type. |
void
|
setShadowFocusLevel(View view, float level)
Set shadow focus level (0 to 1). |
static
boolean
|
supportsDynamicShadow()
Returns true if the platform sdk supports dynamic shadows. |
static
boolean
|
supportsForeground()
Returns true if view.setForeground() is supported. |
static
boolean
|
supportsRoundedCorner()
Returns true if the platform sdk supports rounded corner through outline. |
static
boolean
|
supportsShadow()
Return true if the platform sdk supports shadow. |
Inherited methods | |
---|---|
From
class
java.lang.Object
|
int SHADOW_DYNAMIC
Shadows depend on the size, shape, and position of the view.
Constant Value: 3 (0x00000003)
int SHADOW_NONE
No shadow.
Constant Value: 1 (0x00000001)
int SHADOW_STATIC
Shadows are fixed.
Constant Value: 2 (0x00000002)
ShadowOverlayContainer createShadowOverlayContainer (Context context)
Create ShadowOverlayContainer for this helper.
Parameters | |
---|---|
context |
Context :
Context to create view. |
Returns | |
---|---|
ShadowOverlayContainer |
ShadowOverlayContainer. |
int getShadowType ()
Returns | |
---|---|
int |
boolean needsOverlay ()
Returns | |
---|---|
boolean |
boolean needsRoundedCorner ()
Returns | |
---|---|
boolean |
boolean needsWrapper ()
Returns true if a "wrapper" ShadowOverlayContainer is needed.
When needsWrapper() is true, call createShadowOverlayContainer(Context)
to create the wrapper.
Returns | |
---|---|
boolean |
void onViewCreated (View view)
Must be called when view is created for cases needsWrapper()
is false.
void prepareParentForShadow (ViewGroup parent)
prepareParentForShadow(ViewGroup)
must be called on parent of container
before using shadow. Depending on Shadow type, optical bounds might be applied.
Parameters | |
---|---|
parent |
ViewGroup
|
void setNoneWrapperOverlayColor (View view, int color)
Set overlay color for view other than ShadowOverlayContainer.
See also setOverlayColor(int)
.
Parameters | |
---|---|
view |
View
|
color |
int
|
void setNoneWrapperShadowFocusLevel (View view, float level)
Set shadow focus level (0 to 1). 0 for unfocused, 1 for fully focused.
This is for view other than ShadowOverlayContainer.
See also setShadowFocusLevel(float)
.
Parameters | |
---|---|
view |
View
|
level |
float
|
void setOverlayColor (View view, int color)
Set overlay color for view, it can be a ShadowOverlayContainer if needsWrapper() is true, or other view type.
Parameters | |
---|---|
view |
View
|
color |
int
|
void setShadowFocusLevel (View view, float level)
Set shadow focus level (0 to 1). 0 for unfocused, 1 for fully focused.
Parameters | |
---|---|
view |
View
|
level |
float
|
boolean supportsDynamicShadow ()
Returns true if the platform sdk supports dynamic shadows.
Returns | |
---|---|
boolean |
boolean supportsForeground ()
Returns true if view.setForeground() is supported.
Returns | |
---|---|
boolean |
boolean supportsRoundedCorner ()
Returns true if the platform sdk supports rounded corner through outline.
Returns | |
---|---|
boolean |
boolean supportsShadow ()
Return true if the platform sdk supports shadow.
Returns | |
---|---|
boolean |