我试图按特定顺序制作一个简单的两列视图。
它应该是这样的:
顶行中有两个静态标题,每个
下面每列有5个面板然而,我得到的结果是左边的空白表格,右边的所有细节都是水平排列的。问题是细节是从互联网上实时加载并每8秒刷新一次,所以我需要在数据刷新时更新每个单独的单元格(这就是为什么我没有使用GridLayout
)
代码无限循环(不断提出最新数据直到退出)
我无法事先初始化所有JPanels
,因为从网上获取每个数据点至少需要6秒。
import NeuralNet.NeuralNet;
import javax.swing.*;
import java.awt.*;
public class MWindow {
public MWindow(String[] c){
JFrame mainFr = new JFrame("Current Predictions");
mainFr.setSize(800, 800);
mainFr.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
mainFr.setVisible(true);
JPanel p = new JPanel(new GridBagLayout());
GridBagConstraints cns = new GridBagConstraints();
cns.fill = GridBagConstraints.HORIZONTAL;
cns.insets = new Insets(5,5,15,15);
mainFr.add(p);
JTextArea man = new JTextArea("MANUFACTURING 5");
cns.gridx = 0;
cns.gridy = 0;
cns.weightx = 1.0;
cns.weighty = 1.0;
cns.fill = GridBagConstraints.BOTH;
p.add(man, cns);
JTextArea inter = new JTextArea("INTERNET 5");
cns.gridx = 1;
cns.gridy = 0;
cns.weightx = 1.0;
cns.weighty = 1.0;
cns.fill = GridBagConstraints.BOTH;
p.add(inter, cns);
JPanel aapl = new JPanel();
JPanel msft = new JPanel();
JPanel intc = new JPanel();
JPanel ibm = new JPanel();
JPanel tsla = new JPanel();
JPanel fb = new JPanel();
JPanel goog = new JPanel();
JPanel yhoo = new JPanel();
JPanel twtr = new JPanel();
JPanel amzn = new JPanel();
p.setBackground(Color.white);
mainFr.setBackground(Color.white);
while (true) {
for (String cmp : c) {
JPanel stkPanel = new JPanel();
stkPanel.setBackground(Color.white);
if (!(cmp.equals("INTER5") || cmp.equals("MANU5") || cmp.equals("ALL"))) {
Asset a = new Asset(cmp);
NeuralNet n = Functions.loadNN(cmp);
NeuralNet nA = Functions.loadNN("ALL");
NeuralNet n5;
if (cmp.equals("MSFT") || cmp.equals("AAPL") || cmp.equals("INTC") || cmp.equals("IBM") || cmp.equals("TSLA")) {
n5 = Functions.loadNN("MANU5");
} else if (cmp.equals("TWTR") || cmp.equals("YHOO") || cmp.equals("GOOG") || cmp.equals("FB") || cmp.equals("AMZN")) {
n5 = Functions.loadNN("INTER5");
} else {
System.out.println("ERROR");
n5 = n;
}
double pred = n.PredictRows(Functions.formatData(a));
double pred5 = n5.PredictRows(Functions.formatData(a));
double predA = nA.PredictRows(Functions.formatData(a));
JTextArea stkPred = new JTextArea();
stkPred.setText("Stock: " + cmp +
"\nCurrent Price: " + "$" + a.getCurrPrice().toString() +
"\nPrediction 1: " + Double.toString(pred) +
"\nPrediction 2: " + Double.toString(pred5) +
"\nPrediction 3: " + Double.toString(predA));
stkPred.setFont(new Font("Helvetica", Font.BOLD, 15));
int pr = Functions.calcBS(pred, pred5, predA);
JTextArea act = new JTextArea();
if (pr == -1) {
act.setText("SELL");
act.setForeground(Color.red);
} else if (pr == 1) {
act.setText("BUY");
act.setForeground(Color.green);
} else {
act.setText("HOLD");
act.setForeground(Color.orange);
}
act.setFont(new Font("Helvetica", Font.BOLD, 15));
stkPanel.add(stkPred);
stkPanel.add(act);
switch (cmp) {
case "MSFT":
msft.removeAll();
msft.add(stkPanel);
msft.revalidate();
msft.repaint();
cns.gridx = 0;
cns.gridy = 2;
cns.weightx = 1.0;
cns.weighty = 1.0;
cns.fill = GridBagConstraints.BOTH;
p.add(msft, cns);
case "AAPL":
aapl.removeAll();
aapl.add(stkPanel);
aapl.revalidate();
aapl.repaint();
cns.gridx = 0;
cns.gridy = 1;
cns.weightx = 1.0;
cns.weighty = 1.0;
cns.fill = GridBagConstraints.BOTH;
p.add(aapl, cns);
case "INTC":
intc.removeAll();
intc.add(stkPanel);
intc.revalidate();
intc.repaint();
cns.gridx = 0;
cns.gridy = 3;
p.add(intc, cns);
case "IBM":
ibm.removeAll();
ibm.add(stkPanel);
ibm.revalidate();
ibm.repaint();
cns.gridx = 0;
cns.gridy = 4;
p.add(ibm, cns);
case "TSLA":
tsla.removeAll();
tsla.add(stkPanel);
tsla.revalidate();
tsla.repaint();
cns.gridx = 0;
cns.gridy = 5;
p.add(tsla, cns);
case "TWTR":
twtr.removeAll();
twtr.add(stkPanel);
twtr.revalidate();
twtr.repaint();
cns.gridx = 1;
cns.gridy = 4;
p.add(twtr, cns);
case "FB":
fb.removeAll();
fb.add(stkPanel);
fb.revalidate();
fb.repaint();
cns.gridx = 1;
cns.gridy = 1;
p.add(fb, cns);
case "AMZN":
amzn.removeAll();
amzn.add(stkPanel);
amzn.revalidate();
amzn.repaint();
cns.gridx = 1;
cns.gridy = 5;
p.add(amzn, cns);
case "GOOG":
goog.removeAll();
goog.add(stkPanel);
goog.revalidate();
goog.repaint();
cns.gridx = 1;
cns.gridy = 2;
p.add(goog, cns);
case "YHOO":
yhoo.removeAll();
yhoo.add(stkPanel);
yhoo.revalidate();
yhoo.repaint();
cns.gridx = 1;
cns.gridy = 3;
p.add(yhoo, cns);
}
p.add(stkPanel);
p.revalidate();
}
}
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
答案 0 :(得分:3)
首先,我强烈建议您查看Concurrency in Swing,因为您违反了Swing的单线程特性。
我建议您查看Worker Threads and SwingWorker以获得可能的解决方案。
你的代码中有很多东西,很多东西都被添加,删除和创建,这简直令人困惑。
您通常更新的信息不是动态的,数据是,但它呈现的方式不是。
所以,我建议做的是,创建一个自定义类,它封装你想要显示的信息,这就成了模型,然后创建一个自定义类,它可以以你想要的格式显示信息。 / p>
然后我会创建许多这些组件并以任何你想要的方式将它们放在容器中,也许使用Map
来绑定它们(这样你就可以查找给定数据源的组件了。变化)。
然后,我会简单地将数据/模型传递给适当的组件,它可以更改显示。
根据我从代码中可以看出的内容,JTable
可能会出现问题,以及一系列JLabel
s / JTextField
,这使得更新更容易用户界面来自。
它还可以更轻松地添加/删除数据源