首先,使用 Java Swing 来实现 GUI 界面。对于场地表格,使用 JTable 组件来实现,该组件可以展示二维表格数据。将场地设置为表格的行,时间设置为表格的列,然后在表格中显示预约情况。对于室内室外选择按钮,使用 JRadioButton 组件来实现,根据用户的选择来过滤场地表格的数据。对于日期代码,使用 JCalendar 组件来实现,该组件可以让用户选择日期。 预约按钮和取消预约按钮可以使用 JButton 组件来实现,当用户点击预约按钮时,需要检查当前选择的场地和时间是否已经被预约,如果没有被预约,则将预约信息添加到场地表格中。当用户点击取消预约按钮时,检查当前选择的场地和时间是否已经被预约,如果已经被预约,则将预约信息从场地表格中删除的代码

时间: 2024-03-29 07:35:35 浏览: 12
也可以使用 JavaFX 来实现 GUI 界面,使用 TableView 组件来展示场地表格,使用 DatePicker 组件来实现日期选择,使用 ToggleButton 组件来实现室内室外选择,使用 Button 组件来实现预约和取消预约功能。对于预约和取消预约功能,可以使用模态对话框来提示用户操作结果。代码实现可以参考以下示例: ```java public class ReservationSystem extends Application { private TableView<Reservation> tableView; private DatePicker datePicker; private ToggleButton indoorButton; private ToggleButton outdoorButton; @Override public void start(Stage primaryStage) { // 初始化 GUI 组件 tableView = new TableView<>(); datePicker = new DatePicker(); indoorButton = new ToggleButton("室内"); outdoorButton = new ToggleButton("室外"); Button reserveButton = new Button("预约"); Button cancelButton = new Button("取消预约"); // 初始化表格列 TableColumn<Reservation, String> venueColumn = new TableColumn<>("场地"); venueColumn.setCellValueFactory(new PropertyValueFactory<>("venue")); TableColumn<Reservation, String> timeColumn = new TableColumn<>("时间"); timeColumn.setCellValueFactory(new PropertyValueFactory<>("time")); tableView.getColumns().addAll(venueColumn, timeColumn); // 初始化场地数据 ObservableList<Reservation> data = FXCollections.observableArrayList( new Reservation("室内1", "2022-01-01 09:00"), new Reservation("室内1", "2022-01-01 10:00"), new Reservation("室外1", "2022-01-01 09:00"), new Reservation("室外1", "2022-01-01 10:00") ); tableView.setItems(data); // 设置选择日期的监听器 datePicker.setOnAction(event -> { LocalDate date = datePicker.getValue(); // 根据选择的日期过滤表格数据 tableView.setItems(filterDataByDate(data, date)); }); // 设置选择室内室外的监听器 ToggleGroup toggleGroup = new ToggleGroup(); indoorButton.setToggleGroup(toggleGroup); outdoorButton.setToggleGroup(toggleGroup); toggleGroup.selectedToggleProperty().addListener((observable, oldValue, newValue) -> { // 根据选择的室内室外过滤表格数据 tableView.setItems(filterDataByVenue(data, newValue == indoorButton ? "室内" : "室外")); }); // 设置预约按钮的监听器 reserveButton.setOnAction(event -> { // 获取当前选择的场地和时间 String venue = tableView.getSelectionModel().getSelectedItem().getVenue(); String time = tableView.getSelectionModel().getSelectedItem().getTime(); // 检查是否已经被预约 if (!isReserved(data, venue, time)) { // 添加预约信息到表格中 data.add(new Reservation(venue, time)); // 更新表格视图 tableView.setItems(data); // 提示预约成功 Alert alert = new Alert(Alert.AlertType.INFORMATION, "预约成功!"); alert.showAndWait(); } else { // 提示已经被预约 Alert alert = new Alert(Alert.AlertType.WARNING, "该场地和时间已经被预约!"); alert.showAndWait(); } }); // 设置取消预约按钮的监听器 cancelButton.setOnAction(event -> { // 获取当前选择的场地和时间 String venue = tableView.getSelectionModel().getSelectedItem().getVenue(); String time = tableView.getSelectionModel().getSelectedItem().getTime(); // 检查是否已经被预约 if (isReserved(data, venue, time)) { // 删除预约信息从表格中 data.removeIf(reservation -> reservation.getVenue().equals(venue) && reservation.getTime().equals(time)); // 更新表格视图 tableView.setItems(data); // 提示取消预约成功 Alert alert = new Alert(Alert.AlertType.INFORMATION, "取消预约成功!"); alert.showAndWait(); } else { // 提示该场地和时间没有预约 Alert alert = new Alert(Alert.AlertType.WARNING, "该场地和时间没有预约!"); alert.showAndWait(); } }); // 初始化布局 VBox vbox = new VBox(); vbox.getChildren().addAll(datePicker, indoorButton, outdoorButton, tableView, reserveButton, cancelButton); Scene scene = new Scene(vbox); primaryStage.setScene(scene); primaryStage.show(); } // 过滤表格数据,只显示选择日期的预约情况 private ObservableList<Reservation> filterDataByDate(ObservableList<Reservation> data, LocalDate date) { return data.filtered(reservation -> reservation.getTime().startsWith(date.toString())); } // 过滤表格数据,只显示选择室内室外的预约情况 private ObservableList<Reservation> filterDataByVenue(ObservableList<Reservation> data, String venue) { return data.filtered(reservation -> reservation.getVenue().equals(venue)); } // 检查场地和时间是否已经被预约 private boolean isReserved(ObservableList<Reservation> data, String venue, String time) { return data.stream().anyMatch(reservation -> reservation.getVenue().equals(venue) && reservation.getTime().equals(time)); } public static void main(String[] args) { launch(args); } } // 预约信息类 class Reservation { private String venue; private String time; public Reservation(String venue, String time) { this.venue = venue; this.time = time; } public String getVenue() { return venue; } public void setVenue(String venue) { this.venue = venue; } public String getTime() { return time; } public void setTime(String time) { this.time = time; } } ```

相关推荐

最新推荐

recommend-type

Java Swing组件编程之JTable表格用法实例详解

主要介绍了Java Swing组件编程之JTable表格用法,结合实例形式详细分析了Swing组件中JTable表格的常见定义与使用方法,需要的朋友可以参考下
recommend-type

Java Swing 表格组件

表格也是 GUI 中常用的组件,它是一个由多行、多列组成的二维显示区。Swing 的 JTable 以及相关类提供了对表格的支持。使用 JTable 以及相关类,可以创建功能丰富的表格,还可以为表格定义各种显示外观和编辑特性; ...
recommend-type

Java将数据库的数据展示到JTable表格中

Mysql数据库内容展示写死版 import javax.swing.*; import java.awt.*; import java.sql.*; public class XieSiBan extends JFrame { public static void main(String[] args) { try { // 加载MySql驱动 Class....
recommend-type

Java Swing实现JTable检测单元格数据变更事件的方法示例

主要介绍了Java Swing实现JTable检测单元格数据变更事件的方法,结合完整实例形式分析了Swing实现JTable检测单元格数据变更事件过程中出现的问题与相关解决方法,需要的朋友可以参考下
recommend-type

基于JTable的列宽与内容自适应的实现方法

本篇文章是对JTable的列宽与内容自适应的实现方法进行了详细的分析介绍,需要的朋友参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

云原生架构与soa架构区别?

云原生架构和SOA架构是两种不同的架构模式,主要有以下区别: 1. 设计理念不同: 云原生架构的设计理念是“设计为云”,注重应用程序的可移植性、可伸缩性、弹性和高可用性等特点。而SOA架构的设计理念是“面向服务”,注重实现业务逻辑的解耦和复用,提高系统的灵活性和可维护性。 2. 技术实现不同: 云原生架构的实现技术包括Docker、Kubernetes、Service Mesh等,注重容器化、自动化、微服务等技术。而SOA架构的实现技术包括Web Services、消息队列等,注重服务化、异步通信等技术。 3. 应用场景不同: 云原生架构适用于云计算环境下的应用场景,如容器化部署、微服务
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。