0
Javaで新しく、GridBagLayoutで最初のGUIを生成しようとしています。以下のコードでは全画面表示ができますが、 "label_url_eingabe"と "url_eingabe"というコンポーネントは表示されません(空のウィンドウ)。ウィンドウを最小化すると表示されます。 ウィンドウサイズを特定の値に設定すると、同じ動作が発生します。したがって、コンポーネントはプログラムの最初の開始時には表示されません。Java GridBagLayoutコンポーネントがフルスクリーンで表示されない
package ofb_reader_package;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JTextField;
import java.awt.GridBagConstraints;
import java.awt.GridBagLayout;
public class OFB_Reader_GUI extends JFrame {
// Definition der GUI Komponenten
// Eingabefeld URL
JLabel label_url_eingabe;
JTextField url_eingabe;
//this.OFB_Reader_GUI();
// Eigenschaften Hauptfenster "OFB_Reader_GUI"
public OFB_Reader_GUI() {
// Eigenschaften Hauptfenster
setVisible(true);
setSize(500, 300);
setDefaultCloseOperation(EXIT_ON_CLOSE);
setLocationRelativeTo(null);
setTitle("Mark's OFB Reader");
setResizable(true);
setExtendedState(JFrame.MAXIMIZED_BOTH);
setLayout(null);
this.label_url_eingabe = new JLabel("URL:");
this.url_eingabe = new JTextField(10);
this.getContentPane().setLayout(new GridBagLayout());
GridBagConstraints c = new GridBagConstraints();
// POSITIONIERUNGEN MIT GRIDBAGLAYOUT
// URL Eingabe Label und Einghabefeld
c.fill = GridBagConstraints.HORIZONTAL;
c.gridx = 0;
c.gridy = 0;
c.ipadx = 35;
c.weightx = 1.0;
c.weighty = 1.0;
c.anchor = GridBagConstraints.NORTHWEST;
this.getContentPane().add(this.label_url_eingabe, c);
c.fill = GridBagConstraints.HORIZONTAL;
c.gridx = 1;
c.gridy = 0;
c.ipadx = 35;
c.weightx = 1.0;
c.weighty = 1.0;
c.anchor = GridBagConstraints.NORTHWEST;
add(this.url_eingabe, c);
}
}
はこれがメインです:
package ofb_reader_package;
import javax.swing.*;
public class OFB_Reader_main_class {
public static void main(String[] args){
new OFB_Reader_GUI();
new OFB_Reader_main_class();
}
}
JFrame setVisibleは、** last **メソッド呼び出しであり、最初のものではありません。 JFrameメソッドを呼び出す順序は**最も重要です**。 JFrameをパックして見えるようにする前に、Swingコンポーネントを作成してJPanelまたはJFrameに追加する必要があります。最後に、ヌルレイアウトを使用しないでください。 GUIを作成するには、[Swing layouts](https://docs.oracle.com/javase/tutorial/uiswing/layout/visual.html)を使用してください。 –