教育行業(yè)A股IPO第一股(股票代碼 003032)

全國(guó)咨詢/投訴熱線:400-618-4000

JavaFX工具怎樣開(kāi)發(fā)用戶界面?【JavaFX入門(mén)】

更新時(shí)間:2021年05月10日16時(shí)41分 來(lái)源:傳智教育 瀏覽次數(shù):

傳智教育-一樣的教育,不一樣的品質(zhì)

通過(guò)前面小節(jié)的學(xué)習(xí),已經(jīng)了解到使用JavaFX工具可以實(shí)現(xiàn)圖形用戶界面開(kāi)發(fā),接下來(lái),就通過(guò)一個(gè)用戶登錄的案例來(lái)演示JavaFX的基本使用。

(1)創(chuàng)建JavaFX項(xiàng)目。打開(kāi)Eclipse,并在Eclipse中依次選擇“File”->“New”->“Others..”->“JavaFX Project”選項(xiàng),創(chuàng)建一個(gè)名稱為“javaFX”的項(xiàng)目,項(xiàng)目創(chuàng)建成功后,如圖1所示。

JavaFX工具開(kāi)發(fā)用戶界面

圖1 JavaFX項(xiàng)目默認(rèn)結(jié)構(gòu)

從圖1可以看出,創(chuàng)建成功的JavaFX項(xiàng)目默認(rèn)在application包下有兩個(gè)文件:Main.java(程序的入口)和application.css(圖形用戶界面樣式文件)。其中,Main.java文件中使用JavaFX工具初始化了一個(gè)圖形界面,直接運(yùn)行該文件,會(huì)得到一個(gè)空白窗口。

(2)編輯Main.java文件。在自動(dòng)生成的Main.java文件中編寫(xiě)JavaFX項(xiàng)目主程序代碼,如文件2所示。

文件1 Main.java

     import javafx.application.*;
     import javafx.fxml.*;
     import javafx.stage.*;
     import javafx.scene.*;
     public class Main extends Application {
         public void start(Stage stage) throws Exception {
             // 使用FXMLLoader加載器,加載名為“fxml_example.fxml”的fxml文件
             Parent root = FXMLLoader.load(
                                   getClass().getResource("fxml_example.fxml"));
             // 創(chuàng)建一個(gè)場(chǎng)景
             Scene scene = new Scene(root, 300, 275);
             // 為圖形界面窗口設(shè)置標(biāo)題
             stage.setTitle("FXML Welcome");
             // 為圖形界面窗口設(shè)置場(chǎng)景
             stage.setScene(scene);
             // 將圖形界面窗口設(shè)置為可見(jiàn)
             stage.show();
         }
         public static void main(String[] args) {
             // 通過(guò)Application抽象類的launch()方法啟動(dòng)程序
             launch(args);
         }
     }

文件1中,Main類繼承了Application抽象類并重寫(xiě)了start()方法,在該方法中,Stage就是JavaFX工具中用來(lái)表示整個(gè)圖形工具界面窗口的類,在該類中需要加入一個(gè)Scene(場(chǎng)景)來(lái)進(jìn)行填充,而所有的組件、元素都是構(gòu)建在Scene中的。另外,在JavaFX 8中支持代碼與布局和樣式分離,所以在文件中通過(guò)FXMLLoader的load()方法引入了一個(gè)外聯(lián)的fxml_example.fxml文件,在此fxml文件中就可以專心編寫(xiě)圖形界面布局和組件相關(guān)功能了。

(3)創(chuàng)建fxml_example.fxml文件。在Main.java文件同級(jí)目錄下依次選擇“File”→“New”→“Others..”→“New FXML Document”選項(xiàng),創(chuàng)建一個(gè)名稱為“fxml_example”的fxml格式文件,如文件2所示。

文件2 fxml_example.fxml

     <?xml version="1.0" encoding="UTF-8"?>
     <!-- 引入JavaFX工具相關(guān)類 -->
     <?import java.net.*?>
     <?import javafx.geometry.*?>
     <?import javafx.scene.control.*?>
     <?import javafx.scene.layout.*?>
     <?import javafx.scene.text.*?>
     <!-- 創(chuàng)建一個(gè)GridPane網(wǎng)格式面板組件 -->
     <GridPane fx:controller="application.FXMLExampleController"
         xmlns:fx="http://javafx.com/fxml" alignment="center" 
                                                  hgap="10" vgap="10">
         <!-- 通過(guò)相關(guān)標(biāo)簽創(chuàng)建一個(gè)模擬登錄的“用戶名”和“密碼”的組件 -->
         <Text text="Welcome" GridPane.columnIndex="0" GridPane.rowIndex="0"
                               GridPane.columnSpan="2" />
         <Label text="用戶名:" GridPane.columnIndex="0" GridPane.rowIndex="1" />
         <TextField GridPane.columnIndex="1" GridPane.rowIndex="1" />
         <Label text="密  碼:" GridPane.columnIndex="0" GridPane.rowIndex="2" />
         <PasswordField GridPane.columnIndex="1" GridPane.rowIndex="2" />
         <!-- 通過(guò)HBox嵌入一個(gè)可調(diào)控位置的盒子組件-->
         <HBox spacing="10" alignment="bottom_right" GridPane.columnIndex="1"
                                                          GridPane.rowIndex="4">
             <!-- 在HBox盒子中裝入一個(gè) Button登錄按鈕,同時(shí)注冊(cè)監(jiān)聽(tīng)器 -->
             <Button text="登  錄:" onAction="#handleSubmitButtonAction" />
         </HBox>
         <!-- 作為登錄按鈕的提示框  -->
         <Text fx:id="actiontarget" GridPane.columnIndex="0"
             GridPane.columnSpan="2" GridPane.halignment="RIGHT"
                                           GridPane.rowIndex="6" />
     </GridPane>

文件2中,編碼風(fēng)格與XML文檔類似。其中第1行代碼用來(lái)引入fxml文件約束;第3~7行代碼用于引入JavaFX工具相關(guān)類;第9~29行代碼使用<GridPane>標(biāo)簽創(chuàng)建了一個(gè)網(wǎng)格式的面板組件,然后通過(guò)各種子標(biāo)簽和屬性向該面板組件中進(jìn)行填充。另外在<GridPane>標(biāo)簽中使用fx:controller="application.FXMLExampleController"引入了application包下的FXMLExampleController事件控制類,并且在第23行中,使用onAction="#handleSubmitButtonAction"注冊(cè)了FXMLExampleController類中的監(jiān)聽(tīng)器方法handleSubmitButtonAction()。

(4)創(chuàng)建并編輯FXMLExampleController.java文件。在Main.java文件同級(jí)目錄下創(chuàng)建一個(gè)名為FXMLExampleController的事件處理類,然后在該文件中編寫(xiě)事件處理方法,如文件3所示。

文件3 FXMLExampleController.java

     import javafx.event.ActionEvent;
     import javafx.fxml.FXML;
     import javafx.scene.text.Text;
     public class FXMLExampleController {
         // 與fxml_example.fxml文件中的登錄提示框fx:id一致
         @FXML private Text actiontarget;
         // 為fxml_example.fxml文件中的登錄按鈕編寫(xiě)事件處理
         @FXML protected void handleSubmitButtonAction(ActionEvent event) {
             actiontarget.setText("點(diǎn)擊了登錄按鈕");
         }
     }

文件3中,F(xiàn)XMLExampleController.java類專門(mén)用于編寫(xiě)事件處理方法,其中使用@FXML注解用來(lái)表示actiontarget文本屬性和handleSubmitButtonAction()方法可以被fxml格式文件訪問(wèn),同時(shí)handleSubmitButtonAction()的方法名與文件2中第23行代碼onAction="#handleSubmitButtonAction"中標(biāo)記的名稱需要相同,actiontarget屬性名與文件2中第26行代碼fx:id="actiontarget"的id名也要相同。

完成上述4步操作后,運(yùn)行主程序Main類,結(jié)果如圖2所示。

JavaFX工具開(kāi)發(fā)用戶界面

圖2 JavaFX項(xiàng)目初步效果圖

(5)為fxml_example.fxml圖形布局文件引入外聯(lián)的CSS樣式文件。

● 先在fxml_example.fxml文件最后的</GridPane>標(biāo)簽之前引入名稱為application.css的樣式表文件,示例如下所示:

<!-- 加入名為application.css的樣式表文件  -->
<stylesheets>
<URL value="@application.css" />
</stylesheets>

● 如果要為GridPane面板組件根元素設(shè)置樣式,需要在<GridPane>標(biāo)簽中添加一個(gè)styleClass="root"的屬性,示例如下所示:

<GridPane fx:controller="fxmlexample.FXMLExampleController" 
  xmlns:fx="http://javafx.com/fxml" alignment="center" 
hgap="10" vgap="10" **styleClass="root"**>

● 同時(shí)可以為某個(gè)組件所在標(biāo)簽添加一個(gè)id,為該id所在組件設(shè)置樣式,比如為text="Welcome"的<Text>標(biāo)簽所在組件添加一個(gè)id,示例如下所示:

<Text **id="welcome-text"** text="Welcome" 
    GridPane.columnIndex="0" GridPane.rowIndex="0" 
    GridPane.columnSpan="2"/>


(6)編輯application.css樣式文件。打開(kāi)application.css樣式文件,為圖8-37所示的JavaFX圖形用戶接口項(xiàng)目編寫(xiě)CSS樣式,如文件4所示。

文件4 application.css

     /* 為GridPane面板組件根元素添加背景圖片 */
     .root {
          -fx-background-image: url("background.jpg");
     }
     /* 為label標(biāo)簽組件設(shè)置大小、顏色、展示效果 */
     .label {
         -fx-font-size: 12px;
         -fx-font-weight: bold;
         -fx-text-fill: #333333;
         -fx-effect: dropshadow( gaussian , rgba(255,255,255,0.5) , 0,0,0,1 );
     }
     /* 為id為welcome-text的組件設(shè)置大小、字體、顏色、展示效果 */
     #welcome-text {
        -fx-font-size: 32px;
        -fx-font-family: "Arial Black";
        -fx-fill: #818181;
        -fx-effect: innershadow( three-pass-box ,rgba(0,0,0,0.7),6, 0.0 , 0 , 2 );
     }
     /* 為id為actiontarget的組件設(shè)置大小、顏色、展示效果 */
     #actiontarget {
       -fx-fill: FIREBRICK;
       -fx-font-weight: bold;
       -fx-effect: dropshadow( gaussian , rgba(255,255,255,0.5) , 0,0,0,1 );  
     }
     /* 為button標(biāo)簽組件設(shè)置大小、顏色、展示效果 */
     .button {
         -fx-text-fill: white;
         -fx-font-family: "Arial Narrow";
         -fx-font-weight: bold;
         -fx-background-color: linear-gradient(#61a2b1, #2A5058);
         -fx-effect: dropshadow( three-pass-box ,rgba(0,0,0,0.6),5, 0.0 , 0 , 1 );
     }
     /* 設(shè)置當(dāng)鼠標(biāo)移到button按鈕時(shí)的大小、顏色、展示效果 */
     .button:hover {
         -fx-background-color: linear-gradient(#2A5058, #61a2b1);
     }

在文件4中,application.css文件專門(mén)用于封裝文件樣式,在上一步中為fxml_example.fxml圖形布局文件引入了該外聯(lián)的CSS樣式文件,<GridPane>根組件的background.jpg背景圖片位于該文件所在同級(jí)目錄中。其中,對(duì)fxml_example.fxml文件中某個(gè)名稱的標(biāo)簽進(jìn)行樣式設(shè)置時(shí),可以使用點(diǎn)號(hào)+標(biāo)簽名(如.button)的形式進(jìn)行設(shè)置;對(duì)某個(gè)id所對(duì)應(yīng)的標(biāo)簽組件進(jìn)行樣式設(shè)置時(shí),可以使用井號(hào)+id(如#welcome-text)的形式進(jìn)行設(shè)置。

當(dāng)編寫(xiě)完并引入application.css樣式文件成功后,再次啟動(dòng)主程序入口Main類中的main()方法,結(jié)果如圖3所示。

JavaFX工具開(kāi)發(fā)用戶界面
圖3 JavaFX項(xiàng)目最終效果圖

猜你喜歡:

JavaFX有什么顯著特征?

HashMap,HashTable,ConcurrentHashMap三者有什么區(qū)別?

什么是Spring Data?

傳智教育Java工程師培訓(xùn)

0 分享到:
和我們?cè)诰€交談!