简化了为我的窗口启动线程的代码:
public static LiDrThread lidrThread;
public void onKeyInput(InputEvent.KeyInputEvent event){
if( lidrThread== null || !lidrThread.isAlive())
{
lidrThread= new LiDrThread();
lidrThread.start();
}
}在我的LiDrThread类中重写了run方法,它扩展了线程
private LightDrafterWindow window;
@Override
public void run() {
try {
LogHelper.info("Initializing window");
window = new LightDrafterWindow();
LogHelper.info("Setting window Visible");
window.setVisible(true); // altered since original post
} catch (Exception e) {
LogHelper.warn("Window failed to open");
e.printStackTrace();
}
}这是我的构造函数的简化代码,我的窗口扩展了JFrame:
public JPanel contentPane;
public LightDrafterWindow() {
LogHelper.info("Accessing PlayerName");
LogHelper.info("Accessing Player Capabilities");
LogHelper.info("Setting up basics of Window");
//setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // line 48
setBounds(100, 100, 450, 300);
contentPane = new JPanel();
setContentPane(contentPane);
contentPane.setLayout(null);
//PlayerInfo section -----------------------------------------------------------------------------------------------
LogHelper.info("Initializing player info panel");
contentPane.setVisible(true);
}在最后一个LogHelper之后还有更多,但这是在我的控制台中显示的:
[18:12:46] [Thread-15/INFO] [lidr]: Initializing window
[18:12:46] [Thread-15/INFO] [lidr]: Accessing PlayerName
[18:12:46] [Thread-15/INFO] [lidr]: Accessing Player Capabilities
[18:12:46] [Thread-15/INFO] [lidr]: Setting up basics of Window
[18:12:46] [Thread-15/WARN] [lidr]: Window failed to open
[18:51:14] [Thread-15/INFO] [STDERR]: [main.java.lidr.thread.LiDrThread:run:23]: java.lang.ArrayIndexOutOfBoundsException: 5
[18:51:14] [Thread-15/INFO] [STDERR]: [main.java.lidr.thread.LiDrThread:run:23]: at net.minecraftforge.fml.relauncher.FMLSecurityManager.checkPermission(FMLSecurityManager.java:21)
[18:51:14] [Thread-15/INFO] [STDERR]: [main.java.lidr.thread.LiDrThread:run:23]: at java.lang.SecurityManager.checkExit(Unknown Source)
[18:51:14] [Thread-15/INFO] [STDERR]: [main.java.lidr.thread.LiDrThread:run:23]: at javax.swing.JFrame.setDefaultCloseOperation(Unknown Source)
[18:51:14] [Thread-15/INFO] [STDERR]: [main.java.lidr.thread.LiDrThread:run:23]: at main.java.lidr.thread.LightDrafterWindow.<init>(LightDrafterWindow.java:48)
[18:51:14] [Thread-15/INFO] [STDERR]: [main.java.lidr.thread.LiDrThread:run:23]: at main.java.lidr.thread.LiDrThread.run(LiDrThread.java:18)在这一点上,我不确定可能出了什么问题。它似乎在生成的代码上失败了,我对Gui的了解还不够多,看不出有什么问题。
如果你想看更多的代码,我在github上有这个项目
编辑-注释掉导致此错误的行后,其他任何内容都不会导致错误,但是jframe仍然不显示。更新代码以反映更改。
发布于 2016-03-16 10:10:53
问题来自于Forge代码内部。里面有阻止任何类调用系统出口的代码。
解决方案是使用DISPOSE_ON_CLOSE。
发布于 2016-03-16 08:27:44
您必须将面板添加到JFrame,然后将其设置为可见。如果没有Frame,您将看不到GUI。在结尾处添加这些行。
yourframe.add(contentPane);
yourframe.setvisible(true)
yourframe.pack();https://stackoverflow.com/questions/36024290
复制相似问题