如何使用java swing在jlist中的现有元素下添加新元素



我正在使用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

话虽如此,JTableJTree都是显示化合物信息的更好组件。

@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("");
      }
    });
  }

最新更新