Criando modelos de dados distintos para jTables em diferentes frames internos
-
11-12-2019 - |
Pergunta
Primeiro, deixe-me salientar que sou novo na programação de GUIs Java Desktop.Eu criei um painel da área de trabalho que pode conter vários JInternalFrames.Por enquanto, cada JinternalFrame contém os mesmos componentes GUI e um novo jInternalFrame (aqui referido como Quadro Interno) pode ser criado através de um clique no item de menu.
Os elementos em cada quadro interno são os seguintes:3 Jlabels, 3 JTextFields, um Jbutton e uma Jtable.Após renderizar o primeiro Quadro Interno, preencho os 3 campos de texto com informações e, em seguida, clico no botão e uma nova linha é adicionada à tabela.A linha contém as informações usadas para preencher os campos de texto.
Abrir um segundo Quadro Interno me dá, visualmente, a interface exata do primeiro.Eu preencho este quadro da mesma maneira, clico no botão e pronto, a tabela no segundo quadro é preenchida.
O problema surge quando volto ao quadro interno anterior.Posso digitar nos campos de texto sem problemas, mas clicar no botão para preencher a tabela faz com que a tabela no segundo quadro interno seja preenchida. Suspeito que estou compartilhando um modelo de dados, mas não tenho certeza de como criar modelos de dados distintos para jInternalFrame jTables quando a GUI de cada quadro é a mesma.
Abaixo está o código (como sou novo no desenvolvimento de Java Desktop GUI, segui um dos How-To's da Oracle para renderizar o próprio Frame interno - exemplo muito simples):
public class InternalFrames extends JFrame
implements ActionListener {
private static final long serialVersionUID = 1L;
JDesktopPane desktop;
JLabel label1;
JLabel label2;
JLabel label3;
JLabel label4;
JTextField text1;
JTextField text2;
JTextField text3;
JTable table1;
public InternalFrames(){
super("Practice Internal Frames");
int inset = 50;
Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize();
setBounds(inset,inset,screenSize.width - (inset*2),screenSize.height - (inset*2));
desktop = new JDesktopPane();
createFrame();
setContentPane(desktop);
setJMenuBar(setMenuBar());
}
protected JMenuBar setMenuBar(){
JMenuBar menuBar = new JMenuBar();
JMenu menu = new JMenu("Document");
menu.setMnemonic(KeyEvent.VK_D);
menuBar.add(menu);
JMenuItem menuItem = new JMenuItem("New");
menuItem.setMnemonic(KeyEvent.VK_N);
menuItem.setAccelerator(KeyStroke.getKeyStroke(KeyEvent.VK_D, ActionEvent.ALT_MASK));
menuItem.setActionCommand("New");
menuItem.addActionListener(this);
menu.add(menuItem);
menuItem = new JMenuItem("Quit");
menuItem.setMnemonic(KeyEvent.VK_Q);
menuItem.setAccelerator(KeyStroke.getKeyStroke(KeyEvent.VK_Q, ActionEvent.ALT_MASK));
menuItem.setActionCommand("Quit");
menuItem.addActionListener(this);
menu.add(menuItem);
return menuBar;
}
public void actionPerformed(ActionEvent e){
if ("New".equals(e.getActionCommand())){
createFrame();
} else if ("Quit".equals(e.getActionCommand())){
}
}
protected void createFrame(){
InternalFrame internalFrame = new InternalFrame();
label1 = new JLabel("Name");
label2 = new JLabel("Email Address:");
label3 = new JLabel("Mobile Number:");
label4 = new JLabel("Test Frames");
label1.setSize(100,10);
label2.setSize(100,10);
label3.setSize(100,10);
label4.setSize(200,10);
text1 = new JTextField(40);
text2 = new JTextField(40);
text3 = new JTextField(40);
internalFrame.setLayout(new MigLayout());
internalFrame.getContentPane().add(label1);
internalFrame.getContentPane().add(text1, "wrap");
internalFrame.getContentPane().add(label2);
internalFrame.getContentPane().add(text2, "wrap");
internalFrame.getContentPane().add(label3);
internalFrame.getContentPane().add(text3,"wrap");
internalFrame.getContentPane().add(label4, "span 2, wrap");
internalFrame.getContentPane().add(new JScrollPane(createTable()), "span 2 2, wrap");
internalFrame.getContentPane().add(createButton());
internalFrame.setVisible(true);
desktop.add(internalFrame);
try {
internalFrame.setSelected(true);
} catch (java.beans.PropertyVetoException pve){ }
}
protected JTable createTable(){
DefaultTableModel dModel = new DefaultTableModel();
table1 = new JTable(dModel);
dModel.addColumn("Name");
dModel.addColumn("Email Address");
dModel.addColumn("Mobile Number");
return table1;
}
protected JButton createButton(){
JButton button1 = new JButton("Add New List Member");
button1.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e)
{
//Execute when button is pressed
System.out.println("You clicked the button");
populateTable(table1);
}
});
return button1;
}
protected void populateTable(JTable theTable){
if (validateEntry() == 0)
{
ListMembers listMember = new ListMembers();
listMember.setName(text1.getText());
listMember.setEmailAddress(text2.getText());
listMember.setMobilePhone(text3.getText());
Object[] data = {listMember.getName(),listMember.getEmailAddress(),listMember.getMobilePhone()};
DefaultTableModel dm = (DefaultTableModel) table1.getModel();
dm.addRow(data);
}
}
private static void createAndShowGUI(){
JFrame.setDefaultLookAndFeelDecorated(true);
InternalFrames internalFrame = new InternalFrames();
internalFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
internalFrame.setVisible(true);
}
public static void main(String[] args) {
javax.swing.SwingUtilities.invokeLater(new Runnable() {
public void run() {
createAndShowGUI();
}
});
}
}
Qualquer ajuda seria muito apreciada.
Solução
Cada vez que você cria um novo quadro, você inicializa um único campo (table1
) com esta tabela recém-criada.E o ouvinte de cada botão criado preenche a tabela referenciada por este exclusivo table1
variável.O mesmo vale para seus campos de texto, etc.
Use apenas variáveis locais e passe-as entre métodos (por exemplo, você precisa passar a tabela que acabou de criar para o método que cria o botão, para que este botão preencha esta tabela.Ou você extrai todo o código para uma nova classe, MyInternalFrame
(escolha um nome melhor), torne a tabela, os campos de texto e os campos de instância dos botões desta nova classe e crie uma nova instância desta classe MyInternalFrame cada vez que precisar de uma nova.
Esta segunda solução parece a melhor para mim.