Nachträglich Swing-Elemente in JFrame erzeugen

Status
Nicht offen für weitere Antworten.

skummy

Aktives Mitglied
Hallo Forum,


im Moment erzeuge ich meine GUI-Fenster komfortabel über den Netbeans-GUI-Builder. Jedoch habe ich noch keine Möglichkeit gefunden, wie ich nachträglich irgendwelche Labels, Buttons usw. auf den JFrame erzeugen kann, wenn bestimmte Benutzeraktionen (Klick auf Button) ausgeführt werden.

Ist das irgendwie möglich? Ansonsten würde Netbeans einen ja da schon ganz schön einschränken...!


Danke und Tschau
 

Marco13

Top Contributor
Kommt drauf an. Eigentlich ist das ganz einfach:
Code:
class SomeFrame extends JFrame
{
    void init()
    {
        getContentPane().setLayout(new GridLayout(0,1));
        getContentPane().add(new JLabel("Hallo"));
    }

    // Später
    void addSomething()
    {
        getContentPane().add(new JLabel("Welt"));
        validate();
    }
}

Allerdings neigen solche GUI-Builder dazu, Code zu generieren, den man kaum noch verstehen kann und will. Es KÖNNTE also schwierig werden, die Stelle zu finden, wo man da was einfügen kann...
 

skummy

Aktives Mitglied
Hmmm...also für ein einfaches JFrame erzeugt Netbeans beispielsweise folgenden Code:

Code:
    private void initComponents() {

        setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);

        javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
        getContentPane().setLayout(layout);
        layout.setHorizontalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGap(0, 400, Short.MAX_VALUE)
        );
        layout.setVerticalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGap(0, 300, Short.MAX_VALUE)
        );

        pack();
    }

Wenn ich dann sowas machen will (Keine Ahnung wo das validate() hinkommt. Funktionieren tuts bei beiden nicht.):

Code:
    public static void main(String args[]) {
        java.awt.EventQueue.invokeLater(new Runnable() {
            public void run() {
               JButton jButton1 = new JButton("Hallo");
               FrameDlg dlg = new FrameDlg();    
               dlg.getContentPane().add(jButton1);
                                
               dlg.validate();
               dlg.setVisible(true);
               dlg.validate();
                
            }
        });
    }

wird kein Button erzeugt.

Eigentlich müsstes es doch aber auf diese Weise funktionieren, oder?


Bye
Sandro
 

Marco13

Top Contributor
Ja, genau das meinte ich mit unverstehbarem Code - wenn ich sehe, das da manchmal für "GroupLayout"-Konstrukte rauskommen :autsch: In diesem Fall besonders albern, wenn in dem Frame noch nichts drin ist.... Eine Möglichkeit wäre, die Components, die man "eigentlich" in den Frame packen will, stattdessen in ein JPanel zu legen. DIESES JPanel kann man dann z.B. "von Hand" der ContentPane des Frames hinzufügen, und dort dann später z.B. einen Button drunterklemmen.... Nur mit einem "frame.getContentPane().add(button)" ist es im Moment leider nicht getan: Er muss ja wissen, WO und WIE er den Button einfügen soll...
 

skummy

Aktives Mitglied
Ohoh...irgendwie hab ich deinen letzten Post nicht richtig verstanden.

Du meinst, die "festen" Elemente auf ein JPanel packen? Und das was ich später hinzufügen will...halt irgendwie anders.

Bin ich denn der einzigste, der bis jetzt sowas machen wollte? Irgendwie kann ich mir das nicht vorstellen, dass das, was ich vorhabe, so kompliziert ist...! Oder macht man sowas grundsätzlich gar nicht?
 

Marco13

Top Contributor
Naja - das ist eben einer der Gründe, warum manche Leute (ich) auf solche GUI-Builder verzichten: Man legt ein, zwei Buttons in einen Frame, und was rauskommt, sind 20 Zeilen Code mit ineinander geschachtelten GroupLayout-Aufrufen, die keiner mehr versteht, und keiner mehr vernünftig ändern kann - und WENN man was ändert, muss man damit rechnen, dass der GUI-Builder es nachher nicht mehr versteht, oder schlicht und einfach mit den überschreibt, was er kennt.

Wie auch immer: Bisher hattest du sowas wie
Code:
    private void initComponents() {

        setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);

        javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane()); //-------- getContentPane()!!!
        getContentPane().setLayout(layout);
        layout.setHorizontalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGap(0, 400, Short.MAX_VALUE)
        );
        layout.setVerticalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGap(0, 300, Short.MAX_VALUE)
        );
        getConentPane().add(button); //-------------------------------------------------------- oder so...

        pack();
    }


Das könnte man jetzt per Hand zu sowas umbauen
Code:
    private void initComponents() {

        JPanel panel = new JPanel();
        this.getContentPane().setLayout(new BorderLayout());

        //------------- Wie vorher, aber getContentPane() ersetzt durch das panel
        setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);

        javax.swing.GroupLayout layout = new javax.swing.GroupLayout(panel); //-------- JPanel!
        getContentPane().setLayout(layout);
        layout.setHorizontalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGap(0, 400, Short.MAX_VALUE)
        );
        layout.setVerticalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGap(0, 300, Short.MAX_VALUE)
        );
        panel.add(button); //-------------------------------------------------------- oder so...
        //------------- Wie vorher, aber getContentPane() ersetzt durch das panel


        getContentPane().add(panel, BorderLayout.CENTER);
        pack();
    }

und später dann so eine Methode aufrufen wie
Code:
    private void add()
    {
        getContentPane().add(new JLabel("Label"), BorderLayout.SOUTH);
        validate();
    }






"Besser" (oder einfacher) wäre es, wenn man im GUI-Builder zuerst zwei Panels einfügt: Ins erste Panel kommt alles, was "eigentlich" in den Frame sollte. Das zweite Panel bleibt leer. Dann kann man später die neuen Components ins zweite Panel einfügen, ohne den eigentlich vom GUI-Builder gebauten Code groß verändern zu müssen....
 
G

Guest

Gast
OK, danke für deine Hilfe. Sieht so aus als müsste man sich dafür ganz schön verbiegen.

Ich hab jetzt einfach mal versucht Netbeans einen anderes Layout verwenden zu lassen. Beim Null-Layout generiert der Builder sowas:

Code:
    private void initComponents() {

        jButton1 = new javax.swing.JButton();

        setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
        setBounds(new java.awt.Rectangle(40, 0, 400, 300));
        setMinimumSize(new java.awt.Dimension(500, 500));
        getContentPane().setLayout(null);

        jButton1.setText("jButton1");
        getContentPane().add(jButton1);
        jButton1.setBounds(40, 170, 75, 23);

        pack();
    }

Sieht doch schon weit übersichtlicher aus, oder? Ich denke damit kann ich mein Problem auf einfachere Art und Weise lösen.

Stellt sich nur noch die Frage warum Netbeans ein anderes Layout verwendet, wo keiner durch den Code durchsteigt. Kennst du da eventuell Vor- und Nachteile? Besonders bezüglich Geschwindigkeit und Speichernutzung?


Tschau
Sandro
 

Lim_Dul

Top Contributor
Ein Null-Layout verwendet man nicht. Man zerhaut sich damit jegliche Anpassungsfähigkeit der Fenster ans Vergößeren/Verkleinern/Schriftgrößen etc.
 

Marco13

Top Contributor
Ja, besser wäre es, dem NetBeans zu sagen, dass er BorderLayout, GridLayout und BoxLayout verwenden soll. GroupLayout ist außerdem NetBeans-Spezifisch, d.h. du wirst den Code dann nicht ohne weiteres mit einer anderen IDE compilieren können.

Gründe, warum NetBeans das GroupLayout verwendet? Hm. Da könnte ich nur spekulieren. Das überlasse ich anderen.
 

skummy

Aktives Mitglied
Schade...und das gleiche gilt bestimmt dann auch fürs Netbeans-eigene Absolute-Layout, oder?

Schon komisch: Einfache Layouts wo jeder durchblickt sollte man nicht verwenden. Andere Layouts sind wiederrum schwer zu erlernen, womit man sich eines GUI-Builders bedient. Dieser erzeugt dann Code, den kein Mensch versteht... :shock:

Auch im Internet habe ich kein tolles Swing-GUI-Tutorial gesehen, dass einfach erklärt, wie man auch "komplizierte" Benutzeroberflächen erstellen und vor allen Dingen auch komfortabel pflegen kann.


Tschau
Sandro
 
G

Gast

Gast
Ein "Trick", den ich manchmal verwende, ist:

Die Buttons, die du später hinzufügen willst, einfach schon von Anfang an in die GUI mit dem Builder einfügen und fertig platzieren.

Während der Initialisierung einfach .setVisible(false) nutzen und sie erst dann sichtbar machen, wenn du sie haben möchtest.

Ein Haken an der Sache ist natürlich, dass du vorher schon wissen musst wieviele es sind, wohin sie kommen usw.
 

Marco13

Top Contributor
Complicator's gloves - man könnte postulieren, dass solche GUI-Designer einfach nicht für sich verändernde GUIs gedacht sind.... Naja.
 

GambaJo

Mitglied
Ehrlich gesagt, bin ich auch mit den Möglichkeiten, die man zum GUI-Erstellen so hat, egal ob NB oder Eclipse, nicht sonderlich zufrieden.

Netbeans bietet einen GUI-Builder, der aber nicht immer so funktioniert, wie man sich das wünscht. Die Ergebnisse in der Entwicklung sehen oft anders aus, als wenn man die Applikation ausführt. Es gibt auch oft Unterschiede innerhalb der selben Applikation zwischen den Betriebssystemen (bei gleichem L&F). Die Layouts können einen in den Wahnsinn treiben.

Eclipse läuft bei mir nicht so richtig stabil. Den Visual Editor konnte ich bisher nicht erfolgreich installieren, immer fehlt irgendwas. Und alles zu Fuß machen finde ich irgendwie rückschrittlich. Mag ja sein, dass man so viel Kontrolle hat, aber ich bin mir sicher, dass der GUI-Builder besseren Code generiert, als ich, ein unerfahrener User, schreiben würde. Und bei komplexeren GUIs ist man alleine mit der GUI schon sehr lange beschäftigt, bis die mal halbwegs so ist, wie man es braucht. Nachträgliche Änderungen ziehen relativ großen Aufwand nach sich.

Aus meiner Sicht ist das alles nicht so das Gelbe vom Ei.
 

byte

Top Contributor
Lim_Dul hat gesagt.:
Ein Null-Layout verwendet man nicht. Man zerhaut sich damit jegliche Anpassungsfähigkeit der Fenster ans Vergößeren/Verkleinern/Schriftgrößen etc.
Null-Layout ist schon nützlich, wenn man das Layouting per Hand programmieren will. Die bestehenden LayoutManager decken nicht alles ab.
 
M

Michael...

Gast
byto hat gesagt.:
Lim_Dul hat gesagt.:
Ein Null-Layout verwendet man nicht. Man zerhaut sich damit jegliche Anpassungsfähigkeit der Fenster ans Vergößeren/Verkleinern/Schriftgrößen etc.
Null-Layout ist schon nützlich, wenn man das Layouting per Hand programmieren will. Die bestehenden LayoutManager decken nicht alles ab.
Ich hatte noch nie das Bedürfnis ein Null-Layout zu verwenden, halte ich persönlich auch für recht gefährlich. Wenn ich ein eigenes Layout nötige schreibe ich mir einen eigenen LayoutManager, ist normaler Weise kein grosser Aufwand. Teilweise mache ich das auch, obwohl ich mit einem GridBagLayout das gleiche erzielen könnte.
 

Lim_Dul

Top Contributor
Ich habe das Null-Layout auch schon verwendet, so ist es nicht.

Nur ist das aber bei fast jeder Regel so, dass es tatsächlich Ausnahmefälle gibt, wo man gegen sie verstossen kann. Aber man kann einem Anfänger schlecht sagen "Null-Layout verwendet man nicht, außer in Ausnahmefällen."

Erstmal muss man verstehen, warum man es nicht verwendet. Dann und frühestens dann kann man sich entscheiden es zu verwenden. Solange man das aber nicht verstanden ist, sollte man auch keine Ausnahmen machen.
 

byte

Top Contributor
Michael... hat gesagt.:
Ich hatte noch nie das Bedürfnis ein Null-Layout zu verwenden, halte ich persönlich auch für recht gefährlich. Wenn ich ein eigenes Layout nötige schreibe ich mir einen eigenen LayoutManager, ist normaler Weise kein grosser Aufwand. Teilweise mache ich das auch, obwohl ich mit einem GridBagLayout das gleiche erzielen könnte.
Was ist daran gefährlich, wenn ich einen ComponentListener registriere, der "on resize" meine Resize-Logik aufruft (die Du extra in einem Custom LayoutManager kaspelst)? Ein eigener LayoutManager macht imo nur Sinn, wenn man ihn an mehreren Stellen wiederverwenden möchte. Das trifft bei mir aber i.d.R. nicht zu, wenn der Bedarf für eigenes Layouting besteht.
 
M

Michael...

Gast
gefährlich war vielleicht ein bisschen übertrieben;-)
byto hat gesagt.:
ComponentListener registriere, der "on resize" meine Resize-Logik aufruft
Das ist quasi das gleiche was auch im LayoutManager passiert.
Du sparst Dir einen LayoutManager und ich spare mir einen ComponentListener, ist wahrscheinlich gehupft wie gedupft
 

skummy

Aktives Mitglied
@byto:

Quasi eine onResize-Implementation bauen, die die Position der Elemente einfach beim Verändern der Größe des Frames entsprechend anpasst?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
N JavaFX Projekt nachträglich zu JavaFX Application machen? AWT, Swing, JavaFX & SWT 1
M Swing JLabel mit fester größe nachträglich formatieren AWT, Swing, JavaFX & SWT 2
K JLabel nachträglich laden AWT, Swing, JavaFX & SWT 6
A Textfeld nachträglich einfügen AWT, Swing, JavaFX & SWT 4
H Swing JCalendarCombo nachträglich Datum und Time AWT, Swing, JavaFX & SWT 2
D LayoutManager GridBag | weight nachträglich ändern AWT, Swing, JavaFX & SWT 3
B GUI Editor nachträglich anschalten? AWT, Swing, JavaFX & SWT 4
O Jcheckbox Status nachträglich abfragen AWT, Swing, JavaFX & SWT 2
C Swing JFrame nachträglich Größe ändern AWT, Swing, JavaFX & SWT 6
N Swing JTable: Objekttyp einer Spalte nachträglich ändern AWT, Swing, JavaFX & SWT 6
G JComponent nachträglich in JPanel einfügen AWT, Swing, JavaFX & SWT 5
G Anordnung MenuItems nachträglich ändern AWT, Swing, JavaFX & SWT 2
S swt table mit checkboxen: wie nachträglich im code setzen? AWT, Swing, JavaFX & SWT 6
T SWT - Text eines TreeItems nachträglich ändern AWT, Swing, JavaFX & SWT 6
J JTable nachträglich in einen JScrollPane einfügen AWT, Swing, JavaFX & SWT 6
B JTable - Zeilen nachträglich hinzufügen? AWT, Swing, JavaFX & SWT 3
Juelin javax.swing in javafx AWT, Swing, JavaFX & SWT 1
A Eclipse 2023 und Swing AWT, Swing, JavaFX & SWT 4
W 2 JTables in einem Swing-Fenster? AWT, Swing, JavaFX & SWT 5
H Swing Componente zur Läufzeit ändern AWT, Swing, JavaFX & SWT 3
B Actionlistener mit Java Swing AWT, Swing, JavaFX & SWT 2
W Gibt es einen "automatischen Listener" in Swing oder JTable oder der ATM-Klasse? AWT, Swing, JavaFX & SWT 14
H Swing Buttons erst nach Klick sichtbar AWT, Swing, JavaFX & SWT 13
ExceptionOfExpectation Anpassung von JKomponentengrößen (Swing) AWT, Swing, JavaFX & SWT 3
thor_norsk AWT SWING Aufgabe AWT, Swing, JavaFX & SWT 7
U Zwei Fragen zu eienr Swing Aufgabe AWT, Swing, JavaFX & SWT 2
M Swing Bilder in Swing anzeigen AWT, Swing, JavaFX & SWT 9
H Swing , GridLayout, Größenbestimmung der Komponenten im Layout AWT, Swing, JavaFX & SWT 8
H Simple Animation mit Swing AWT, Swing, JavaFX & SWT 2
Guybrush Threepwood Einfachste Möglichkeit zum Abspielen eines Videos in Swing AWT, Swing, JavaFX & SWT 4
A Swing ProgressBar über 2 parallel laufende Threads AWT, Swing, JavaFX & SWT 2
M Swing GridLayout AWT, Swing, JavaFX & SWT 2
O return-Statement mit Swing AWT, Swing, JavaFX & SWT 6
O Ein Java-Programm mit Swing steuern AWT, Swing, JavaFX & SWT 1
Monokuma Swing zu JavaFX AWT, Swing, JavaFX & SWT 5
J Swing Slider AWT, Swing, JavaFX & SWT 11
G Thread starten Swing AWT, Swing, JavaFX & SWT 5
G Swing JPasswordField AWT, Swing, JavaFX & SWT 12
L Swing Button Farbe ändern/wechseln AWT, Swing, JavaFX & SWT 2
C Swing AWT GUI Anfänger Aufgabe AWT, Swing, JavaFX & SWT 7
W Inject bei einem Swing Frontend AWT, Swing, JavaFX & SWT 8
L Kommunikation zwischen Klassen / Konstruktoren bei Swing AWT, Swing, JavaFX & SWT 9
M Feldvalidierung swing AWT, Swing, JavaFX & SWT 4
E Swing Componenten werden nach Änderung des display modes verzerrt dargestellt AWT, Swing, JavaFX & SWT 8
D [Swing] Anordnung von Komponenten mit GridLayout Manager AWT, Swing, JavaFX & SWT 13
O Zukunft von Swing und JavaFX ? AWT, Swing, JavaFX & SWT 3
S Swing Fenster State Machine AWT, Swing, JavaFX & SWT 1
T Swing Swing an Bildschirm anpassen AWT, Swing, JavaFX & SWT 3
S Swing Panel wird nicht neu gezeichnet AWT, Swing, JavaFX & SWT 3
M Swing Java Swing/AWT Combobox Bug AWT, Swing, JavaFX & SWT 3
M Swing GUI mittels erben sowie variabler Dateninhalt AWT, Swing, JavaFX & SWT 1
W Swing Multitouch mit Swing AWT, Swing, JavaFX & SWT 6
S Swing-Applikation die ein Numpad nachbildet samt Keybindings..? AWT, Swing, JavaFX & SWT 5
S Swing Java Swing AWT, Swing, JavaFX & SWT 6
Blender3D Problem mit € Symbol Font Gotham Windows 10 Swing AWT, Swing, JavaFX & SWT 11
J Swing oder JavaFX AWT, Swing, JavaFX & SWT 21
D Swing Anwendung ohne JPanel erstellen AWT, Swing, JavaFX & SWT 1
D SQL Statements mit Java Swing benutzen AWT, Swing, JavaFX & SWT 4
Damtonix BufferStrategy flackert (Swing) AWT, Swing, JavaFX & SWT 9
D DatePicker für Java Swing AWT, Swing, JavaFX & SWT 2
B JavaFX oder swing AWT, Swing, JavaFX & SWT 3
T Java Swing - kleines Rechteck unter dem cursor AWT, Swing, JavaFX & SWT 5
L 2D-Grafik Swing paint|paintComponent AWT, Swing, JavaFX & SWT 2
L Swing Größe automatisch anpassen AWT, Swing, JavaFX & SWT 14
G Swing Swing Binding JList funktioniert nicht AWT, Swing, JavaFX & SWT 5
Blender3D Meine Swing Anwendung läuft unter Windows 10 und Ubuntu aber nicht auf Windows 7 AWT, Swing, JavaFX & SWT 16
B Bar Plot in Swing JPanel AWT, Swing, JavaFX & SWT 0
D Swing in Kombination mit JGraphX und JGraphT AWT, Swing, JavaFX & SWT 0
F main-Funktion bei Swing AWT, Swing, JavaFX & SWT 4
S Java Swing Print() method AWT, Swing, JavaFX & SWT 4
S Java Swing auf Windows Phone AWT, Swing, JavaFX & SWT 6
I JAVAFX - Übergabe der Inhalte an eine Scene - Wo ist der Vorteil gegenüber Swing? AWT, Swing, JavaFX & SWT 2
S Manuelles Menu in Swing AWT, Swing, JavaFX & SWT 3
T Custom Window ohne Swing / AWT / FX..?! AWT, Swing, JavaFX & SWT 1
MaxG. Swing Swing Komponenten zur Laufzeit hinzufügen AWT, Swing, JavaFX & SWT 2
Java_RY Bin Ratlos bzgl Malen in Swing AWT, Swing, JavaFX & SWT 5
offi Swing Shuttle List AWT, Swing, JavaFX & SWT 9
I Graph mit Swing zeichnen AWT, Swing, JavaFX & SWT 8
D Swing Swing Objekte sehen im Entwurf anders aus als beim Ausführen AWT, Swing, JavaFX & SWT 3
S Swing & Clean und build Problem AWT, Swing, JavaFX & SWT 12
javampir Swing repaint in JavaFX Anwendung AWT, Swing, JavaFX & SWT 3
K Mit JavaFX angefangen. Lohnt sich Swing? AWT, Swing, JavaFX & SWT 28
B Swing Update Swing Komponente bevor Methode startet. AWT, Swing, JavaFX & SWT 4
B Swing Tabelle(JTable) filtern swing GUI AWT, Swing, JavaFX & SWT 3
M Swing Swing-Widgets und paintComponent() AWT, Swing, JavaFX & SWT 2
B Swing WindowBuilde: Menu -> anderes Panel wechseln AWT, Swing, JavaFX & SWT 1
K eigener button in swing AWT, Swing, JavaFX & SWT 3
A JavaFX DatePicker in Swing beim Start nicht sichtbar AWT, Swing, JavaFX & SWT 2
windl Bufferstrategy in Swing nachstellen AWT, Swing, JavaFX & SWT 0
M Kamera in Java Swing einbinden AWT, Swing, JavaFX & SWT 4
Z Swing Swing und die Progressbar AWT, Swing, JavaFX & SWT 1
J Frage zur objektorentierten Swing Programmierung AWT, Swing, JavaFX & SWT 10
Xanny 2D-Grafik Beginner! Probleme mit Swing, Gprahics class und paint AWT, Swing, JavaFX & SWT 13
F Java Swing Rechteck in JPanel zeichnen AWT, Swing, JavaFX & SWT 7
N Swing Benötige Hilfe um ein Swing Canvas zu speichern AWT, Swing, JavaFX & SWT 4
stylegangsta JButton Fehelr javax.swing.ImageIcon.<init>(Unknown Source) AWT, Swing, JavaFX & SWT 24
RalleYTN Swing JavaFX VideoPlayer in Swing einbetten. Ich komm nicht an die Dimension des Videos! AWT, Swing, JavaFX & SWT 0
T swing läuft nur beding flüssig AWT, Swing, JavaFX & SWT 1
A Sonderzeichen bei Swing AWT, Swing, JavaFX & SWT 3
L DoubleBuffering unter Swing AWT, Swing, JavaFX & SWT 0

Ähnliche Java Themen

Neue Themen


Oben