Graphics Supplement (Part 2)
Sections 5.4, 6.8, 7.6, 8.5
Graphics Supplement 5-8: Outline
The GraphicsContext
Class
- An object of the
GraphicsContext
class represents an area of the screen
- JavaFX applications use the metaphor of a
Stage
and Scene
- The
Scene
object contains a set of Nodes
called a scene graph
that describes a scene of the applications, just like the script, actors, and props describe a scene in a play or movie
- In out simple JavaFX applications we create a special type of Node called a
Group
that contains other Nodes and can auto-size based on the nodes within the group
- At this point, sufficient to know that
GraphicsContext
is a class that allows us to draw figures and write text in an area of the application.
- Figure 5.8 Some Methods in the Class
GraphicsContext
data:image/s3,"s3://crabby-images/a0b42/a0b4252d9b8eeb52c1a7e994c35ead8b9dbe306d" alt="Figure5.8"
Drawing Images and Applying Effects
- We can use the
drawImage
method to draw an image on the screen and apply a variety of image effects.
- View sample program, listing 5.23, for reading an image file and drawing it with scale and reflection.
data:image/s3,"s3://crabby-images/83d5c/83d5c2283597aabd67471adb35bed7d345af8dc8" alt="Listing5.23"
Programming Example
- Multiple faces - using a Helping method
- View sample code, listing 5.24 class
MultipleFaces
data:image/s3,"s3://crabby-images/f77e1/f77e11526dfc4df23f4ba434c6ebb3ff83cd38c6" alt="Listing5.24"
Adding Labels to a JavaFX Application
- Provides a way to add text to an application
- More flexible than using
fillText
- Add a
Label
in conjunction with a Layout
which specifies how components will be arranged visually in the window
- Here we use a simple vertical box layout,
VBox
- View sample application, listing 5.25 class
LabelDemo
data:image/s3,"s3://crabby-images/14ee1/14ee122c4a154704bccb6486e489a72b130276e9" alt="listing5.25"
Graphics Supplement: Outline: 6.8
- Adding buttons
- Adding button images
- Create object of type
Button
- Buttons don’t do anything yet when clicked, this is covered in chapter 8
- Application Output:
data:image/s3,"s3://crabby-images/8618f/8618f175183f22cc56f96a03aa0b01fbf1c7212c" alt="addingButtons"
Adding Images
- An image is a picture
- Can load an image stored in standard formats by creating an
Image
object and sending in the pathname to the file
Image img = new Image("pathname-to-image-file");
- Image can be added to other components, such as a button
btn.setGraphic(new ImageView(img));
- View button image demo, listing 6.22 class
IconDemo
- Note
- Creation of image
- Attaching to button
data:image/s3,"s3://crabby-images/f5907/f59077dd0fa2ad883a2d9b89dcfef0999ce61218" alt="listing6.22"
Graphic Supplement: Outline
- Layout Panes
- VBox
- HBox
- StackPane
- FlowPane
- GridPane
- BorderPane
- Combining Layouts
- The Classes
TextArea
and TextField
- Drawing Polygons
HBox Layout
- Layout panes control how components are laid out and displayed in a JavaFX application.
- We’ve already seen VBox, which arranges components vertically
- The HBox layout arranges components horizontally
- View sample code, listing 7.15, class
HBoxDemo
data:image/s3,"s3://crabby-images/5abd7/5abd7d152246dd2e0bc1ada13a1ec7f10a8367a6" alt="listing7.15"
StackPane Layout
- The StackPane layout stacks components on top of one another
- This provides a way to overlay text onto a shape or image to create a more complex object
- View sample code, listing 7.16, class
StackPaneDemo
data:image/s3,"s3://crabby-images/e1ff2/e1ff262d3157e2e7949fb7073997f700f895257b" alt="listing.7.16"
FlowPane Layout
- The FlowPane layout adds components left to right and wraps around to the left when the right side of screen is reached
- You can control the amount of vertical and horizontal space between elements by using the methods
setVgap
and setHgap
- View sample code, listing 7.17, class
FlowPaneDemo
data:image/s3,"s3://crabby-images/1a4b2/1a4b210b706ffdddb5c077570268a72f8cee3876" alt="listing.7.17"
GridPane Layout
- The GridPane layout arranges components into a grid of rows and columns that are accessible like a 2D array
- The upper left cell is at 0,0:
- “Out there” is at 2, 2
- This a Button 1 is at 1, 0
- View sample code, listing 7.18, class
GridPaneDemo
data:image/s3,"s3://crabby-images/93fea/93fea1304f1c0693c08eff8f3c2483d3344b5d70" alt="listing7.18"
BorderPane Layout
- The BorderPane layout places items into the five regions shown below. Unused regions take up no space.
data:image/s3,"s3://crabby-images/41170/41170327c647c0c5abfc8afabafc9ef8ece5c4ac" alt="listing7.19"
- View sample code, listing 7.19, class
BorderPaneDemo
- BorderPaneDemo Output
data:image/s3,"s3://crabby-images/ebc93/ebc9398080c288b8b092ae786ac2ae040b253236" alt="lBorderPaneDemo"
Text Areas, Text Fields
- Text area is object of class
TextArea
- Displayed as place for user to enter multiple lines of text
- Text area is object of class
TextField
- Displayed as a place for user to enter a single line of text
- Can place into layouts
- View sample code, listing 7.20, class
TextControlDemo
data:image/s3,"s3://crabby-images/6d420/6d420301f1d714e8769c46d665a7a94a4cba7f59" alt="Lisiting7.20"
Combining Layout
- Layouts can be added as a component inside another layout, giving you the flexibility to create sophisticated interfaces
- View sample code, listing 7.21, class
CombinedLayoutDemo
, which embeds a HBox and FlowPane into a BorderPane
data:image/s3,"s3://crabby-images/25863/25863ff2c6fbb690e7ce6ec4cb6e8966f220445a" alt="listing7.21"
Drawing Polygons
- Class GraphicsContext has method
strokeRect
- But only 4 sides and only 90 degrees corners
- Method
stokePolygons
can draw polygons of any number of sides
- Three arguments
- Array of
double
for x values of coordinates
- Array of
double
for y values of coordinates
- Number of points (vertices)
- A polyline like a polygon, not closed
- Figure 7.10 A polygon and a polyline
data:image/s3,"s3://crabby-images/7b2cb/7b2cb67707476fe6e77b8c74c48547f7dd3cfc33" alt="figure7.10"
- View sample application, listing 7.22 class
PolygonDemo
data:image/s3,"s3://crabby-images/2a90a/2a90add569d0cdf29b7bc05df2b32b4baa8da5bf" alt="listing.7.22"
Graphics Supplement: Outline: 8.5
- Event-Driven Programming
- Separate class to handle events
- Anonymous inner class
- Same class as the window
Event Firing and Event Listeners
- An event object is generated when something happens, like a button is clicked, the mouse is moved, the mouse is over a component, the mouse leaves a component, etc.
- You specify what happens when the event occurs by creating an event handler or listener
data:image/s3,"s3://crabby-images/24789/24789a4d3e956acd7811219542c81379c7e9a8d8" alt="eventFiring"
data:image/s3,"s3://crabby-images/8f049/8f0499ab21436ddc3ceec41b25d2e79b81cf3e26" alt="figure8.7"
Event Handling with a Separate Class
- We can write a class whose purpose is specifically to handle a particular event, in this case, to react to a button click
- View event handler demo 1, listing 8.20,
ButtonDemo1
and event handler, listing 8.21, HandleButtonClick
data:image/s3,"s3://crabby-images/dbeee/dbeeedf4e399ceba0d6e90087988f07274f551fb" alt="listing8.21"
Event Handling in the Main GUI Class
- We can put the event handler in the same class as the GUI; this allows the event handler to have easy access to any GUI class variables
- Add the handler and implement the ActionListener
- View event handling demo 2, listing 8.22,
ButtonDemo2
data:image/s3,"s3://crabby-images/18e5f/18e5fd1d389a47b5ef87bd0aec0addee797155eb" alt="listing8.22"
Event Handling in an Anonymous Inner Class
- We can create a new event handler by creating an anonymous inner class for each event we want to handle
- This is a class with no name that we declared an instantiate at the same time
- View event handling demo 3, listing 8.23,
ButtonDemo3
data:image/s3,"s3://crabby-images/edc7e/edc7e67069c73365cb144c0b2760ab8b34bb0eb7" alt="listing8.23"
Event Handling Example - Adding Numbers
- An example that ties together layouts (GridPane with BorderPane) and event handling to add two numbers together is shown in
AddingNumbersApp
- View event handling demo 4, listing 8.24,
AddingNumbersApp
data:image/s3,"s3://crabby-images/d741d/d741d922e97d87aa15d31dc4635024a81f3fabe1" alt="listing8.24"
Powerpoint