Gluon Scene Builder is a drag and drop UI designer tool allowing rapid desktop and mobile app development. Scene Builder separates design from logic, allowing team members to quickly and easily focus on their specific aspect of application development.
Scene Builder works with the JavaFX ecosystem – official controls, community projects, and Gluon offerings including Gluon Mobile, Gluon Desktop, and Gluon CloudLink.
Scene Builder is open source, and it is freely licensed under the BSD license. Gluon can provide custom consultancy and training, and open source commercial support.
The best way to get started with Gluon Scene Builder is by downloading and installing on your developer machine the latest Scene Builder release.
See the documentation about the new features recently included.
For community support, go to StackOverflow.
Issues can be reported to the Issue tracker
Contributions can be submitted via Pull requests
Gluon Scene Builder is frequently released, and this is only required in case you want to fork and build your local version of Scene Builder.
These are the requisites:
- A recent version of JDK 11 or later for building 'master' branch
- A recent version of JDK 8 for building '8u-dev' branch
To build the Scene Builder services, on the project's root, run:
./gradlew clean build
It will create a partial shadow cross-platform jar under app/build/libs/scenebuilder-$version.jar
, that doesn't include the JavaFX dependencies.
You can run it with Gradle:
./gradlew run
or you can run the partial shadow jar, providing you have downloaded the JavaFX SDK from here:
`java --module-path /path/to/javafx-sdk-$javafxVersion/lib --add-modules javafx.web,javafx.fxml,javafx.swing,javafx.media --add-opens=javafx.fxml/javafx.fxml=ALL-UNNAMED -cp app/build/libs/scenebuilder-$version.jar com.oracle.javafx.scenebuilder.app.SceneBuilderApp
To build and install the Scene Builder Kit in your local repository, run:
./gradlew clean :kit:install
The custom controls of the Scene Builder kit can be used in your project. You can add it as a regular dependency to the build of your app:
repositories {
mavenLocal()
}
dependencies {
implementation ('com.gluonhq.scenebuilder:scenebuilder-kit:$version') { transitive = false }
}