The official definition of JavaFX - OpenJFX is an open source, next generation client application platform for desktop, mobile and embedded systems built on Java.
JavaFX in an open-source platform and follows GPL with the class path exception, similar to OpenJDK. This tutorial provides all the steps required to write the Hello World Application in JavaFX on macOS using e(fx)clipse plugin for the Eclipse IDE and JavaFX SDK. We can also use either of the build systems among Maven or Gradle instead of JavaFX SDK. It assumes that Java and eclipse are already installed on the system.
The tutorials relevant to installing Java and Eclipse include How To Install Java 13 On Mac, How To Install Java 14 On Mac, How To Install OpenJDK 14 On Mac, and How To Install Eclipse For Java On Mac.
You can also refer to Hello World in JavaFX for Windows and Ubuntu. I have used OpenJDK 14.0.1, Eclipse Java 2020 03 R, e(fx)clipse 3.6.0, and JavaFX SDK 14 while writing this tutorial.
Step 1: Install e(fx)clipse Plugin
In this step, we will install the e(fx)clipse plugin for the Eclipse IDE. Click the Help Option on the Main Menu and click the Eclipse Marketplace Option as shown in Fig 1.
data:image/s3,"s3://crabby-images/63bb7/63bb7e15b5ade19d6150dcb11076bf5553135a6f" alt="JavaFX - Eclipse - Marketplace JavaFX - Eclipse - Marketplace"
Fig 1
Search for JavaFX as shown in Fig 2.
data:image/s3,"s3://crabby-images/6b98a/6b98a74d1800fb4a4974bf820f36da92a7968069" alt="JavaFX - Eclipse - Marketplace JavaFX - Eclipse - Marketplace"
Fig 2
Now click the Install Button to start installing e(fx)clipse plugin on Eclipse. It will show the installation progress and ask to accept the License Agreement as shown in Fig 3 and Fig 4.
data:image/s3,"s3://crabby-images/ab6ec/ab6ec955d8ca2544cad3de3f7e6b354259c13af0" alt="JavaFX - Eclipse - Install JavaFX - Eclipse - Install"
Fig 3
It might throw an error at this stage. In such case, again follow the steps as shown in Fig 1 and Fig 2.
data:image/s3,"s3://crabby-images/5cca6/5cca6742e933aa7ae78ec7aa5c9f1cb18c64acc3" alt="JavaFX - Eclipse - License Agreement JavaFX - Eclipse - License Agreement"
Fig 4
Accept the License and click the Finish Button to start the installation. It will ask to accept the Certificate and restart the IDE after successfully installing the plugin as shown in Fig 5 and Fig 6.
data:image/s3,"s3://crabby-images/c464b/c464bed3a74f74b2462fdc2045431221643cd7fb" alt="JavaFX - Eclipse - Certificate JavaFX - Eclipse - Certificate"
Fig 5
data:image/s3,"s3://crabby-images/ec5b1/ec5b119d71efdbaa16810a006784339b3b618d9d" alt="JavaFX - Eclipse - Restart JavaFX - Eclipse - Restart"
Fig 6
Click Restart Now to apply the plugin-specific changes. This completes the installation of e(fx)clipse plugin on Eclipse.
Step 2: Create JavaFX Project
Now click the New Option on Main Menu and click the Other Option as shown in Fig 7.
data:image/s3,"s3://crabby-images/e34c7/e34c71cad9c786b790e714a7fe0f316764fffc17" alt="JavaFX - Eclipse - New Project JavaFX - Eclipse - New Project"
Fig 7
It will show the project type selection wizard as shown in Fig 8.
data:image/s3,"s3://crabby-images/6344c/6344c20a2e0f01c72fd361a068677114b350bba6" alt="JavaFX - Eclipse - New Project JavaFX - Eclipse - New Project"
Fig 8
Now click the Next Button to configure the project as shown in Fig 9.
data:image/s3,"s3://crabby-images/d1070/d1070611eff333c91f2970c9ae01108dd3ba4904" alt="JavaFX - Eclipse - Configure Project JavaFX - Eclipse - Configure Project"
Fig 9
Configure the project and click the Next Button. We can further configure the Java for the project as shown in Fig 10.
data:image/s3,"s3://crabby-images/f9ff7/f9ff7a0afebe238e0e902be910647c3b07692e00" alt="JavaFX - Eclipse - Configure Project JavaFX - Eclipse - Configure Project"
Fig 10
Now click the Next Button to configure the Application as shown in Fig 11.
data:image/s3,"s3://crabby-images/3203c/3203c24a66bdf62e9c117a1f20f32568f14eba49" alt="JavaFX - Eclipse - Configure Application JavaFX - Eclipse - Configure Application"
Fig 11
Finally, click the Finish Button to complete the project creation and configuration. It will create the project and shows on the projects library as shown in Fig 12.
data:image/s3,"s3://crabby-images/6dfac/6dfac4d608734b08dadb2e8f43c52e8bd63c60e2" alt="JavaFX - Eclipse - Project JavaFX - Eclipse - Project"
Fig 12
Step 3: Fix the Imports
In this step, we will fix the imports by creating a user-defined library since JavaFX is not bundled with the JDK since Java 11. We need to create this library for the first time and it can be used for multiple projects. Open the Application Class file to view the import errors as shown in Fig 13.
data:image/s3,"s3://crabby-images/fd8e1/fd8e14fb8966b24f546442a0fff71a8e5ee3b31a" alt="JavaFX - Eclipse - Import Errors JavaFX - Eclipse - Import Errors"
Fig 13
Download the JavaFX SDK from the official website. We can use either JavaFX 11 LTS or JavaFX 14 as shown in Fig 14. I have downloaded JavaFX 14 SDK as highlighted in Fig 14.
data:image/s3,"s3://crabby-images/cdd75/cdd75f2cecbdaf05f4577d7c4dc8d75a626e885e" alt="JavaFX - Eclipse - Downloads JavaFX - Eclipse - Downloads"
Fig 14
Now extract the downloaded JavaFX SDK to the appropriate location. We will add a new user-defined library to the eclipse. Click the Eclipse Option on the Main Menu and navigates to Preferences -> Java -> Build Path -> User Libraries and click the New Button as highlighted in Fig 15.
data:image/s3,"s3://crabby-images/54551/5455189c2860c9a4774ab04aa5ede659ee4b9df6" alt="JavaFX - Eclipse - User Libraries JavaFX - Eclipse - User Libraries"
Fig 15
On clicking the New Button, it will ask the library name as shown in Fig 16.
data:image/s3,"s3://crabby-images/84e48/84e48a729e60331a46778f702f44740b46d3b021" alt="JavaFX - Eclipse - Add User Library JavaFX - Eclipse - Add User Library"
Fig 16
Provide the appropriate library name and click the OK Button. It will create the library as shown in Fig 17.
data:image/s3,"s3://crabby-images/dc390/dc39038ee5d77608516f501639be646c40fa3804" alt="JavaFX - Eclipse - User Libraries JavaFX - Eclipse - User Libraries"
Fig 17
Now click the Add External JARs Button as shown in Fig 17. It will ask to choose the JARs to be added to the library created by us. Navigate to the lib directory of the JavaFX SDK downloaded by us and select the JARs as shown in Fig 18.
data:image/s3,"s3://crabby-images/fcf4c/fcf4c8ce124d059339ad6727b06b7607e68cce29" alt="JavaFX - Eclipse - Library Jars JavaFX - Eclipse - Library Jars"
Fig 18
Now click the Open Button to add the JARs to the library. The library gets updated with the selected JARs as shown in Fig 19.
data:image/s3,"s3://crabby-images/caf7d/caf7d39a1c225daefc5872b7d98e7bf6b6eeb2ba" alt="JavaFX - Eclipse - Library Jars JavaFX - Eclipse - Library Jars"
Fig 19
Click the Apply and Close Button to finalize the library. Now right-click the project and click the Properties Option as shown in Fig 20.
data:image/s3,"s3://crabby-images/e93f8/e93f8047dc88c90f9d308effa614997fe09bbe4e" alt="JavaFX - Eclipse - Project Properties JavaFX - Eclipse - Project Properties"
Fig 20
Click the Java Build Path and Libraries as shown in Fig 21. I have also highlighted the Classpath.
data:image/s3,"s3://crabby-images/0168d/0168d770cf60b62a99247238161541c46727f101" alt="JavaFX - Eclipse - Project Libraries JavaFX - Eclipse - Project Libraries"
Fig 21
Click the Add Library Button on the left side to add the library created by us. It will open the wizard to add the library as shown in Fig 22.
data:image/s3,"s3://crabby-images/552f9/552f9694111b0f46b03d5640f0d0ff4d55eb0e65" alt="JavaFX - Eclipse - Add Project Library JavaFX - Eclipse - Add Project Library"
Fig 22
Now choose User Library and click the Next Button. It will show all the user libraries as shown in Fig 23 and Fig 24.
data:image/s3,"s3://crabby-images/56bbf/56bbffb034c8578438bcd76903524faa3081a216" alt="JavaFX - Eclipse - Add Project Library JavaFX - Eclipse - Add Project Library"
Fig 23
data:image/s3,"s3://crabby-images/b196a/b196abdcf74a232d503c325460aba57661618b15" alt="JavaFX - Eclipse - Project Libraries JavaFX - Eclipse - Project Libraries"
Fig 24
Choose the JavaFX library created by us and click the Finish Button. Also note that I have removed the JavaFX SDK library added by the e(fx)clipse plugin. Now click Apply and Close Button. It will add the library to our project and also resolve the import errors as shown in Fig 25.
data:image/s3,"s3://crabby-images/f800e/f800e79061ac6e8c75e32a8e00d03bdd59097ab0" alt="JavaFX - Eclipse - Project JavaFX - Eclipse - Project"
Fig 25
Step 4: Run the Project
In this step, we configure the project runtime and run the project. Now right-click the Project -> Run As -> Java Application as shown in Fig 26.
data:image/s3,"s3://crabby-images/0a8f5/0a8f531c20d4a1d15020e5e8a14e43fad8fbbd74" alt="JavaFX - Eclipse - Run Project JavaFX - Eclipse - Run Project"
Fig 26
It will ask to choose the Main Class as shown in Fig 27.
data:image/s3,"s3://crabby-images/d5a35/d5a35e7e9217a4eb5518725a645a65877ec5d0cf" alt="JavaFX - Eclipse - Main Class JavaFX - Eclipse - Main Class"
Fig 27
Now choose the Main class and click the OK Button to execute the application. It will show the missing runtime error as shown in Fig 28.
data:image/s3,"s3://crabby-images/a7dd3/a7dd3c13a59151482b71dce2755b2051bb21a0f2" alt="JavaFX - Eclipse - Missing Components JavaFX - Eclipse - Missing Components"
Fig 28
So, the default run configuration did not execute our project since it's missing the JavaFX runtime components. We can configure it for the project by creating our own Run Configuration. Now right-click the Project -> Run As -> Run Configuration as shown in Fig 29.
data:image/s3,"s3://crabby-images/b3a97/b3a979f323f163aa74a97fb27cd0bbc0e2910bcd" alt="JavaFX - Eclipse - Run Config JavaFX - Eclipse - Run Config"
Fig 29
It will show the run configurations as shown in Fig 30.
data:image/s3,"s3://crabby-images/9cf35/9cf358c6d64c207e39569db7fc6552a76b536e97" alt="JavaFX - Eclipse - Run Config JavaFX - Eclipse - Run Config"
Fig 30
Now click the New launch configuration Icon as highlighted in Fig 30 and configure the Arguments. Click the Arguments Tab and use the below-mentioned arguments by providing the appropriate path to the JavaFX SDK.
--module-path "<JavaFX SDK Path>/lib" --add-modules javafx.controls,javafx.fxml
Also, configure the Main Class as shown in Fig 31.
data:image/s3,"s3://crabby-images/6d9a6/6d9a6557362af88a407fcb28485091b239372ce5" alt="JavaFX - Eclipse - Run Config JavaFX - Eclipse - Run Config"
Fig 31
Now click the Apply Button and click the Run Button to execute the application using the Run Configuration created by us. It might throw an error as shown in Fig 32 on macOS Mojave and macOS Catalina since the OpenGL is deprecated on these operating systems. Apple introduced macOS Metal Framework and deprecated OpenGL.
data:image/s3,"s3://crabby-images/f3b7d/f3b7dcca559f31d2ece7bf0758b0dbab4ea22c88" alt="JavaFX - Eclipse - Render Error JavaFX - Eclipse - Render Error"
Fig 32
It will build and run the application below macOS Mojave. It will simply show the Coffee Icon without application window. After adding an additional configuration as shown in Fig 33, the application ran fine as shown in Fig 34.
data:image/s3,"s3://crabby-images/f8fee/f8fee5f1cadc5c520a26edeb7521b77305f0f622" alt="JavaFX - Eclipse - Runtime Config JavaFX - Eclipse - Runtime Config"
Fig 33
data:image/s3,"s3://crabby-images/805d2/805d2d8f7fea6298fce34537508c47f2fb0a23c7" alt="JavaFX - Eclipse - App Window JavaFX - Eclipse - App Window"
Fig 34
This is the simplest application that can be written using JavaFX.
Summary
This tutorial provided all the steps required to install e(fx)clipse plugin for the Eclipse IDE and also provided all the configurations and processes required to create and execute the first JavaFX application.