- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.2k
Simple Circle Button
        Weiping Huang edited this page Dec 10, 2016 
        ·
        25 revisions
      
    
Add simple circle buttons with just an image 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="simpleCircle"
    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 simple circle button has lots of methods to customize the boom-buttons.
for (int i = 0; i < bmb.getPiecePlaceEnum().pieceNumber(); i++) {
    SimpleCircleButton.Builder builder = new SimpleCircleButton.Builder()
            .listener(new OnBMClickListener() {
                @Override
                public void onBoomButtonClick(int index) {
                    // When the boom-button corresponding this builder is clicked.
                    Toast.makeText(SimpleCircleButtonActivity.this, "Clicked " + index, Toast.LENGTH_SHORT).show();
                }
            })
            // Whether the image-view should rotate.
            .rotateImage(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))
            // 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(false)
            // 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.getPiecePlaceEnum().pieceNumber(); i++) {
    SimpleCircleButton.Builder builder = new SimpleCircleButton.Builder()
            .normalImageRes(R.drawable.jellyfish);
    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)
 2. PiecePlaceEnum.DOT_2_M(in .java) or bmb_piecePlace_dot_2_M(in .xml)
   
2. PiecePlaceEnum.DOT_2_M(in .java) or bmb_piecePlace_dot_2_M(in .xml)  

 3. PiecePlaceEnum.DOT_3_M(in .java) or bmb_piecePlace_dot_3_M(in .xml)
  
3. PiecePlaceEnum.DOT_3_M(in .java) or bmb_piecePlace_dot_3_M(in .xml)  

 
  
  4. PiecePlaceEnum.DOT_4_M(in .java) or bmb_piecePlace_dot_4_M(in .xml)
  
4. PiecePlaceEnum.DOT_4_M(in .java) or bmb_piecePlace_dot_4_M(in .xml)  

 5. PiecePlaceEnum.DOT_5_M(in .java) or bmb_piecePlace_dot_5_M(in .xml)
  
5. PiecePlaceEnum.DOT_5_M(in .java) or bmb_piecePlace_dot_5_M(in .xml)  

 
  
  6. PiecePlaceEnum.DOT_6_M(in .java) or bmb_piecePlace_dot_6_M(in .xml)
  
6. PiecePlaceEnum.DOT_6_M(in .java) or bmb_piecePlace_dot_6_M(in .xml)  

 
  
  
   
   7. PiecePlaceEnum.DOT_7_M(in .java) or bmb_piecePlace_dot_7_M(in .xml)
  
7. PiecePlaceEnum.DOT_7_M(in .java) or bmb_piecePlace_dot_7_M(in .xml)  

 
  
  
   
   8. PiecePlaceEnum.DOT_8_M(in .java) or bmb_piecePlace_dot_8_M(in .xml)
  
8. PiecePlaceEnum.DOT_8_M(in .java) or bmb_piecePlace_dot_8_M(in .xml)  

 
  
  
   
   
  9. PiecePlaceEnum.DOT_9_M(in .java) or bmb_piecePlace_dot_9_M(in .xml)
  
9. PiecePlaceEnum.DOT_9_M(in .java) or bmb_piecePlace_dot_9_M(in .xml)  


 
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)
 2. ButtonPlaceEnum.SC_2_M(in .java) or bmb_buttonPlace_sc_2_M(in .xml)
   
2. ButtonPlaceEnum.SC_2_M(in .java) or bmb_buttonPlace_sc_2_M(in .xml)  

 3. ButtonPlaceEnum.SC_3_M(in .java) or bmb_buttonPlace_sc_3_M(in .xml)
  
3. ButtonPlaceEnum.SC_3_M(in .java) or bmb_buttonPlace_sc_3_M(in .xml)  

 
  
  4. ButtonPlaceEnum.SC_4_M(in .java) or bmb_buttonPlace_sc_4_M(in .xml)
  
4. ButtonPlaceEnum.SC_4_M(in .java) or bmb_buttonPlace_sc_4_M(in .xml)  

 5. ButtonPlaceEnum.SC_5_M(in .java) or bmb_buttonPlace_sc_5_M(in .xml)
  
5. ButtonPlaceEnum.SC_5_M(in .java) or bmb_buttonPlace_sc_5_M(in .xml)  

 
  
  6. ButtonPlaceEnum.SC_6_M(in .java) or bmb_buttonPlace_sc_6_M(in .xml)
  
6. ButtonPlaceEnum.SC_6_M(in .java) or bmb_buttonPlace_sc_6_M(in .xml)  

 
  
  
   
   7. ButtonPlaceEnum.SC_7_M(in .java) or bmb_buttonPlace_sc_7_M(in .xml)
  
7. ButtonPlaceEnum.SC_7_M(in .java) or bmb_buttonPlace_sc_7_M(in .xml)  

 
  
  
   
   8. ButtonPlaceEnum.SC_8_M(in .java) or bmb_buttonPlace_sc_8_M(in .xml)
  
8. ButtonPlaceEnum.SC_8_M(in .java) or bmb_buttonPlace_sc_8_M(in .xml)  

 
  
  
   
   
  9. ButtonPlaceEnum.SC_9_M(in .java) or bmb_buttonPlace_sc_9_M(in .xml)
  
9. ButtonPlaceEnum.SC_9_M(in .java) or bmb_buttonPlace_sc_9_M(in .xml)  


 
              - 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