Skip to content

Basic Usage (Objective C)

Weiping Huang edited this page May 9, 2017 · 2 revisions

How to use BMB in just several lines of code?

Swift | Objective-C

Create BMB

From version 2.0.0, BMB can be used directly in .storyboard or .xib. Add a view to view-controller and then change the Class to VHBoomMenuButton in identity inspector. Of course, BMB can be also added by frame-initialization method:

VHBoomMenuButton *bmb = [[VHBoomMenuButton alloc] initWithFrame:CGRectMake(0, 0, 60, 60)];

And, don't forget to import BMB:

#import <VHBoomMenuButton/VHBoomMenuButton.h>

After adding a BMB in your view-controller, now you should tell BMB what kind of boom-buttons(the sub-buttons when booming) that you expect to boom by setting VHButtonEnum property.

  1. VHButtonSimpleCircle corresponding to Simple Circle Button
  2. VHButtonTextInsideCircle corresponding to Text Inside Circle Button
  3. VHButtonTextOutsideCircle corresponding to Text Outside Circle Button
  4. VHButtonHam corresponding to Ham Button
bmb.buttonEnum = VHButtonSimpleCircle;

Then you need to tell BMB how it should place pieces on itself. Click the links for 4 kinds of buttons above to check different piece-place-enums.

bmb.piecePlaceEnum = VHPiecePlaceDOT_3_1;

Now tell BMB how to place the buttons on the screen when booming. Click the links for 4 kinds of buttons above to check different button-place-enums.

bmb.buttonPlaceEnum = VHButtonPlaceSC_3_3;

Add Builders

You have set enough properties for BMB itself, now add builders for customizing boom-buttons to BMB. There are 4 different builders for the 4 kinds of boom-buttons above. For instance, use SimpleCircleButtonBuilder for VHButtonSimpleCircle. Click the links for 4 kinds of buttons above to find out how to use builders.

for (int i = 0; i < bmb.pieceNumber; i++)
{
    VHSimpleCircleButtonBuilder *builder = [VHSimpleCircleButtonBuilder builder];
    builder.normalImageName = @"PictureName";
    [bmb addBuilder:builder];
}

And now your BMB is ready for a boom.

Attention

You must keep the number of piece-place-enum, number of button-place-enum and number of builders being the same.

The name of piece-place-enum is XXX_N_M, where XXX is name(DOT or HAM), N is number and M represents different types. Similarly, the name of button-place-enum is YYY_N_M. You must keep the first N equals to the second one. But you needn't keep the two M same(The code above is an example: VHPiecePlaceDOT_3_1 and VHButtonPlaceSC_3_3). Unless the piece-place-enum is VHPiecePlaceShare or VHPiecePlaceCustom. Check Share Style and Custom Position for more details.

And the number of builders must be N. Any breaking-rules-code will get an assert.

Home
Chapters

  1. Basic Usage
  2. Simple Circle Button
  3. Text Inside Circle Button
  4. Text Outside Circle Button
  5. Ham Button
  6. Share Style
  7. Custom Position
  8. Button Place Alignments
  9. Different Ways to Boom
  10. Ease Animations for Buttons
  11. Different Order for Buttons
  12. Other Animations Attributes for Buttons
  13. Click Event and Listener
  14. Control BMB
  15. Use BMB in Navigation Bar
  16. Use BMB in Table View
  17. Attributes for BMB or Pieces on BMB
  18. Cache Optimization & Boom Area
  19. Change Boom Buttons Dynamically
  20. Blur Background & Tip
  21. Fade Views
  22. Structure of BMB
  23. Version History
Clone this wiki locally