
- JavaFX 教程
- JavaFX - 首頁
- JavaFX - 概述
- JavaFX 安裝和架構
- JavaFX - 環境
- 使用 Netbeans 安裝 JavaFX
- 使用 Eclipse 安裝 JavaFX
- 使用 Visual Studio Code 安裝 JavaFX
- JavaFX - 架構
- JavaFX - 應用
- JavaFX 2D 形狀
- JavaFX - 2D 形狀
- JavaFX - 繪製線條
- JavaFX - 繪製矩形
- JavaFX - 繪製圓角矩形
- JavaFX - 繪製圓形
- JavaFX - 繪製橢圓
- JavaFX - 繪製多邊形
- JavaFX - 繪製折線
- JavaFX - 繪製三次貝塞爾曲線
- JavaFX - 繪製二次貝塞爾曲線
- JavaFX - 繪製弧形
- JavaFX - 繪製 SVG 路徑
- JavaFX 2D 物件的屬性
- JavaFX - 描邊型別屬性
- JavaFX - 描邊寬度屬性
- JavaFX - 描邊填充屬性
- JavaFX - 描邊屬性
- JavaFX - 描邊線連線屬性
- JavaFX - 描邊斜接限制屬性
- JavaFX - 描邊線帽屬性
- JavaFX - 平滑屬性
- JavaFX 路徑物件
- JavaFX - 路徑物件
- JavaFX - LineTo 路徑物件
- JavaFX - HLineTo 路徑物件
- JavaFX - VLineTo 路徑物件
- JavaFX - QuadCurveTo 路徑物件
- JavaFX - CubicCurveTo 路徑物件
- JavaFX - ArcTo 路徑物件
- JavaFX 顏色和紋理
- JavaFX - 顏色
- JavaFX - 線性漸變圖案
- JavaFX - 徑向漸變圖案
- JavaFX 文字
- JavaFX - 文字
- JavaFX 特效
- JavaFX - 特效
- JavaFX - 顏色調整特效
- JavaFX - 顏色輸入特效
- JavaFX - 圖片輸入特效
- JavaFX - 混合特效
- JavaFX - 輝光特效
- JavaFX - 泛光特效
- JavaFX - 方框模糊特效
- JavaFX - 高斯模糊特效
- JavaFX - 運動模糊特效
- JavaFX - 反射特效
- JavaFX - 棕褐色調特效
- JavaFX - 陰影特效
- JavaFX - 投影陰影特效
- JavaFX - 內陰影特效
- JavaFX - 光照特效
- JavaFX - 遠光源特效
- JavaFX - 聚光燈特效
- JavaFX - 點光源特效
- JavaFX - 位移貼圖
- JavaFX - 透視變換
- JavaFX 動畫
- JavaFX - 動畫
- JavaFX - 旋轉動畫
- JavaFX - 縮放動畫
- JavaFX - 平移動畫
- JavaFX - 淡入淡出動畫
- JavaFX - 填充動畫
- JavaFX - 描邊動畫
- JavaFX - 順序動畫
- JavaFX - 並行動畫
- JavaFX - 暫停動畫
- JavaFX - 路徑動畫
- JavaFX 圖片
- JavaFX - 圖片
- JavaFX 3D 形狀
- JavaFX - 3D 形狀
- JavaFX - 建立長方體
- JavaFX - 建立圓柱體
- JavaFX - 建立球體
- 3D 物件的屬性
- JavaFX - 剔除面屬性
- JavaFX - 繪製模式屬性
- JavaFX - 材質屬性
- JavaFX 事件處理
- JavaFX - 事件處理
- JavaFX - 使用便捷方法
- JavaFX - 事件過濾器
- JavaFX - 事件處理器
- JavaFX UI 控制元件
- JavaFX - UI 控制元件
- JavaFX - 列表檢視
- JavaFX - 手風琴
- JavaFX - 按鈕欄
- JavaFX - 選擇框
- JavaFX - HTML 編輯器
- JavaFX - 選單欄
- JavaFX - 分頁
- JavaFX - 進度指示器
- JavaFX - 滾動窗格
- JavaFX - 分隔符
- JavaFX - 滑塊
- JavaFX - 微調器
- JavaFX - 分割窗格
- JavaFX - 表格檢視
- JavaFX - 標籤頁窗格
- JavaFX - 工具欄
- JavaFX - 樹檢視
- JavaFX - 標籤
- JavaFX - 複選框
- JavaFX - 單選按鈕
- JavaFX - 文字欄位
- JavaFX - 密碼欄位
- JavaFX - 檔案選擇器
- JavaFX - 超連結
- JavaFX - 工具提示
- JavaFX - 警報框
- JavaFX - 日期選擇器
- JavaFX - 文字區域
- JavaFX 圖表
- JavaFX - 圖表
- JavaFX - 建立餅圖
- JavaFX - 建立折線圖
- JavaFX - 建立面積圖
- JavaFX - 建立柱狀圖
- JavaFX - 建立氣泡圖
- JavaFX - 建立散點圖
- JavaFX - 建立堆疊面積圖
- JavaFX - 建立堆疊柱狀圖
- JavaFX 佈局面板
- JavaFX - 佈局面板
- JavaFX - HBox 佈局
- JavaFX - VBox 佈局
- JavaFX - BorderPane 佈局
- JavaFX - StackPane 佈局
- JavaFX - TextFlow 佈局
- JavaFX - AnchorPane 佈局
- JavaFX - TilePane 佈局
- JavaFX - GridPane 佈局
- JavaFX - FlowPane 佈局
- JavaFX CSS
- JavaFX - CSS
- JavaFX 多媒體
- JavaFX - 處理多媒體
- JavaFX - 播放影片
- JavaFX 有用資源
- JavaFX - 快速指南
- JavaFX - 有用資源
- JavaFX - 討論
JavaFX - 手風琴
手風琴充當一個或多個標題面板的容器。這些標題面板是帶有標題的面板,可以透過點選其標題來展開或摺疊。但是,一次只允許開啟一個標題面板。手風琴可用於將UI組織成可以根據需要隱藏或顯示的部分。
下圖顯示了一個手風琴:

JavaFX 中的手風琴
在 JavaFX 中,手風琴由名為Accordion的類表示。此類屬於javafx.scene.control包。透過例項化此類,我們可以在 JavaFX 中建立手風琴節點。
此類有兩個建構函式,如下所示:
Accordion() - 用於建立不帶TitledPane的手風琴。
Accordion(...TitledPanes) - 它將使用指定的TitledPane建立一個手風琴。
在 JavaFX 中建立手風琴的步驟
請按照以下步驟在 JavaFX 中建立手風琴。
步驟 1:建立兩個或多個 TitledPane
我們可以透過例項化名為TitledPane的類(屬於javafx.scene.control包)在 JavaFX 中建立標題面板。如下所示例項化此類:
//Creating a TitledPane object TitledPane paneOne = new TitledPane();
同樣,建立所需數量的標題面板。
步驟 2:設定 TitledPane 的標題和內容
分別使用setText()和setContent()方法指定標題面板的標題和內容,如下面的程式碼塊所示。
paneOne.setText("Your Name"); paneOne.setContent(new Label("My name is: \n Ansh"));
請記住,我們可以根據我們的需求使用 JavaFX 的不同 UI 節點自定義 TitledPane 的內容。
步驟 3:例項化 Accordion 類
例項化javafx.scene.control包中的Accordion類,無需向其建構函式傳遞任何引數值,並使用以下程式碼塊新增所有TitledPane:
Accordion accordionNew = new Accordion(); accordionNew.getPanes().addAll(paneOne, paneTwo, paneThree);
步驟 4:啟動應用程式
建立手風琴後,請按照以下步驟正確啟動應用程式:
首先,透過將 Accordion 物件作為引數值傳遞給其建構函式來例項化名為VBox的類。
然後,透過將 VBox 物件作為引數值傳遞給其建構函式來例項化名為Scene的類。我們還可以將應用程式螢幕的尺寸作為可選引數傳遞給此建構函式。
然後,使用Stage類的setTitle()方法設定舞臺的標題。
現在,使用名為Stage的類的setScene()方法將 Scene 物件新增到舞臺。
使用名為show()的方法顯示場景的內容。
最後,使用launch()方法啟動應用程式。
示例
以下是使用 JavaFX 建立手風琴的程式。將此程式碼儲存在名為JavafxAccordion.java的檔案中。
import javafx.application.Application; import javafx.scene.Scene; import javafx.scene.control.Accordion; import javafx.scene.control.TitledPane; import javafx.scene.control.Label; import javafx.scene.layout.VBox; import javafx.scene.paint.Color; import javafx.stage.Stage; public class JavafxAccordion extends Application { @Override public void start(Stage stage) { //Creating the first TitledPane TitledPane paneOne = new TitledPane(); paneOne.setText("Your Name"); paneOne.setContent(new Label("My name is: \n Ansh")); //Creating the second TitledPane TitledPane paneTwo = new TitledPane(); paneTwo.setText("Your Address"); paneTwo.setContent(new Label("My address is: \n Hyderabad \n Telangana")); //Creating the third TitledPane TitledPane paneThree = new TitledPane(); paneThree.setText("Your Job"); paneThree.setContent(new Label("My job role is: \n Content Engineer")); //Creating an Accordion for all TitledPane Accordion accordionNew = new Accordion(); accordionNew.getPanes().addAll(paneOne, paneTwo, paneThree); accordionNew.setExpandedPane(paneOne); VBox root = new VBox(accordionNew); //Setting the stage Scene scene = new Scene(root, 500, 500, Color.BEIGE); stage.setTitle("Accordion in JavaFX"); stage.setScene(scene); stage.show(); } public static void main(String args[]){ launch(args); } }
使用以下命令從命令提示符編譯並執行儲存的 Java 檔案。
javac --module-path %PATH_TO_FX% --add-modules javafx.controls JavafxAccordion.java java --module-path %PATH_TO_FX% --add-modules javafx.controls JavafxAccordion
輸出
執行上述程式後,將生成一個 JavaFX 視窗,顯示如下所示的手風琴。

使用其引數化建構函式在 JavaFX 中建立手風琴
如前所述,在 JavaFX 中建立手風琴有兩種方法:一種使用 Accordion 類的預設建構函式,另一種使用其引數化建構函式。在下一個示例中,我們將使用 Accordion 類的引數化建構函式在 JavaFX 中建立手風琴。將此 Java 程式碼儲存在名為JavafxAccordion.java的檔案中。
示例
import javafx.application.Application; import javafx.scene.Scene; import javafx.scene.control.Accordion; import javafx.scene.control.TitledPane; import javafx.scene.control.Label; import javafx.scene.layout.VBox; import javafx.scene.paint.Color; import javafx.stage.Stage; public class JavafxAccordion extends Application { @Override public void start(Stage stage) { //Creating the first TitledPane TitledPane paneOne = new TitledPane(); paneOne.setText("Your Name"); paneOne.setContent(new Label("My name is: \n Ansh")); //Creating the second TitledPane TitledPane paneTwo = new TitledPane(); paneTwo.setText("Your Address"); paneTwo.setContent(new Label("My address is: \n Hyderabad \n Telangana")); //Creating the third TitledPane TitledPane paneThree = new TitledPane(); paneThree.setText("Your Job"); paneThree.setContent(new Label("My job role is: \n Content Engineer")); //Creating an Accordion for all TitledPane Accordion accordionNew = new Accordion(paneOne, paneTwo, paneThree); accordionNew.setExpandedPane(paneThree); VBox root = new VBox(accordionNew); //Setting the stage Scene scene = new Scene(root, 500, 500, Color.BEIGE); stage.setTitle("Accordion in JavaFX"); stage.setScene(scene); stage.show(); } public static void main(String args[]){ launch(args); } }
使用以下命令從命令提示符編譯並執行儲存的 java 檔案。
javac --module-path %PATH_TO_FX% --add-modules javafx.controls JavafxAccordion.java java --module-path %PATH_TO_FX% --add-modules javafx.controls JavafxAccordion
輸出
執行上述程式碼時,將生成以下輸出。
