UiBooster is a lean library to create fast and easy dialogs for utility tools.
This project ports UiBooster 1.21.0 full functionally to the Processing eco-system as a library to create dialogs for your sketch fast as possible. With a lot of examples you will learn to use this library in less than five minutes.
If you like this project, and you want to keep me awake ðĪŠ, than please support me on ko-fi
In version 1.21.0 of UiBooster some getValue()
and setValue()
methods of the FormElements are changed its return.
Please check your code after updating if you used UiBooster in earlier versions before.
ImageFormElement.getValue()
returns the path to the image and not the ImagePanel anymoreListFormElement.setValue()
sets the selected elements and not the list of options. If you want to change the options you have to use setElements()
methodTableFormElement.setValue()
and getValue()
uses a new TableData-wrapper-class instead of String[][]
In version 1.12.0 of UiBooster the ChangeListener
and the FilledForm
are changed. Please check your code after updating if you
used UiBooster in earlier versions before.
Form form
as third parameter to your listenerFilledForm
is renamed to Form
A big thanks goes to the supporters of this project. I thank every single one of them for contributing to UiBooster.
If you want to use this library in your processing sketch you can download it via the integrated Contribution Manager
.
The following examples show the usage of this library. If you interested in the javadoc documentation look here.
new UiBooster().showInfoDialog("UiBooster is a lean library to ....");
new UiBooster().showWarningDialog("Your computer has a low battery ....", "WARN");
new UiBooster().showErrorDialog("The connection to SQL database is failed.", "ERROR");
String opinion = new UiBooster().showTextInputDialog("What do you think?");
new UiBooster().showConfirmDialog(
"Do you really want this action?",
"Are you sure?",
() -> System.out.println("Action accepted"),
() -> System.out.println("Action declined"));
String password = booster.showPasswordDialog("Whats your password?", "Password");
String selection = new UiBooster().showSelectionDialog(
"What's your favorite movie?",
"Favorite Movie?",
Arrays.asList("Pulp Fiction", "Bambi", "The Godfather", "Hangover"));
List<String> selectedElement = new UiBooster().showMultipleSelection(
"What are your favorite hobbies?",
"Your hobbies",
"Reading", "Traveling", "Fishing", "Music", "Gardening", "Sport", "Television",
"Video Games", "Crafting", "Bird Watching", "Collecting");
Integer numberOfHotDogs = new UiBooster().showSlider("How many HotDogs do you want?", "Your order",
0, 10, 2, 5, 1);
Color selectedColor = new UiBooster().showColorPicker("Choose your favorite color", "Color picking");
library by @dheid: colorpicker
Font selectedFont = new UiBooster().showFontChooser("Choose your favorite font", "Font choosing");
library by @dheid: fontchooser
Date birthday = new UiBooster().showDatePicker("What's your birthday?", "Birthday");
UiBooster booster = new UiBooster();
File file = booster.showFileSelection();
File directory = booster.showDirectorySelection();
File fileOrDirectory = booster.showFileOrDirectorySelection();
new UiBooster().showException(
"An error occurred",
"Exception message",
new Exception("Something went wrong ...")
);
ListElement selectedElement = new UiBooster().showList(
"Select a robot",
"Avatars from RoboHash.org",
element -> System.out.println("Selected: " + element.toString()),
new ListElement("Robo 1", "Green and strong", "src/test/resources/avatar1.png"),
new ListElement("Robo 2", "Shy without an avatar!"),
new ListElement("Robo 3", "- Crazy\n- Fast\n- Funny", "src/test/resources/avatar2.png"),
new ListElement("Robo 4", null, "src/test/resources/avatar3.png")
);
LoginCredentials credentials = new UiBooster().showLogin(
"Login",
"Internal area",
"Username",
"Password",
"Go",
"Cancel");
WaitingDialog dialog = new UiBooster().showWaitingDialog("Starting", "Please wait");
dialog.setMessage("Ready");
dialog.close();
WaitingDialog dialog = new UiBooster().showWaitingDialog("Starting", "Please wait");
dialog.setMessage("Initializing");
dialog.setLargeMessage("Some more information...\nMaybe from log files or other resources. \nBe transparent to the user to understand long processes...");
dialog.close();
ProgressDialog dialog = new UiBooster().showProgressDialog("Please wait", "Waiting", 0, 120);
dialog.setProgress(10);
// ...
dialog.setProgress(120);
dialog.setMessage("Ready");
dialog.close();
String[][] modifiedData = new UiBooster().showTable( // showTableImmutable for immutable tables
new String[][]{
{"Jimmy Johnson", "35", "Zombieland"},
{"Danny Durango", "23", "Hangover"},
{"Larry Berry", "54", ""}
},
Arrays.asList("Name", "Age", "Favorite movie"),
"Favorite movies");
new UiBooster().showPictures(
"My picture",
Arrays.asList(
new File("/home/nick/pictures/img-01.jpg"),
new File("/home/nick/pictures/img-02.jpg")
)
);
UiBooster booster = new UiBooster();
Form form = booster.createForm("Personal information")
.addText("Whats your first name?")
.addTextArea("Tell me something about you")
.addSelection(
"Whats your favorite movie?",
Arrays.asList("Pulp Fiction", "Bambi", "The Godfather", "Hangover"))
.addLabel("Choose an action")
.addButton("half full", () -> booster.showInfoDialog("Optimist"))
.addButton("half empty", () -> booster.showInfoDialog("Pessimist"))
.addSlider("How many liters did you drink today?", 0, 5, 1, 5, 1)
.show();
// use .run() instead of show() to open the formBuilder without blocking.
The form is very powerful and provides a lot of features:
Splashscreen splash = new UiBooster().showSplashscreen("/path/to/your/splash.png");
// do your stuff
splash.hide();
UiBooster booster = new UiBooster();
booster.createTrayMenu("Food", "screenshots/color.jpg")
.withPopupMenu()
.addMenu("Hotdogs", () -> booster.showInfoDialog("Sausage in a roll"))
.addMenu("Fries", () -> booster.showInfoDialog("Fried potatoes"))
.addMenu("Pizza", () -> booster.showInfoDialog("Dough with tomato sauce"));
new UiBooster().
createNotification("It's hot and delicious","Dinner is ready");
UiBooster booster = new UiBooster(
UiBoosterOptions.Theme.DARK_THEME,
"/path/to/your/custom-window-icon.png"
);
See some examples for UiBoosterOptions here
Please report issues for bugs or feature requests with ideas for other useful dialogs. If you interested in the development process, take a look to the origin project UiBooster.
The port of UiBooster works as copy from the original project with some package adjustments. An update script pulls the current UiBooster code and replace it with the code from this library. New features from UiBooster are added as examples, and the README.md has been updated.
This script updates the code. Attention: It removes the existing code!
cd ./update/
bash update-uibooster.sh