!53 feature-I7X1L7增加设置按钮和增加设置页面,修改UI代码结构

Merge pull request !53 from Luke/I7X1L7
This commit is contained in:
Luke 2023-08-30 03:41:11 +00:00 committed by Gitee
commit c3b78c9ebd
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
2 changed files with 64 additions and 56 deletions

View File

@ -31,7 +31,7 @@ public class SetBtn implements EventHandler<ActionEvent> {
*/
@Override
public void handle(ActionEvent event) {
SetStage.getInstance();
SetStage.getInstance().openSetStage();
}

View File

@ -1,96 +1,104 @@
package org.jcnc.jnotepad.ui.setStage;
import javafx.geometry.Insets;
import javafx.scene.Scene;
import javafx.scene.control.*;
import javafx.scene.layout.GridPane;
import javafx.scene.layout.HBox;
import javafx.scene.control.Label;
import javafx.scene.control.ListView;
import javafx.scene.control.SplitPane;
import javafx.scene.layout.StackPane;
import javafx.scene.control.TitledPane;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
/**
* 设置窗口管理类实现了单例模式
*
* @author 许轲
*/
public class SetStage {
// 唯一的 SetStage 实例使用单例模式
private static final SetStage SET_STAGE = new SetStage();
private StackPane contentDisplay; // Declare contentDisplay as a class member
private StackPane contentDisplay;
private ListView<String> generalListView;
private ListView<String> appearanceListView;
private ListView<String> securityListView;
/**
* 获取 SetStage 的唯一实例
*
* @return SetStage 的实例
*/
public static SetStage getInstance() {
return SET_STAGE;
}
private SetStage() {
openSetStage(new Stage());
// 私有构造方法以实现单例模式
}
public void openSetStage(Stage setStage) {
/**
* 打开设置窗口
*/
public void openSetStage() {
// 创建一个用于显示内容的 StackPane并初始化为默认显示的标签
contentDisplay = new StackPane(new Label("从左侧选择设置以显示内容"));
// 创建 TitledPane 组件
TitledPane generalPane = new TitledPane("常规设置", createListView("常规设置项1", "常规设置项2"));
TitledPane appearancePane = new TitledPane("外观设置", createListView("外观设置项1", "外观设置项2"));
TitledPane securityPane = new TitledPane("安全设置", createListView("安全设置项1", "安全设置项2"));
// 创建不同设置类别的 ListView并初始化设置项
generalListView = createListView("常规设置项1", "常规设置项2");
appearanceListView = createListView("外观设置项1", "外观设置项2");
securityListView = createListView("安全设置项1", "安全设置项2");
generalPane.setOnMouseClicked(event -> {
ListView<String> listView = (ListView<String>) generalPane.getContent();
if (listView.getSelectionModel().getSelectedItem() != null) {
contentDisplay.getChildren().setAll(new Label(listView.getSelectionModel().getSelectedItem() + " 的设置内容"));
}
});
// 创建 TitledPanes每个面板包含一个标题和对应的设置列表
TitledPane generalPane = new TitledPane("常规设置", generalListView);
TitledPane appearancePane = new TitledPane("外观设置", appearanceListView);
TitledPane securityPane = new TitledPane("安全设置", securityListView);
appearancePane.setOnMouseClicked(event -> {
ListView<String> listView = (ListView<String>) appearancePane.getContent();
if (listView.getSelectionModel().getSelectedItem() != null) {
contentDisplay.getChildren().setAll(new Label(listView.getSelectionModel().getSelectedItem() + " 的设置内容"));
}
});
// TitledPanes 添加点击事件监听器用于更新内容显示区域
generalPane.setOnMouseClicked(event -> updateContentDisplay(generalListView));
appearancePane.setOnMouseClicked(event -> updateContentDisplay(appearanceListView));
securityPane.setOnMouseClicked(event -> updateContentDisplay(securityListView));
securityPane.setOnMouseClicked(event -> {
ListView<String> listView = (ListView<String>) securityPane.getContent();
if (listView.getSelectionModel().getSelectedItem() != null) {
contentDisplay.getChildren().setAll(new Label(listView.getSelectionModel().getSelectedItem() + " 的设置内容"));
}
});
// 创建一个 VBox 来容纳 TitledPanes
// 创建一个垂直布局容器 TitledPanes 放入其中
VBox titledPaneContainer = new VBox(10);
titledPaneContainer.getChildren().addAll(generalPane, appearancePane, securityPane);
// 创建一个占位符用于显示右侧内容区域
StackPane contentDisplay = new StackPane(new Label("从左侧选择设置以显示内容"));
// 设置 TitledPanes 的点击事件监听器
generalPane.setOnMouseClicked(event -> contentDisplay.getChildren().setAll(new Label("常规设置内容")));
appearancePane.setOnMouseClicked(event -> contentDisplay.getChildren().setAll(new Label("外观设置内容")));
securityPane.setOnMouseClicked(event -> contentDisplay.getChildren().setAll(new Label("安全设置内容")));
// 创建一个水平分割面板来容纳整个布局
// 创建一个分割面板左侧是设置列表右侧是内容显示区域
SplitPane splitPane = new SplitPane(titledPaneContainer, contentDisplay);
splitPane.setDividerPositions(0.3); // 设置分隔条位置
splitPane.setDividerPositions(0.3); // 设置分割位置
// 创建场景
// 创建设置窗口的场景
Scene scene = new Scene(splitPane, 800, 600);
// 设置场景并显示窗口
// 创建设置窗口的 Stage并设置标题和场景
Stage setStage = new Stage();
setStage.setScene(scene);
setStage.setTitle("设置窗口");
setStage.show();
setStage.show(); // 显示设置窗口
}
/**
* 创建一个 ListView 并初始化项
*
* @param items 要添加到 ListView 的项
* @return 初始化后的 ListView
*/
private ListView<String> createListView(String... items) {
ListView<String> listView = new ListView<>();
listView.getItems().addAll(items);
listView.setOnMouseClicked(event -> {
String selectedItem = listView.getSelectionModel().getSelectedItem();
if (selectedItem != null) {
contentDisplay.getChildren().setAll(new Label(selectedItem + " 的设置内容"));
}
});
return listView;
}
/**
* 更新内容显示区域根据选定的列表项显示相应的设置内容
*
* @param listView 选定项所属的 ListView
*/
private void updateContentDisplay(ListView<String> listView) {
String selectedItem = listView.getSelectionModel().getSelectedItem();
if (selectedItem != null) {
// 更新内容显示区域为选定项的设置内容标签
contentDisplay.getChildren().setAll(new Label(selectedItem + " 的设置内容"));
}
}
}