All Downloads are FREE. Search and download functionalities are using the official Maven repository.

it.tidalwave.role.ui.javafx.example.large.Main Maven / Gradle / Ivy

/*
 * #%L
 * *********************************************************************************************************************
 *
 * SteelBlue
 * http://steelblue.tidalwave.it - git clone [email protected]:tidalwave/steelblue-src.git
 * %%
 * Copyright (C) 2015 - 2015 Tidalwave s.a.s. (http://tidalwave.it)
 * %%
 *
 * *********************************************************************************************************************
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
 * the License. You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
 * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations under the License.
 *
 * *********************************************************************************************************************
 *
 *
 *
 * *********************************************************************************************************************
 * #L%
 */
package it.tidalwave.role.ui.javafx.example.large;

import javax.annotation.Nonnull;
import it.tidalwave.util.PreferencesHandler;
import javafx.application.Platform;
import org.springframework.context.ApplicationContext;
import it.tidalwave.ui.javafx.JavaFXSpringApplication;
import it.tidalwave.role.ui.javafx.example.large.mainscreen.MainScreenPresentationControl;
import static it.tidalwave.util.PreferencesHandler.KEY_INITIAL_SIZE;

/***********************************************************************************************************************
 *
 * The main class extends {@link JavaFXSpringApplication} and invokes a starting method on a controller that boots
 * the application.
 *
 * @author  Fabrizio Giudici
 *
 **********************************************************************************************************************/
public class Main extends JavaFXSpringApplication
  {
    /*******************************************************************************************************************
     *
     * Usually {@code main()} does nothing more than a typical {@code main()} of a typical JavaFX application.
     * JavaFX and Spring are automatically booted with an implicit configuration:
     *
     * 
    *
  • The FXML resource for the main UI is loaded from the same package as this class, and the name's * {@code Application.fxml}
  • *
  • A splash screen is created from a FXML resource in the same package as this class and name * {@code Splash.fxml}, It is rendered on the screen while the system is initialised in background.
  • *
* ******************************************************************************************************************/ public static void main (final @Nonnull String ... args) { try { System.setProperty(PreferencesHandler.PROP_APP_NAME, "LargeExample"); Platform.setImplicitExit(true); final PreferencesHandler preferencesHandler = PreferencesHandler.getInstance(); preferencesHandler.setDefaultProperty(KEY_INITIAL_SIZE, 0.8); launch(args); } catch (Throwable t) { // Don't use logging facilities here, they could be not initialized t.printStackTrace(); System.exit(-1); } } /******************************************************************************************************************* * * {@inheritDoc} * * This method allows to change some default settings, if needed. * ******************************************************************************************************************/ @Override public void init() { // setUseAquaFxOnMacOsX(true); super.init(); // always call super.init()!! } /******************************************************************************************************************* * * {@inheritDoc} * * This method retrieves a reference to the main controller and boots it. * ******************************************************************************************************************/ @Override protected void onStageCreated (final @Nonnull ApplicationContext applicationContext) { applicationContext.getBean(MainScreenPresentationControl.class).start(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy