Wie kann ich JToolBars in die nächste Zeile umgebrochen lassen (Flowlayout), ohne sie unter ihnen die JPanel versteckt ty werden?

StackOverflow https://stackoverflow.com/questions/3679886

Frage

Ich bin im Begriff, eine GUI zu machen, die zeigen drei JToolBars über einem großen JPanel. Diese Symbolleiste sind kollektiv sehr groß, so dass ich ein Flow bin mit ihnen in der nächsten Zeile umgebrochen zu machen, wenn sie die JFrame Grenze erreichen. Das Problem ist, dass, wenn sie in der nächsten Zeile umgebrochen, sie durch die JPanel versteckt worden unten .. Ich möchte ich die JPanel zwingen könnte, die Symbolleiste enthält, genug, um zu wachsen alle Symbolleiste zu zeigen ..

Gibt es eine Möglichkeit, dies zu tun? Oder gibt es eine andere Art und Weise diese Symbolleiste sichtbar zu machen?

War es hilfreich?

Lösung

Ich habe vor in dieses Problem. Ich fand die beste Lösung, die eine modifizierte Version von FlowLayout zu verwenden ist, das Konto vertikale Veränderungen trägt und wickelt sie in der nächsten Zeile. Hier ist der Code für ein solches Layout.

import java.awt.*;

/**
  * A modified version of FlowLayout that allows containers using this
  * Layout to behave in a reasonable manner when placed inside a
  * JScrollPane
  * @author Babu Kalakrishnan
  * Modifications by greearb and jzd
  */

 public class ModifiedFlowLayout extends FlowLayout {
       public ModifiedFlowLayout() {
              super();
           }

           public ModifiedFlowLayout(int align) {
              super(align);
           }
       public ModifiedFlowLayout(int align, int hgap, int vgap) {
          super(align, hgap, vgap);
       }

       public Dimension minimumLayoutSize(Container target) {
          // Size of largest component, so we can resize it in
          // either direction with something like a split-pane.
          return computeMinSize(target);
       }

       public Dimension preferredLayoutSize(Container target) {
          return computeSize(target);
       }

       private Dimension computeSize(Container target) {
          synchronized (target.getTreeLock()) {
             int hgap = getHgap();
             int vgap = getVgap();
             int w = target.getWidth();

             // Let this behave like a regular FlowLayout (single row)
             // if the container hasn't been assigned any size yet
             if (w == 0) {
                w = Integer.MAX_VALUE;
             }

             Insets insets = target.getInsets();
             if (insets == null){
                insets = new Insets(0, 0, 0, 0);
             }
             int reqdWidth = 0;

             int maxwidth = w - (insets.left + insets.right + hgap * 2);
             int n = target.getComponentCount();
             int x = 0;
             int y = insets.top + vgap; // FlowLayout starts by adding vgap, so do that here too.
             int rowHeight = 0;

             for (int i = 0; i < n; i++) {
                Component c = target.getComponent(i);
                if (c.isVisible()) {
                   Dimension d = c.getPreferredSize();
                   if ((x == 0) || ((x + d.width) <= maxwidth)) {
                      // fits in current row.
                      if (x > 0) {
                         x += hgap;
                      }
                      x += d.width;
                      rowHeight = Math.max(rowHeight, d.height);
                   }
                   else {
                      // Start of new row
                      x = d.width;
                      y += vgap + rowHeight;
                      rowHeight = d.height;
                   }
                   reqdWidth = Math.max(reqdWidth, x);
                }
             }
             y += rowHeight;
             y += insets.bottom;
             return new Dimension(reqdWidth+insets.left+insets.right, y);
          }
       }

       private Dimension computeMinSize(Container target) {
          synchronized (target.getTreeLock()) {
             int minx = Integer.MAX_VALUE;
             int miny = Integer.MIN_VALUE;
             boolean found_one = false;
             int n = target.getComponentCount();

             for (int i = 0; i < n; i++) {
                Component c = target.getComponent(i);
                if (c.isVisible()) {
                   found_one = true;
                   Dimension d = c.getPreferredSize();
                   minx = Math.min(minx, d.width);
                   miny = Math.min(miny, d.height);
                }
             }
             if (found_one) {
                return new Dimension(minx, miny);
             }
             return new Dimension(0, 0);
          }
       }

    }

Andere Tipps

Hier finden Sie aktuelle WrapLayout . Er arbeitete für mich. Hier der Code.

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top