Git Product home page Git Product logo

jfx-router's Introduction

jfx-router

Simple JavaFX router to switch between scenes for Java 11+

How to install to your project

Gradle

repositories {
    maven { url 'https://jitpack.io' }
}

dependencies {
    implementation 'com.github.chamexxxx:jfx-router:1.0'
}

Maven

<repositories>
    <repository>
        <id>jitpack.io</id>
        <url>https://jitpack.io</url>
    </repository>
</repositories>

<dependency>
    <groupId>com.github.chamexxxx</groupId>
    <artifactId>jfx-router</artifactId>
    <version>-SNAPSHOT</version>
</dependency>

Usage

Bind router

Router.bind(primaryStage);

Define routes

Router.addScene("home", getClass().getResource("home-view.fxml"));
Router.addScene("login", getClass().getResource("login-view.fxml"));
Router.addScene("register", getClass().getResource("register-view.fxml"));

Switch view

Router.switchScene("login");

Example

import com.chamexxxx.Router;
import javafx.application.Application;
import javafx.stage.Stage;

public class Main extends Application {
    @Override
    public void start(Stage primaryStage) {
        configureStage(primaryStage);

        Router.bind(primaryStage);

        Router.setInitialSceneConfigurator(scene -> {
            scene.getStylesheets().add(getClass().getResource("app.css").toExternalForm());
        });

        Router.addScene("home", getClass().getResource("home-view.fxml"));
        Router.addScene("login", getClass().getResource("login-view.fxml"));
        Router.addScene("register", getClass().getResource("register-view.fxml"));
        
        Router.switchScene("login");

        primaryStage.show();
    }

    public static void main(String[] args) {
        launch();
    }

    private void configureStage(Stage stage) {
        stage.setTitle("App title");
    }
}

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.