- JavaFX 教程
- JavaFX - 首頁
- JavaFX - 概述
- JavaFX 安裝和架構
- JavaFX - 環境
- JavaFX - 使用 Netbeans 安裝
- JavaFX - 使用 Eclipse 安裝
- JavaFX - 使用 Visual Studio Code 安裝
- JavaFX - 架構
- JavaFX - 應用程式
- JavaFX 二維形狀
- JavaFX - 二維形狀
- JavaFX - 繪製直線
- JavaFX - 繪製矩形
- JavaFX - 繪製圓角矩形
- JavaFX - 繪製圓形
- JavaFX - 繪製橢圓
- JavaFX - 繪製多邊形
- JavaFX - 繪製折線
- JavaFX - 繪製三次貝塞爾曲線
- JavaFX - 繪製二次貝塞爾曲線
- JavaFX - 繪製弧形
- JavaFX - 繪製 SVG 路徑
- JavaFX 二維物件的屬性
- 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 三維形狀
- JavaFX - 三維形狀
- 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 - 分隔符
一個分隔符是用於分隔 JavaFX 應用程式 UI 元素的水平或垂直線。請注意,它不會產生任何操作。但是,可以對其進行樣式設定,應用視覺效果,甚至對其進行動畫處理以提供更好的使用者體驗。在下圖中,我們可以看到垂直和水平分隔符 -
JavaFX 中的分隔符
在 JavaFX 中,分隔符由名為Separator的類表示。此類屬於包javafx.scene.control。透過例項化此類,我們可以在 JavaFX 中建立一個分隔符。此類具有以下建構函式 -
Separator() - 它建立一個新的水平分隔符。
Separator(Orientation orientation) - 它建立一個具有指定方向的分隔符。方向可以是垂直或水平。
在 JavaFX 中建立分隔符
我們需要按照以下步驟在 JavaFX 中建立分隔符。
步驟 1:建立將要分隔的節點
由於分隔符用於分隔 JavaFX 中的 UI 節點。因此,需要指定將要分隔的 UI 元素。例如,我們使用以下程式碼建立按鈕 -
// Creating Buttons
Button btn1 = new Button("Button 1");
Button btn2 = new Button("Button 2");
Button btn3 = new Button("Button 3");
Button btn4 = new Button("Button 4");
步驟 2:例項化 Separator 類
在 JavaFX 中,分隔符是透過例項化名為Separators的類建立的,該類屬於包javafx.scene.control。如下所示,在start()方法內例項化此類 -
// creating a separator Separator sep1 = new Separator();
步驟 3:設定所需的方向
預設情況下,分隔符是水平的,但是,我們可以使用setOrientation()方法並將 Orientation 列舉值(HORIZONTAL 或 VERTICAL)作為引數傳遞來更改其方向。以下程式碼將方向設定為垂直 -
sep1.setOrientation(Orientation.VERTICAL);
此外,分隔符佔據分配給它的全部水平或垂直空間。因此,有必要使用setMaxWidth()或setMaxHeight方法根據需要設定其最大寬度或高度。要指定分配空間內分隔線的水平或垂直對齊方式,請使用setHalignment或setValignment方法並將HPos或VPos列舉值作為引數傳遞。
步驟 4:啟動應用程式
建立分隔符後,請按照以下步驟正確啟動應用程式 -
首先,透過將 ChoiceBox 物件作為引數值傳遞給其建構函式來例項化名為Scene的類。我們還可以將應用程式螢幕的尺寸作為可選引數傳遞給此建構函式。
然後,使用Stage類的setTitle()方法設定舞臺的標題。
現在,使用名為Stage的類的setScene()方法將 Scene 物件新增到舞臺。
使用名為show()的方法顯示場景的內容。
最後,在launch()方法的幫助下啟動應用程式。
示例
以下 JavaFX 程式演示瞭如何在 JavaFX 應用程式中按鈕之間建立分隔符。將此程式碼儲存在名為JavafxSeparator.java的檔案中。
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.Separator;
import javafx.scene.layout.GridPane;
import javafx.geometry.Orientation;
import javafx.stage.Stage;
import javafx.geometry.Pos;
public class JavafxSeparator extends Application {
@Override
public void start(Stage stage) {
// creating grid to contain buttons
GridPane newgrid = new GridPane();
// set horizontal and vertical gap
newgrid.setHgap(10);
newgrid.setVgap(10);
newgrid.setAlignment(Pos.CENTER);
// Creating Buttons
Button btn1 = new Button("Button 1");
Button btn2 = new Button("Button 2");
Button btn3 = new Button("Button 3");
Button btn4 = new Button("Button 4");
// adding buttons to the grid
newgrid.add(btn1, 0, 0);
newgrid.add(btn2, 2, 0);
newgrid.add(btn3, 0, 1);
newgrid.add(btn4, 2, 1);
// creating a horizontal and a vertical separator
Separator sep1 = new Separator();
Separator sep2 = new Separator();
sep2.setOrientation(Orientation.VERTICAL);
// Setting background color to the separators
sep1.setStyle("-fx-background-color: #D2691E;");
sep2.setStyle("-fx-background-color: #D2691E;");
// adding separators to the grid
newgrid.add(sep1, 0, 2, 2, 1);
newgrid.add(sep2, 1, 0, 1, 2);
// creating scene and stage
Scene scene = new Scene(newgrid, 400, 300);
stage.setTitle("Separator 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 JavafxSeparator.java java --module-path %PATH_TO_FX% --add-modules javafx.controls JavafxSeparator
輸出
當我們執行上述程式碼時,它將生成以下輸出。
使用其引數化建構函式在 JavaFX 中建立分隔符
如前所述,在 JavaFX 中建立分隔符有兩種方法:一種使用 Separator 類的預設建構函式,另一種使用其引數化建構函式。在下一個示例中,我們將使用Separator類的引數化建構函式在 JavaFX 中建立一個分隔符。將此程式碼儲存在名為VerticalSeparator.java的檔案中。
示例
import javafx.application.Application;
import javafx.geometry.Insets;
import javafx.scene.Scene;
import javafx.scene.control.Separator;
import javafx.scene.control.TextField;
import javafx.scene.layout.HBox;
import javafx.stage.Stage;
import javafx.geometry.Orientation;
public class VerticalSeparator extends Application {
@Override
public void start(Stage stage) {
// creating three text fields
TextField textField1 = new TextField();
TextField textField2 = new TextField();
TextField textField3 = new TextField();
// creating vertical separators
Separator separator1 = new Separator(Orientation.VERTICAL);
Separator separator2 = new Separator(Orientation.VERTICAL);
// creating HBox
HBox hbox = new HBox();
hbox.setPadding(new Insets(15, 12, 15, 12));
hbox.setSpacing(10);
hbox.getChildren().addAll(textField1, separator1, textField2, separator2, textField3);
// setting the scene and stage
Scene scene = new Scene(hbox, 500, 300);
stage.setScene(scene);
stage.show();
}
public static void main(String[] args) {
launch(args);
}
}
使用以下命令從命令提示符編譯和執行儲存的 Java 檔案 -
javac --module-path %PATH_TO_FX% --add-modules javafx.controls VerticalSeparator.java java --module-path %PATH_TO_FX% --add-modules javafx.controls VerticalSeparator
輸出
執行上述程式碼後,它將生成以下輸出。