Skip to content

Commit

Permalink
feat: add attribute to control which bar corners should be cornered
Browse files Browse the repository at this point in the history
+ new attribute called `corners` which can be `top_left` , `top_right` , `bottom_left` , `bottom_right` , `all`, or `none`. It can be combination of corners using |. for example `top_left|bottom_left`.
  • Loading branch information
brookmg committed Oct 10, 2021
1 parent d675d81 commit e42a4f7
Show file tree
Hide file tree
Showing 4 changed files with 66 additions and 3 deletions.
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -318,6 +318,8 @@ Prior to the [initial addition of this feature](https://github.com/ibrahimsn98/S
app:backgroundColor=""
app:indicatorColor=""
app:indicatorRadius=""
app:cornerRadius=""
app:corners=""
app:sideMargins=""
app:itemPadding=""
app:textColor=""
Expand Down
4 changes: 3 additions & 1 deletion app/src/main/res/layout/activity_main.xml
Original file line number Diff line number Diff line change
Expand Up @@ -27,11 +27,13 @@
app:textSize="14sp"
app:iconSize="24dp"
app:indicatorColor="#2DFFFFFF"
app:indicatorRadius="10dp"
app:indicatorRadius="16dp"
app:sideMargins="10dp"
app:itemPadding="10dp"
app:iconTint="#C8FFFFFF"
app:iconTintActive="#FFFFFF"
app:cornerRadius="16dp"
app:corners="top_left|bottom_right"
app:menu="@menu/menu_bottom"
app:layout_constraintBottom_toBottomOf="parent"/>

Expand Down
55 changes: 53 additions & 2 deletions lib/src/main/java/me/ibrahimsn/lib/SmoothBottomBar.kt
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,8 @@ class SmoothBottomBar @JvmOverloads constructor(

@Dimension
private var _barCornerRadius = context.d2p(DEFAULT_BAR_CORNER_RADIUS)

private var _barCorners = DEFAULT_BAR_CORNERS

@Dimension
private var _itemPadding = context.d2p(DEFAULT_ITEM_PADDING)
Expand Down Expand Up @@ -128,6 +130,13 @@ class SmoothBottomBar @JvmOverloads constructor(
invalidate()
}

var barCorners: Int
get() = _barCorners
set(value) {
_barCorners = value
invalidate()
}

var itemTextSize: Float
@Dimension get() = _itemTextSize
set(@Dimension value) {
Expand Down Expand Up @@ -281,6 +290,10 @@ class SmoothBottomBar @JvmOverloads constructor(
R.styleable.SmoothBottomBar_cornerRadius,
barCornerRadius
)
barCorners = typedArray.getInteger(
R.styleable.SmoothBottomBar_corners,
barCorners
)
itemPadding = typedArray.getDimension(
R.styleable.SmoothBottomBar_itemPadding,
itemPadding
Expand Down Expand Up @@ -374,10 +387,39 @@ class SmoothBottomBar @JvmOverloads constructor(
0f, 0f,
width.toFloat(),
height.toFloat(),
barCornerRadius,
barCornerRadius,
minOf(barCornerRadius.toFloat(), height.toFloat() / 2),
minOf(barCornerRadius.toFloat(), height.toFloat() / 2),
paintBackground
)

if (barCorners != ALL_CORNERS) {

if ((barCorners and TOP_LEFT_CORNER) != TOP_LEFT_CORNER) {
// Draw a box to cover the curve on the top left
canvas.drawRect(0f, 0f, width.toFloat() / 2,
height.toFloat() / 2, paintBackground)
}

if ((barCorners and TOP_RIGHT_CORNER) != TOP_RIGHT_CORNER) {
// Draw a box to cover the curve on the top right
canvas.drawRect(width.toFloat() / 2, 0f, width.toFloat(),
height.toFloat() / 2, paintBackground)
}

if ((barCorners and BOTTOM_LEFT_CORNER) != BOTTOM_LEFT_CORNER) {
// Draw a box to cover the curve on the bottom left
canvas.drawRect(0f, height.toFloat() / 2, width.toFloat() / 2,
height.toFloat(), paintBackground)
}

if ((barCorners and BOTTOM_RIGHT_CORNER) != BOTTOM_RIGHT_CORNER) {
// Draw a box to cover the curve on the bottom right
canvas.drawRect(width.toFloat() / 2, height.toFloat() / 2, width.toFloat(),
height.toFloat(), paintBackground)
}

}

} else {
canvas.drawRect(
0f, 0f,
Expand Down Expand Up @@ -597,6 +639,14 @@ class SmoothBottomBar @JvmOverloads constructor(
private const val DEFAULT_INDICATOR_COLOR = "#2DFFFFFF"
private const val DEFAULT_TINT = "#C8FFFFFF"

// corner flags
private const val NO_CORNERS = 0;
private const val TOP_LEFT_CORNER = 1;
private const val TOP_RIGHT_CORNER = 2;
private const val BOTTOM_RIGHT_CORNER = 4;
private const val BOTTOM_LEFT_CORNER = 8;
private const val ALL_CORNERS = 15;

private const val DEFAULT_SIDE_MARGIN = 10f
private const val DEFAULT_ITEM_PADDING = 10f
private const val DEFAULT_ANIM_DURATION = 200L
Expand All @@ -605,6 +655,7 @@ class SmoothBottomBar @JvmOverloads constructor(
private const val DEFAULT_TEXT_SIZE = 11F
private const val DEFAULT_CORNER_RADIUS = 20F
private const val DEFAULT_BAR_CORNER_RADIUS = 0F
private const val DEFAULT_BAR_CORNERS = TOP_LEFT_CORNER or TOP_RIGHT_CORNER

private const val OPAQUE = 255
private const val TRANSPARENT = 0
Expand Down
8 changes: 8 additions & 0 deletions lib/src/main/res/values/attrs.xml
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,14 @@
<attr name="cornerRadius" format="dimension" />
<attr name="activeItem" format="integer" />
<attr name="duration" format="integer" />
<attr name="corners">
<flag name="none" value="0" />
<flag name="top_left" value="1" />
<flag name="top_right" value="2" />
<flag name="bottom_right" value="4" />
<flag name="bottom_left" value="8" />
<flag name="all" value="15" />
</attr>
</declare-styleable>

<attr name="SmoothBottomBarStyle" format="reference" />
Expand Down

0 comments on commit e42a4f7

Please sign in to comment.