From 2bddd317b8d0653db9542e9ea02b6154a9c7f46f Mon Sep 17 00:00:00 2001 From: Colin Date: Sat, 31 Oct 2015 18:50:24 -0400 Subject: [PATCH] Add renderOverNavigationBar attribute, which renders the showcase over the nav bar. --- .../materialshowcaseview/MaterialShowcaseView.java | 13 ++++++++++++- .../materialshowcaseview/ShowcaseConfig.java | 9 +++++++++ 2 files changed, 21 insertions(+), 1 deletion(-) diff --git a/library/src/main/java/uk/co/deanwild/materialshowcaseview/MaterialShowcaseView.java b/library/src/main/java/uk/co/deanwild/materialshowcaseview/MaterialShowcaseView.java index b2d22bd3..d8d0feb8 100644 --- a/library/src/main/java/uk/co/deanwild/materialshowcaseview/MaterialShowcaseView.java +++ b/library/src/main/java/uk/co/deanwild/materialshowcaseview/MaterialShowcaseView.java @@ -61,6 +61,7 @@ public class MaterialShowcaseView extends FrameLayout implements View.OnTouchLis private int mContentTopMargin; private boolean mDismissOnTouch = false; private boolean mShouldRender = false; // flag to decide when we should actually render + private boolean mRenderOverNav = false; private int mMaskColour; private AnimationFactory mAnimationFactory; private boolean mShouldAnimate = true; @@ -256,7 +257,7 @@ public void setTarget(Target target) { /** * If we're on lollipop then make sure we don't draw over the nav bar */ - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { + if (!mRenderOverNav && Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { mBottomMargin = getSoftButtonsBarSizePort((Activity) getContext()); FrameLayout.LayoutParams contentLP = (LayoutParams) getLayoutParams(); @@ -420,6 +421,7 @@ public void setConfig(ShowcaseConfig config) { setMaskColour(config.getMaskColor()); setShape(config.getShape()); setShapePadding(config.getShapePadding()); + setRenderOverNavigationBar(config.getRenderOverNavigationBar()); } private void updateDismissButton() { @@ -577,6 +579,12 @@ public Builder withRectangleShape(boolean fullWidth) { return this; } + public Builder renderOverNavigationBar() { + // Note: This only has an effect in Lollipop or above. + showcaseView.setRenderOverNavigationBar(true); + return this; + } + public MaterialShowcaseView build() { if (showcaseView.mShape == null) { switch (shapeType) { @@ -760,4 +768,7 @@ public static int getSoftButtonsBarSizePort(Activity activity) { return 0; } + private void setRenderOverNavigationBar(boolean mRenderOverNav) { + this.mRenderOverNav = mRenderOverNav; + } } diff --git a/library/src/main/java/uk/co/deanwild/materialshowcaseview/ShowcaseConfig.java b/library/src/main/java/uk/co/deanwild/materialshowcaseview/ShowcaseConfig.java index 32d6ecbf..fb814612 100644 --- a/library/src/main/java/uk/co/deanwild/materialshowcaseview/ShowcaseConfig.java +++ b/library/src/main/java/uk/co/deanwild/materialshowcaseview/ShowcaseConfig.java @@ -21,6 +21,7 @@ public class ShowcaseConfig { private long mFadeDuration = DEFAULT_FADE_TIME; private Shape mShape = DEFAULT_SHAPE; private int mShapePadding = DEFAULT_SHAPE_PADDING; + private boolean renderOverNav = false; public ShowcaseConfig() { mMaskColour = Color.parseColor(ShowcaseConfig.DEFAULT_MASK_COLOUR); @@ -83,4 +84,12 @@ public void setShapePadding(int padding) { public int getShapePadding() { return mShapePadding; } + + public boolean getRenderOverNavigationBar() { + return renderOverNav; + } + + public void setRenderOverNavigationBar(boolean renderOverNav) { + this.renderOverNav = renderOverNav; + } }