-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Text Inside Circle Button
Weiping Huang edited this page Dec 10, 2016
·
12 revisions
Add text inside circle buttons with a text and image inside for each to BMB.
###Create BMB
Add BMB in .xml file.
<com.nightonke.boommenu.BoomMenuButton
android:id="@+id/bmb"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:bmb_buttonEnum="textInsideCircle"
app:bmb_piecePlaceEnum="piecePlace_dot_9_1"
app:bmb_buttonPlaceEnum="buttonPlace_sc_9_1"
/>
You can set button-enum, piece-place-enum and button-place-enum in .xml file with attributes or in .java file with setters. For more information and pictures about piece-place-enum and button-place-enum, check the tables below.
###Add Builders The builder of text inside circle button has lots of methods to customize the boom-buttons.
for (int i = 0; i < bmb.getButtonPlaceEnum().buttonNumber(); i++) {
TextInsideCircleButton.Builder builder = new TextInsideCircleButton.Builder()
.listener(new OnBMClickListener() {
@Override
public void onBoomButtonClick(int index) {
// When the boom-button corresponding this builder is clicked.
Toast.makeText(TextInsideCircleButtonActivity.this, "Clicked " + index, Toast.LENGTH_SHORT).show();
}
})
// Whether the image-view should rotate.
.rotateImage(false)
// Whether the text-view should rotate.
.rotateText(false)
// Whether the boom-button should have a shadow effect.
.shadowEffect(true)
// Set the horizontal shadow-offset of the boom-button.
.shadowOffsetX(20)
// Set the vertical shadow-offset of the boom-button.
.shadowOffsetY(0)
// Set the radius of shadow of the boom-button.
.shadowRadius(Util.dp2px(20))
// Set the color of the shadow of boom-button.
.shadowColor(Color.parseColor("#ee000000"))
// Set the image resource when boom-button is at normal-state.
.normalImageRes(R.drawable.jellyfish)
// Set the image drawable when boom-button is at normal-state.
.normalImageDrawable(getResources().getDrawable(R.drawable.jellyfish, null))
// Set the image resource when boom-button is at highlighted-state.
.highlightedImageRes(R.drawable.bat)
// Set the image drawable when boom-button is at highlighted-state.
.highlightedImageDrawable(getResources().getDrawable(R.drawable.bat, null))
// Set the image resource when boom-button is at unable-state.
.unableImageRes(R.drawable.butterfly)
// Set the image drawable when boom-button is at unable-state.
.unableImageDrawable(getResources().getDrawable(R.drawable.butterfly, null))
// Set the rect of image.
// By this method, you can set the position and size of the image-view in boom-button.
// For example, builder.imageRect(new Rect(0, 50, 100, 100)) will make the
// image-view's size to be 100 * 50 and margin-top to be 50 pixel.
.imageRect(new Rect(Util.dp2px(10), Util.dp2px(10), Util.dp2px(70), Util.dp2px(70)))
// Set the padding of image.
// By this method, you can control the padding in the image-view.
// For instance, builder.imagePadding(new Rect(10, 10, 10, 10)) will make the
// image-view content 10-pixel padding to itself.
.imagePadding(new Rect(0, 0, 0, 0))
// Set the text resource when boom-button is at normal-state.
.normalTextRes(R.string.text_inside_circle_button_text_normal)
// Set the text resource when boom-button is at highlighted-state.
.highlightedTextRes(R.string.text_inside_circle_button_text_highlighted)
// Set the text resource when boom-button is at unable-state.
.unableTextRes(R.string.text_inside_circle_button_text_unable)
// Set the text when boom-button is at normal-state.
.normalText("Put your normal text here")
// Set the text when boom-button is at highlighted-state.
.highlightedText("Put your highlighted text here")
// Set the text when boom-button is at unable-state.
.unableText("Unable!")
// Set the color of text when boom-button is at normal-state.
.normalTextColor(Color.BLACK)
// Set the color of text when boom-button is at highlighted-state.
.highlightedTextColor(Color.BLUE)
// Set the color of text when boom-button is at unable-state.
.unableTextColor(Color.RED)
// Set the rect of text.
// By this method, you can set the position and size of the text-view in boom-button.
// For example, builder.textRect(new Rect(0, 50, 100, 100)) will make the
// text-view's size to be 100 * 50 and margin-top to be 50 pixel.
.textRect(new Rect(Util.dp2px(15), Util.dp2px(52), Util.dp2px(65), Util.dp2px(72)))
// Set the padding of text.
// By this method, you can control the padding in the text-view.
// For instance, builder.textPadding(new Rect(10, 10, 10, 10)) will make the
// text-view content 10-pixel padding to itself.
.textPadding(new Rect(0, 0, 0, 0))
// Set the typeface of the text.
.typeface(Typeface.DEFAULT_BOLD)
// Set the maximum of the lines of text-view.
.maxLines(2)
// Set the gravity of text-view.
.textGravity(Gravity.CENTER)
// Set the ellipsize of the text-view.
.ellipsize(TextUtils.TruncateAt.MIDDLE)
// Set the text size of the text-view.
.textSize(10)
// Whether the boom-button should have a ripple effect.
.rippleEffect(true)
// The color of boom-button when it is at normal-state.
.normalColor(Color.RED)
// The color of boom-button when it is at highlighted-state.
.highlightedColor(Color.BLUE)
// The color of boom-button when it is at unable-state.
.unableColor(Color.BLACK)
// Whether the boom-button is unable, default value is false.
.unable(true)
// The radius of boom-button, in pixel.
.buttonRadius(Util.dp2px(40));
bmb.addBuilder(builder);
}
Don't need to set every attributes for boom-buttons, just customize what you want. For example:
for (int i = 0; i < bmb.getButtonPlaceEnum().buttonNumber(); i++) {
TextInsideCircleButton.Builder builder = new TextInsideCircleButton.Builder()
.normalImageRes(R.drawable.butterfly)
.normalText("Butter Doesn't fly!");
bmb.addBuilder(builder);
}
After adding builders to BMB, it is ready for a boom.
All piece-place-enum and button-place-enum can be found in demo.
- PiecePlaceEnum.DOT_1(in .java) or bmb_piecePlace_dot_1(in .xml)
data:image/s3,"s3://crabby-images/1d6cb/1d6cb5931f333f238676e59fd62cca9fa0e0091f" alt=""
data:image/s3,"s3://crabby-images/fcc03/fcc0315bb8199fdf38b533e2db15439a28bb7ba6" alt=""
data:image/s3,"s3://crabby-images/17e56/17e56b6b680675762eea2e532bff80df31c9d8b2" alt=""
data:image/s3,"s3://crabby-images/6a708/6a708f0a787c47670fb6f189b3e793513751b6b9" alt=""
data:image/s3,"s3://crabby-images/ca629/ca6298caf88dd6594dacecf1fc3cda7b3934cc2b" alt=""
data:image/s3,"s3://crabby-images/df779/df779532b4f52d49dc71219b9c7d61d31a480b2e" alt=""
data:image/s3,"s3://crabby-images/9cac1/9cac1e656ac4c4c079295f352c74587706f99e5c" alt=""
data:image/s3,"s3://crabby-images/14de2/14de217c1d381de2a8d1fe39ca0940688b42d48e" alt=""
data:image/s3,"s3://crabby-images/82c56/82c56dfb689e20137e006c31adde3448e8b6b909" alt=""
data:image/s3,"s3://crabby-images/18fb6/18fb678a6f2cf77657fb00e5b1679354d102ef82" alt=""
data:image/s3,"s3://crabby-images/71aaf/71aaf548506e7cafffe030a61711fa37bebd2c11" alt=""
data:image/s3,"s3://crabby-images/0903a/0903a96ef3fbb5414643eaf07ccb5463592ed894" alt=""
data:image/s3,"s3://crabby-images/26edb/26edb1e9aa7c14310935e4394f5087b221a26991" alt=""
data:image/s3,"s3://crabby-images/65ee1/65ee15b65613b83b97fe63995815fd0fa81a597a" alt=""
data:image/s3,"s3://crabby-images/1d583/1d583bc8cf40fef22c8db9750fc1b3b3e1bc0a61" alt=""
data:image/s3,"s3://crabby-images/56ecd/56ecd7faa9d71492b39beadce1e1ce650be589a0" alt=""
data:image/s3,"s3://crabby-images/23fed/23fedf15dad1f599286dc24010ba882436e6cfba" alt=""
data:image/s3,"s3://crabby-images/bfb9c/bfb9cdb06ee7c7277ea082487c781c37af87e476" alt=""
data:image/s3,"s3://crabby-images/35a80/35a80b5468a1c66a1472053ef0b3d41154ec31f7" alt=""
data:image/s3,"s3://crabby-images/cd4ae/cd4ae2ab3f96d0dfba64d285c5e6f2e0fdebe478" alt=""
data:image/s3,"s3://crabby-images/06f6f/06f6f63862093a86630bcab1ff61d6434ed704e4" alt=""
data:image/s3,"s3://crabby-images/143fc/143fc2fb05032e2279ad84e7ebf79535bda4c923" alt=""
data:image/s3,"s3://crabby-images/2298a/2298aa59f18e43d70a06a3a898ca091517b75971" alt=""
data:image/s3,"s3://crabby-images/0e955/0e955b237a59aa3a92818d9197739466946c285e" alt=""
data:image/s3,"s3://crabby-images/0eea1/0eea1a89f6eef83a5896c1ae1d0d0e0a61745e7f" alt=""
data:image/s3,"s3://crabby-images/49c10/49c105e3a273310e86647b3cf14dced8439c859a" alt=""
data:image/s3,"s3://crabby-images/a4850/a485019517fbb1f8014fe151ff7472333730d950" alt=""
data:image/s3,"s3://crabby-images/1e66e/1e66e7e9d07de800b5cdd33b64914b4bc5bee5fd" alt=""
data:image/s3,"s3://crabby-images/5bd00/5bd008570b24b1d158b383ccaa33b30e1751848a" alt=""
data:image/s3,"s3://crabby-images/84bb2/84bb23405022fb71441f348528b3f874dc0bd983" alt=""
data:image/s3,"s3://crabby-images/18337/18337387e892a85becfd05037d923028992995ff" alt=""
data:image/s3,"s3://crabby-images/6b6b6/6b6b6ac8696c87bfcdd0c22784b46d1533953490" alt=""
data:image/s3,"s3://crabby-images/d705d/d705dfc004074a419c8899165de03f83456c6346" alt=""
data:image/s3,"s3://crabby-images/a3391/a339164af4434586849a0be87a8c2dbf57436e35" alt=""
data:image/s3,"s3://crabby-images/a63e2/a63e2f6d799a118f74487844bf74a28e9ef87495" alt=""
All piece-place-enum and button-place-enum can be found in demo.
- ButtonPlaceEnum.SC_1(in .java) or bmb_buttonPlace_sc_1(in .xml)
data:image/s3,"s3://crabby-images/917c6/917c6c5dc75fb7d229abce06ab8b23c5b920518a" alt=""
data:image/s3,"s3://crabby-images/9756f/9756f780859df2375deff1ac1c9edc3fd6daab88" alt=""
data:image/s3,"s3://crabby-images/01a6f/01a6fae744f4493eca717eba280ad607359e3c8f" alt=""
data:image/s3,"s3://crabby-images/cff6b/cff6bd6f208d20cef0be00ca915ef1648c85e0a9" alt=""
data:image/s3,"s3://crabby-images/2b2e5/2b2e53f6b23804ca47207300737fe1ee16568956" alt=""
data:image/s3,"s3://crabby-images/97642/97642d5b1c6b2a217bfa388ad10fa786ad2d3869" alt=""
data:image/s3,"s3://crabby-images/2355e/2355e93e8e7c3412780be501fb49104945e66704" alt=""
data:image/s3,"s3://crabby-images/979a4/979a4d3d6b3034b3628e693609d156183743cc81" alt=""
data:image/s3,"s3://crabby-images/64801/6480130730f67d74b3b7af8987b1876497dadd23" alt=""
data:image/s3,"s3://crabby-images/af2be/af2be9d70774c04f19334f4fe0bd74a14880cb2b" alt=""
data:image/s3,"s3://crabby-images/cef4c/cef4cbea9c144269c6403ef4ec462e14a4bb5bb1" alt=""
data:image/s3,"s3://crabby-images/758e3/758e3461c68fd08307efe5673c1586ec140b15ee" alt=""
data:image/s3,"s3://crabby-images/12b1f/12b1fc6335f1c76082dab3183c3bbffeb8c609b9" alt=""
data:image/s3,"s3://crabby-images/45291/452914cad26a973c9de653444addc80f9a336f1a" alt=""
data:image/s3,"s3://crabby-images/e7b86/e7b869eca729e87c407e2962be04c6ee6a08a8cf" alt=""
data:image/s3,"s3://crabby-images/e7902/e7902c6a695712afcefec9b046f6453f8c959b3e" alt=""
data:image/s3,"s3://crabby-images/7db31/7db316c4efe2041577b50bd13b986f7e7b838a76" alt=""
data:image/s3,"s3://crabby-images/0b8be/0b8be95137878b30e2089ed68cd276a238bbc126" alt=""
data:image/s3,"s3://crabby-images/41aac/41aacbbc5c3d598f52de33974b33f1ecd5c4ebe3" alt=""
data:image/s3,"s3://crabby-images/974c4/974c410fbb6520bd9c5a99bfa867105da5ae094c" alt=""
data:image/s3,"s3://crabby-images/3394a/3394ae18cd93f746415530aaf76f4f251e6ab682" alt=""
data:image/s3,"s3://crabby-images/6714a/6714a15e4ed2f560b3ff9e8c4e306cbfa9c6d5b0" alt=""
data:image/s3,"s3://crabby-images/ee5e7/ee5e73cc0e58332b703dd76c632ef9c7676a5cf5" alt=""
data:image/s3,"s3://crabby-images/5cd2e/5cd2e879c8bac488b4341384888f6524908dcfb9" alt=""
data:image/s3,"s3://crabby-images/3f9d7/3f9d7cd39e5689b4f14e37cae6339c0e83c58738" alt=""
data:image/s3,"s3://crabby-images/3f165/3f165cda90458960d795d34ff1a188041a8f041b" alt=""
data:image/s3,"s3://crabby-images/4f2f9/4f2f902d5c066465c539ab4738f004047d728b11" alt=""
data:image/s3,"s3://crabby-images/010f3/010f38d42042dce1631f62bb22a8da54fdf7f348" alt=""
data:image/s3,"s3://crabby-images/f952b/f952b1b5e377577f1bdda8f1d0e1ad4e54610887" alt=""
data:image/s3,"s3://crabby-images/07e25/07e25bb2ce75239108b5728f0bf4ac7a3d641e38" alt=""
data:image/s3,"s3://crabby-images/17bb5/17bb5837433a0b8bf8633149cc4d43f74704b6b9" alt=""
data:image/s3,"s3://crabby-images/3d666/3d66634a31d695b050db170f024bdae18766b08f" alt=""
data:image/s3,"s3://crabby-images/c1790/c1790da2631a798c4bc90479ae9cc67af05f286b" alt=""
data:image/s3,"s3://crabby-images/ec548/ec54877cf9c3280f9901d4bd3138b0b3dd00feab" alt=""
data:image/s3,"s3://crabby-images/fa8b0/fa8b077142962f099c3d2e584040cc3ed17e8fb0" alt=""
- Basic Usage
- Simple Circle Button
- Text Inside Circle Button
- Text Outside Circle Button
- Ham Button
- Share Style
- Custom Position
- Button Place Alignments
- Different Ways to Boom
- Ease Animations for Buttons
- Different Order for Buttons
- Other Animations Attributes for Buttons
- Click Event and Listener
- Control BMB
- Use BMB in Action Bar
- Use BMB in Tool Bar
- Use BMB in List
- Use BMB in Fragment
- Attributes for BMB or Pieces on BMB
- Cache Optimization & Boom Area
- Change Boom Buttons Dynamically
- Fade Views
- Version History
- Structure for BMB