我正在使用jlist来显示我的数据库数据。该过程适用于从数据库获取数据并显示在 jlist 元素中。我需要通过单击事件在 jlist 元素下显示我的数据。示例:包含用户名的 jlist,一旦我单击特定用户,它应该在 jlist 元素下方显示用户的属性。
建议我,如果有办法执行此过程,或者无法在特定 jlist 元素下显示。
提前谢谢。
你要做的第一件事总是首先是JavaDocs和教程,因为它们通常而不是,有如何做到这一点的例子。
因此,您现在需要根据MouseEvent
(或Point
)对元素进行索引。有趣的是,在浏览JList
JavaDocs 时,我偶然发现了这个例子......
MouseListener mouseListener = new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
if (e.getClickCount() == 2) {
int index = list.locationToIndex(e.getPoint());
System.out.println("Double clicked on Item " + index);
}
}
};
list.addMouseListener(mouseListener);
好的,好的,我们知道JList
中元素的索引,我们可以使用 ListModel#elementAt
来获取物理元素,您可以使用它来查询数据库、查找属性,或者,如果您做得正确并将实际对象嵌入到模型中,则获取属性。
将元素动态添加到JList
/ListModel
的唯一方法是通过可变ListModel
,例如 DefaultListModel
。
话虽如此,JTable
和JTree
都是显示化合物信息的更好组件。
@Arunachalam 这是树节点包含图像的示例 通过使用 DefaultTreeCellRenderer
.
import java.awt.Component;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JScrollPane;
import javax.swing.JTree;
import javax.swing.event.TreeSelectionEvent;
import javax.swing.event.TreeSelectionListener;
import javax.swing.tree.DefaultMutableTreeNode;
import javax.swing.tree.DefaultTreeCellRenderer;
import javax.swing.tree.DefaultTreeModel;
public class DatabaseTree implements TreeSelectionListener {
JFrame frame;
DefaultTreeModel treeModel;
DefaultTreeCellRenderer cellRenderer;
JScrollPane pane;
JTree tree;
Connection connection;
PreparedStatement pst;
ResultSet rs;
List<String> databaseNode = new ArrayList<String>();
public DatabaseTree() {
// JFrame.setDefaultLookAndFeelDecorated(true);
frame = new JFrame();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
DefaultMutableTreeNode root = new DefaultMutableTreeNode();
root.setUserObject(new JLabel("Databases", new ImageIcon("/images/g.jpg"), JLabel.CENTER));
treeModel = new DefaultTreeModel(root);
try {
Class.forName("com.mysql.jdbc.Driver");
connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/ganesh", "root",
"admina");
pst = connection.prepareStatement("show databases");
rs = pst.executeQuery();
while (rs.next()) {
String text = rs.getString(1);
databaseNode.add(text);
root.add(new DefaultMutableTreeNode(new JLabel(text, new ImageIcon("/images/g.jpg"),
JLabel.CENTER)));
}
} catch (Exception e) {
e.printStackTrace();
}
tree = new JTree(treeModel);
tree.setCellRenderer(new MyTreeCellRenderer());
tree.addTreeSelectionListener(this);
tree.setRootVisible(true);
tree.expandRow(0);
pane = new JScrollPane(tree);
frame.setContentPane(pane);
frame.setVisible(true);
}
public static void main(String args[]) {
new DatabaseTree();
}
@Override
public void valueChanged(TreeSelectionEvent e) {
DefaultMutableTreeNode node = (DefaultMutableTreeNode) e.getPath().getLastPathComponent();
String text = ((JLabel) node.getUserObject()).getText();
JLabel label = null;
if (databaseNode.contains(text)) {
if (node.getChildCount() == 0) {
try {
pst = connection.prepareStatement("show tables in " + text);
rs = pst.executeQuery();
while (rs.next()) {
String data = rs.getString(1);
label = new JLabel(data);
node.add(new DefaultMutableTreeNode(label));
}
} catch (Exception ee) {
ee.printStackTrace();
}
}
}
}
class MyTreeCellRenderer extends DefaultTreeCellRenderer {
JLabel label;
@Override
public Component getTreeCellRendererComponent(JTree tree, Object value, boolean selected,
boolean expanded, boolean leaf, int row,
boolean hasFocus) {
DefaultMutableTreeNode node = (DefaultMutableTreeNode) value;
label = (JLabel) node.getUserObject();
if (selected) {
label.setBackground(backgroundSelectionColor);
label.setForeground(textSelectionColor);
} else {
label.setBackground(backgroundNonSelectionColor);
label.setForeground(textNonSelectionColor);
}
return label;
}
}
}
这是动态树的工作示例,它将数据库加载为节点,将其表加载为子节点。首先,您必须创建一个包含数据库所有节点的root
节点,然后在隐藏根节点之后,这会给您数据库列表的感觉。之后,当我们单击任何数据库节点时,它会在树中动态加载其表(注意:它仅在单击数据库节点时加载表)
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTree;
import javax.swing.event.TreeSelectionEvent;
import javax.swing.event.TreeSelectionListener;
import javax.swing.tree.DefaultMutableTreeNode;
import javax.swing.tree.DefaultTreeModel;
public class DatabaseTree implements TreeSelectionListener {
JFrame frame;
DefaultTreeModel treeModel;
DefaultTreeCellRenderer cellRenderer;
JScrollPane pane;
JTree tree;
Connection connection;
PreparedStatement pst;
ResultSet rs;
List<String> databaseNode = new ArrayList<String>();
public DatabaseTree() {
// JFrame.setDefaultLookAndFeelDecorated(true);
frame = new JFrame();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
DefaultMutableTreeNode root = new DefaultMutableTreeNode();
root.setUserObject("Database");
treeModel = new DefaultTreeModel(root);
try {
Class.forName("com.mysql.jdbc.Driver");
connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/ganesh", "root",
"admina");
pst = connection.prepareStatement("show databases");
rs = pst.executeQuery();
while (rs.next()) {
String text = rs.getString(1);
databaseNode.add(text);
root.add(new DefaultMutableTreeNode(text));
}
} catch (Exception e) {
e.printStackTrace();
}
tree = new JTree(treeModel);
tree.addTreeSelectionListener(this);
tree.setRootVisible(false);
tree.expandRow(0);
pane = new JScrollPane(tree);
frame.getContentPane().add(pane);
frame.setVisible(true);
frame.pack();
}
public static void main(String args[]) {
new DatabaseTree();
}
@Override
public void valueChanged(TreeSelectionEvent e) {
DefaultMutableTreeNode node = (DefaultMutableTreeNode) e.getPath().getLastPathComponent();
String text = (String) node.getUserObject();
if (databaseNode.contains(text)) {
if (node.getChildCount() == 0) {
try {
pst = connection.prepareStatement("show tables in " + text);
rs = pst.executeQuery();
while (rs.next()) {
String data = rs.getString(1);
node.add(new DefaultMutableTreeNode(data));
}
} catch (Exception ee) {
ee.printStackTrace();
}
}
}
}
}
更新对于树节点上的单击事件,您必须在其上添加鼠标侦听器
tree.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
TreePath treePath = tree.getPathForLocation(e.getX(), e.getY());
if (treePath != null)
String text = ((DefaultMutableTreeNode)treePath.getLastPathComponent()).getUserObject();
txtField.setText(text);
else
txtField.setText("");
}
});
}