0% found this document useful (0 votes)
52 views

Topic 6 (1) JavaFX

JavaFX is the new GUI framework that replaces Swing and AWT for developing rich internet applications in Java. The basic structure of a JavaFX application includes a Stage containing a Scene with Nodes. JavaFX introduces binding properties to synchronize property values between objects. It provides various layout panes, controls, shapes, colors, fonts and images that can be used to build the user interface.
Copyright
© © All Rights Reserved
Available Formats
Download as PPT, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
52 views

Topic 6 (1) JavaFX

JavaFX is the new GUI framework that replaces Swing and AWT for developing rich internet applications in Java. The basic structure of a JavaFX application includes a Stage containing a Scene with Nodes. JavaFX introduces binding properties to synchronize property values between objects. It provides various layout panes, controls, shapes, colors, fonts and images that can be used to build the user interface.
Copyright
© © All Rights Reserved
Available Formats
Download as PPT, PDF, TXT or read online on Scribd
You are on page 1/ 36

CSF3043 OBJECT-ORIENTED

PROGRAMMING

1
TOPIC 6(1)
JavaFX Basics
Chapter 14

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
2
Motivations
JavaFX is a new framework for developing Java
GUI programs. The JavaFX API is an excellent
example of how the object-oriented principle is
applied. This chapter serves two purposes. First, it
presents the basics of JavaFX programming.
Second, it uses JavaFX to demonstrate OOP.
Specifically, this chapter introduces the framework
of JavaFX and discusses JavaFX GUI components
and their relationships.

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
3
Objectives
 To distinguish between JavaFX, Swing, and AWT (§14.2).
 To write a simple JavaFX program and understand the relationship among stages,
scenes, and nodes (§14.3).
 To create user interfaces using panes, UI controls, and shapes (§14.4).
 To use binding properties to synchronize property values (§14.5).
 To use the common properties style and rotate for nodes (§14.6).
 To create colors using the Color class (§14.7).
 To create fonts using the Font class (§14.8).
 To create images using the Image class and to create image views using the
ImageView class (§14.9).
 To layout nodes using Pane, StackPane, FlowPane, GridPane, BorderPane, HBox, and
VBox (§14.10).
 To display text using the Text class and create shapes using Line, Circle, Rectangle,
Ellipse, Arc, Polygon, and Polyline (§14.11).
 To develop the reusable GUI components ClockPane for displaying an analog clock
(§14.12).

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
4
JavaFX vs Swing and AWT
Swing and AWT are replaced by the JavaFX platform for
developing rich Internet applications.

When Java was introduced, the GUI classes were bundled in a


library known as the Abstract Windows Toolkit (AWT). AWT is
fine for developing simple graphical user interfaces, but not for
developing comprehensive GUI projects. In addition, AWT is
prone to platform-specific bugs. The AWT user-interface
components were replaced by a more robust, versatile, and
flexible library known as Swing components. Swing components
are painted directly on canvases using Java code. Swing
components depend less on the target platform and use less of
the native GUI resource. With the release of Java 8, Swing is
replaced by a completely new GUI platform known as JavaFX.

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
5
Basic Structure of JavaFX
 Application
 Override the start(Stage) method
 Stage, Scene, and Nodes
Stage
Scene

Button

MyJavaFX Run

MultipleStageDemo Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
6
Panes, UI Controls, and Shapes

ButtonInPane Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
7
Display a Shape
This example displays a circle in the center of the pane.

x
Y Axis
(0, 0) X Axis

y
(x, y)
(0, 0) X Axis
Java Conventional
Coordinate Coordinate
System System
Y Axis

ShowCircle Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
8
Binding Properties
JavaFX introduces a new concept called binding property
that enables a target object to be bound to a source
object. If the value in the source object changes, the
target property is also changed automatically. The target
object is simply called a binding object or a binding
property.

ShowCircleCentered Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
9
Binding Property:
getter, setter, and property getter

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
10
Uni/Bidirectional Binding

BindingDemo Run

BidirectionalBindingDemo Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
11
Common Properties and Methods
for Nodes
 style: set a JavaFX CSS style

 rotate: Rotate a node

NodeStyleRotateDemo Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
12
The Color Class

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
13
The Font Class

FontDemo Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
14
The Image Class

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
15
The ImageView Class

ShowImage Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
16
Layout Panes
JavaFX provides many types of panes for organizing nodes
in a container.

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
17
FlowPane

MultipleStageDemo Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
18
GridPane

ShowGridPane
Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
19
BorderPane

ShowBorderPane Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
20
HBox

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
21
VBox

ShowHBoxVBox Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
22
Shapes
JavaFX provides many shape classes for drawing texts,
lines, circles, rectangles, ellipses, arcs, polygons, and
polylines.

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
23
Text

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
24
Text Example

ShowText Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
25
Line

ShowLine Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
26
Rectangle

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
27
Rectangle Example

ShowRectangle Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
28
Circle

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
29
Ellipse

radiusX radiusY
(centerX, centerY)

ShowEllipse Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
30
Arc

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
31
Arc Examples
radiusY length

startAngle

0 degree

radiusX
(centerX, centerY)

–30° –50°

–20° 20°

(a) Negative starting angle –30° and (b) Negative starting angle –50°
negative spanning angle –20° and positive spanning angle 20°

ShowArc Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
32
Polygon and Polyline

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
33
Polygon
The getter and setter methods for property values and a getter for property
javafx.scene.shape.Polygon itself are provided in the class, but omitted in the UML diagram for brevity.

+Polygon() Creates an empty polygon.


+Polygon(double... points) Creates a polygon with the given points.
+getPoints(): Returns a list of double values as x- and y-coordinates of the points.
ObservableList<Double>

ShowPolygon Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
34
Case Study: The ClockPane Class
This case study develops a class that displays a clock on a
pane.

javafx.scene.layout.Panel The getter and setter methods for


-char token these data fields are provided in the class,
but omitted in the UML diagram for brevity.
+getToken
+setToken ClockPane
+paintComponet
+mouseClicked
-hour: int The hour in the clock.
-minute: int The minute in the clock.
-second: int The second in the clock.

+ClockPane() Constructs a default clock for the current time.


+ClockPane(hour: int, minute: int, Constructs a clock with the specified time.
second: int)
+setCurrentTime(): void Sets hour, minute, and second for current time.
+setWidth(width: double): void Sets clock pane’s width and repaint the clock,
+setHeightTime(height: double): void Sets clock pane’s height and repaint the clock,

ClockPane
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
35
Use the ClockPane Class

DisplayClock Run

Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
36

You might also like