Chapter 10 ■ User InterfaCe DesIgn InteraCtIvIty: event hanDlIng anD ImagIng effeCts
Next, let’s copy and paste the helpButton Java statements into the legalButton event handling structure
and then configure these method call parameter areas by using the correct Text, Background, and Image
objects and pixel location values. Again, clear your TextFlow object and then load your TextFlow object
with your copyText and riteText Text objects using the .addAll() method. Next, set the TextFlow container’s
X,Y pixel location (its position on the screen) using a 240 Integer value for the .setTranslateX() method
call and a 370 Integer value for the .setTranslateY() method call. Load your uiLayout object background
with the Background.EMPTY constant using your .setBackground() method call and then load your
boardGameBackPlate ImageView with your legalLayer Image object by using the .setImage() method call.
This is all accomplished using the following Java code structure inside the .handle() method, as shown
highlighted in the middle of Figure 10-7:
creditButton.setOnAction(new EventHandler
@Override
public void handle(ActionEvent event) {
infoOverlay.getChildren().clear();
infoOverlay.getChildren().addAll(credText, codeText);
infoOverlay.setTranslateX( 240 );
infoOverlay.setTranslateY( 370 );
uiContainer.setBackground(Background.EMPTY);
boardGameBackPlate.setImage(creditLayer);
}
} );
Figure 10-7. Implement the code in the handle() method to reconfigure your creditButton UI compositing
layer objects
Next, use your Run ➤ Project work process and make sure your Credits TextFlow object is positioning
all its Text objects in a readable format on the screen. As you can see in Figure 10-8, your UI screen looks
great. We’ll leave the High Scores Button unimplemented for now, as we’ll be creating a scoring engine and
high score table a bit later.