- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的数据库中有 1 个表
TableRoom
- NoRoom
- Status
我有
room
101,
102,
103,
104,
105,
201,
202,
203,
204,
205
我的问题是如何调用数据库并指定按钮的颜色。如果房间状态已满,按钮应为红色,如果房间状态为空,按钮应为绿色
这个我的代码
JButton [] arr = new JButton[10];
.........
if(r.next()){
status = r.getString("status");
noRoom = r.getString("noRoom");
for(int i=0; i<10; i++){
if (arr[i].getActionCommand().equals(noRoom)){
r.beforeFirst();
while(r.next()){
arr[i].setBackground(Color.red);
}
s.close();
c.close();
} else {
arr[i].setBackground(Color.green);
}
}
}
最佳答案
首先创建 Room
的 POJO...类似...
public class Room {
private final int roomNumber;
private final boolean status;
public Room(int roomNumber, boolean status) {
this.roomNumber = roomNumber;
this.status = status;
}
public int getRoomNumber() {
return roomNumber;
}
public boolean isOccupied() {
return status;
}
@Override
public int hashCode() {
int hash = 7;
hash = 89 * hash + this.roomNumber;
return hash;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
final Room other = (Room) obj;
if (this.roomNumber != other.roomNumber) {
return false;
}
return true;
}
}
例如。这允许您将与单个房间相关的所有信息包含到一个类中。此外,通过使用
equals
和
hashcode
,我们不需要跟踪每个
Room
对象的单个实例,但可以有多个实例,但它们等同于同一件事,这在你之后会更有意义......
创建一个“通用”实用方法来加载房间
protected List<Room> getRooms() throws SQLException {
Connection con = null;
List<Room> rooms = new ArrayList<>(25);
try (PreparedStatement stmt = con.prepareStatement("select * from TableRoom")) {
try (ResultSet rs = stmt.executeQuery()) {
while (rs.next()) {
Room room = new Room(rs.getInt("NoRoom"), rs.getBoolean("Status"));
rooms.add(room);
}
}
}
return rooms;
}
这一切所做的就是查询数据库,将数据加载到一系列 Room
中并返回一个 List
,很好。现在,当您想要检查数据库时,只需调用此方法即可获取 Room
的 List
接下来,您需要某种方式来链接房间
及其按钮,一个简单的 map
就足够了......
private Map<Room, JButton> buttons;
接下来,您需要初始化这些值...
buttons = new HashMap<>(25);
try {
List<Room> rooms = getRooms();
for (Room room : rooms) {
JButton btn = new JButton(Integer.toString(room.getRoomNumber()));
buttons.put(room, btn);
updateRoomStatus(room);
// Add button to UI as required
}
} catch (SQLException exp) {
exp.printStackTrace();
}
现在,当您想要更新按钮的状态时,您只需执行以下操作...
try {
List<Room> rooms = getRooms();
for (Room room : rooms) {
updateRoomStatus(room);
}
} catch (SQLException exp) {
exp.printStackTrace();
}
最后,您需要一个简单的实用方法,当提供 Room
时,该方法可以更新关联按钮的状态,例如...
protected void updateRoomStatus(Room room) {
JButton btn = buttons.get(room);
if (btn != null) {
if (room.isOccupied()) {
btn.setBackground(Color.RED);
} else {
btn.setBackground(Color.GREEN);
}
}
}
现在,这是一个非常简单的示例,更复杂的示例将让您维护 Room
的单个实例并根据数据库中的数据更新它。这意味着,如果您要更改任何给定 Room
的状态,该更改将反射(reflect)在您对该 Room
的所有引用中。
此外,这假设房间数量在初始化数据和更新数据之间不会发生变化,这似乎有道理,但值得指出。
看看JDBC Database Access和 Collections Trail了解更多详情
关于java - 如何从数据库获取值并为多个 JButton 设置颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32580120/
本质上,我编写的是一个益智游戏。 它包含一个图像,该图像进一步分为 9 block ,放置在包含 3x3 JButton GridLayout 的 JPanel 上。最初,9 个按钮是空的。当用户点击
我正在制作一个游戏,其中有一个名为 move(int x1, int y1, int x2, int y2) 的方法,该方法将棋子从第一个按钮 (x1,y1) 移动并将其放置在第二个按钮 (x2, y
我使用 NetBeans 创建了一个框架。该框架有两个按钮 A 和 B。按钮 A 最初被禁用。仅当单击按钮 B 时才启用。 public newFrame() { //newFrame is t
我想使用 MouseListener 从按钮矩阵中删除某个按钮,并在空白处添加 JLabel,所以我使用: import java.awt.*; import java.awt.event.*; im
我正在创建一个黑白棋游戏,想知道如何在单击时将按钮文本从 B 更改为 W,反之亦然。 我尝试将 Action 监听器添加到我的 forloop 中,这为游戏创建了我的板,当我单击标记为 W 的按钮时,
我的项目中有 7 个按钮。其中有 6 个类别,RandomSoru 按钮是随机选择其中一个类别的按钮。我想访问所选类别。 “r”是随机生成器。 RandomSoru.addActionListener
我对此感到好奇,因为我们正在 Swing 中制作游戏,并且出于某种原因将 map 图 block 制作为 jButtons 而不是 jPanels。现在我们想将单位放在它们上面,这样当单位位于它们上面
我创建了一个按钮数组: JButton bt[][]=new JButton[8][8]; 然后我通过以下方式调用一个名为 refreshBoard 的函数 public void refreshBo
我想在这篇文章的序言中告诉大家,这是我第一次发帖,所以如果有任何错误,请告诉我。 我正在尝试为我的高中计算机数学(编程)课编写一款二十一点游戏,但出现了很多错误,但真正令人烦恼的是这个错误。 我的 G
我正在创建一个“谁想成为百万富翁”游戏,并创建了一个半按钮,我想使用它来删除两个 JButton 答案。以下是两个作为答案选项的 JButton 的代码。 enter code here: Answe
我有一个 JButton,我想在按下它时创建一个新的 JButton,我添加了一个如下所示的 ActionListener,但它没有添加另一个 JButton。 public void actionP
如果在 JTextBox 中输入字符串,然后按“输入按钮”,它会在 JTextField 中返回正确的数据,如果我更改字符串,然后重新按输入,也会返回正确的数据。如果我按“输入按钮”然后按“添加”按钮
我想在单击另一个 jbutton 时获得一个 jbutton。 Here the link for sample code(Log in as jbutton,asdf as a password)
假设我创建了一个带有 jbuttons 的 2d tile map ,然后在 map 顶部创建了单位,当单位(也是一个 jbutton)位于 tile 顶部时,有没有办法显示 map 的背景,因为如何
我正在开发一个项目,我需要单击一个按钮来创建另一个按钮。最终,我希望对新按钮的位置有更多的控制,并能够多次创建新按钮,但现在......我希望只让一个 JButton 创建另一个 JButton。 使
JPanel 中有 12 个 JButton。我想单击其中一个并禁用所有其他(它将“突出显示”)。然后,如果我单击禁用的一个,则前一个将被禁用,并且过程是相同的。考虑到有 12 个按钮并且我想避免重复
我正忙于用 Java 制作游戏。然而,我正在努力让 GUI 正常工作。 我遇到的问题: 当按下按钮时,我希望它显示一个彩色圆圈,当再次按下按钮时,我希望它在旧圆圈周围画一个圆圈,这可能会发生,直到每个
大家好,我正在尝试使用 Java 创建一个简单的国际象棋游戏。我有一个 [8][8] 数组的 JButton 板。我为每个分配一个新的 SquareListener,它是一个扩展 BoardListn
我有 JButtons“暂停”和“取消暂停”。当用户暂停程序时,应禁用“暂停”按钮,并启用“取消暂停”按钮。我不知道怎么写。取消暂停按钮有效,但暂停按钮不起作用,因为“无法解决取消暂停”。怎么处理呢?
我设置了一个网格布局,中间有 16 个按钮。我在第一个按钮上放置了一个图标。 我将如何循环,当用户选择网格上的下一个按钮时,它将图标从旧位置 move 到新位置? private ArrayList
我是一名优秀的程序员,十分优秀!