Buttons can be troublesome, so when I was developing my games, I asked myself "what is necessary ?". Then, I have created game-specific buttons which has rich features. (ButtonGame, ButtonToggle, ButtonLevel)
General features of all buttons:
General features of all buttons:
- Set down and up textures
- Set lock condition and texture
- Set text with any font
- Set external texture for different purposes
- Each button type also has special features
TEST SCREEN
I again used previous tutorials screen, I removed one of the bats, and centered the other bat, I created new method setUpButtons() to show the buttons and their abilities. I have also created a table to add all the buttons in it.
This is very simple buttons and table creator for faster and less code writing.
BUTTONGAME
First two buttons are the general game buttons. These can be used, skiils, shoot, grap or any other game specific purposes. First button was set to lock so it cannot detect hits the other button is active and has a text on it with a font I have chosen, text was set to desired position. Each time of click this buttons, sets a momentary animation (Coming on next tutorial) to bat, so each time you click the bat cycles. I also made a counter to decrease to number, when it is 0 it locks the button and makes it unusable.
// #3.1 TEST // Button locked // #################################################### ButtonGame btnTest1 = MenuCreator.createCustomGameButton(Assets.btnBatCircle, Assets.btnBatCirclePressed); btnTest1.setTextureLocked(Assets.btnBatLocked, true); tableButtons.add(btnTest1).pad(5); // #3.2 TEST // General Game Button (Button + Text) // #################################################### final ButtonGame btnTest2 = MenuCreator.createCustomGameButton(Assets.btnBatCircle, Assets.btnBatCirclePressed); btnTest2.setText(Assets.font2, "" + batCircleCounter, true); btnTest2.setTextPosXY(50, 35); btnTest2.addListener(new ActorGestureListener() { @Override public void touchUp(InputEvent event, float x, float y, int pointer, int button) { super.touchUp(event, x, y, pointer, button); // Set the momentary animation of abstractactor // It is like a blink eye animation then goes back to regular animation bat2.setAnimationMomentary(Assets.animBatCircleRight, true, null, true, false); // Decrease counter if(batCircleCounter > 1){ btnTest2.setTextChange("" + --batCircleCounter); } else{ btnTest2.setTextureLocked(Assets.btnBatLocked, true); } }}); tableButtons.add(btnTest2).pad(5);
BUTTONTOGGLE
Third button is a type of button toggle (This is not fully finished, but it works). As the name sounds, its duty is toggling. So if you press this button it bat will constantly cycle, if you press again bat will fly normal.
// #3.3 TEST // Toggle Button // #################################################### final ButtonToggle btnTest3 = MenuCreator.createCustomToggleButton(Assets.btnBatCirclePressed, Assets.btnBatCircle, false); btnTest3.addListener(new ActorGestureListener() { @Override public void touchUp(InputEvent event, float x, float y, int pointer, int button) { super.touchUp(event, x, y, pointer, button); // Toggle the button, and change animation of abstract actor btnTest3.setToggleSwitch(); if(btnTest3.isToggleActive()){ bat2.setAnimation(Assets.animBatCircleRight, true, true); } else{ bat2.setAnimation(Assets.animBatFlyRight, true, true); } }}); tableButtons.add(btnTest3).pad(5);
BUTTONLEVEL
The forth button is the type of level button. This is probably the most game specific button I have created :). Pretty easy to use and implement. You can set level number or text, also you can set achivement objects (I named as star) on it. For example, you can set 2 starts, it means on that level 2 stars achieved.
For achiements, you should set holders and stars textures (or other things). For example, In levels 5 stars is the maximum achievement, then user achieved 3 stars. Button will show 5 star holders but it will set 3 stars. Still with me ? :))). Its best to see in action in the code.
- I created the button
- I set the level star holder ( dull star holders - Assets.imgStarHolder) and star ( yellow shiny -Assets.imgStar) textures, the maximum number of stars can be achived (3), the number of stars that earned (1). The number of stars earned normally comes from database of the game in actual games.
- Then the MTX auto centers all the stars, but you can set the ratio (size of it)
- You can also move the stars upper or lower with setLevelStarPosYStart()
- Then I set the level number with a font.
FOR TEST PURPOSES, I made button to increase the stars numbers on each click and it also resets the bat cycle button and activates again just for fun.
// #3.4 TEST // Level Button // #################################################### final ButtonLevel btnTest4 = MenuCreator.createCustomLevelButton(Assets.btnLevel, Assets.btnLevelPressed); btnTest4.setLevelStars(Assets.imgStarHolder, Assets.imgStar, 3, 1); btnTest4.setLevelStarSizeRatio(3); btnTest4.setLevelStarPosYStart(2); btnTest4.setLevelNumber(1, Assets.font2); btnTest4.addListener(new ActorGestureListener() { @Override public void touchUp(InputEvent event, float x, float y, int pointer, int button) { super.touchUp(event, x, y, pointer, button); // Reset circle counter, update button 2 batCircleCounter = 9; btnTest2.setTextChange("" + batCircleCounter); btnTest2.setLockActive(false); // if full reset (JUST FOR TEST) if(btnTest4.getNumberOfEarnedStars() == btnTest4.getNumberOfTotalStars()){ btnTest4.setNumberOfEarnedStars(0); } // Increase the earned stars btnTest4.setNumberOfEarnedStars(btnTest4.getNumberOfEarnedStars() + 1); }}); tableButtons.add(btnTest4).pad(5);
BUTTON WITH A EXTERNAL TEXTURE
The last and the long button is a button game. Why would you need a external texture, you wouldn't, but sometimes it may be handy to use. For example, like in my example.
I created the button, I gave text "Top apps", but it was do dull and boring, so I put a external texture on it with burning app icons, and it became sexy.
// #3.5 TEST // General Game Button (Button + Text + ExternalImage) // #################################################### final ButtonGame btnTest5 = MenuCreator.createCustomGameButton(Assets.btnAllMenu, Assets.btnAllMenuPressed); btnTest5.setText(Assets.font2, "Top Apps", true); btnTest5.setTextPosXY(20, 50); btnTest5.setTextureExternal(Assets.imgTopApps, true); btnTest5.setTextureExternalSize(120, 120); btnTest5.setTextureExternalPosXY(144, -16); btnTest5.addListener(new ActorGestureListener() { @Override public void touchUp(InputEvent event, float x, float y, int pointer, int button) { super.touchUp(event, x, y, pointer, button); // Set the momentary animation of abstractactor // It is like a blink eye animation then goes back to regular animation }}); tableButtons.add(btnTest5).pad(5);
This comment has been removed by the author.
ReplyDeleteHey! I'm trying to do a little game and I used your tutorial for my menu. It works really good but I have two problems.
ReplyDeleteFirst: I can't load a picture like you (800x480). It say to me that I have to have a power of two!!
Secondly: With my button I don't have the text. I have to put a label inside the button.
So maybe you have an answer!! ^^.
Thanks in advance.
hi Sylvain you can stop the power of two error by add that code inside your Create method
DeleteTexture.setEnforcePotImages(false);
Thanks a lot it works now!!!
DeleteThis comment has been removed by the author.
ReplyDeletehow can i got this buttons ?
ReplyDelete