这两个限制之间有什么区别?
来自文档:
PUSH - 使组件所在的行和/或列以“权重”增长
GROW - 设置组件相对于同一单元格中的其他组件的增长程度。
那么,主要思想是缩小组件内外的大小?
答案 0 :(得分:17)
了解fill
,(列,行)grow
,push
一起工作非常重要
使用(组件)grow
来定义布局。 (有两种不同的grow
约束可以做不同的事情。)
MigLayout
是一个基于网格的经理。 (更准确地说,它最重要的模式是。)
有两个步骤需要完成:
这是fill
,(列,行)grow
,push
和(组件)grow
约束的内容
帮助实现。前三个定义了网格列和行的增长,
最后一个定义了组件如何在其上传播
分区,例如它被放入的细胞。注意,填充或生长是倾向或渴望占据
布局中的空白空间。列,行或列不占用的窗口区域
组件充满了空白空间。
push
和(列,行)grow
采用可选的weight
参数。它
定义列或行相对于其他列的增长程度
和行。 fill
约束均匀分布weight
。
(push
约束可用于在不同的上下文中使间隙变得贪婪。)
我提供了三个例子来阐明这些约束的使用。
<强>填充强>
fill
约束会影响网格的所有单元格。它们占据了所有可用空间。
(组件)grow
约束指定组件在其单元中的传播方式。
package com.zetcode;
import java.awt.EventQueue;
import javax.swing.BorderFactory;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import net.miginfocom.swing.MigLayout;
public class MigLayoutFillEx extends JFrame {
public MigLayoutFillEx() {
initUI();
setSize(300, 250);
setTitle("Fill");
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setLocationRelativeTo(null);
}
private void initUI() {
JPanel pnl = new JPanel(new MigLayout("fill"));
pnl.add(getLabel("Area 1"), "cell 0 0, growx");
pnl.add(getLabel("Area 2"), "cell 0 1, grow");
pnl.add(getLabel("Area 3"), "cell 1 0 1 2, grow");
add(pnl);
}
private JLabel getLabel(String text) {
JLabel label = new JLabel(text, JLabel.CENTER);
label.setBorder(BorderFactory.createEtchedBorder());
return label;
}
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
@Override
public void run() {
MigLayoutFillEx ex = new MigLayoutFillEx();
ex.setVisible(true);
}
});
}
}
在示例中,我们有三个标签。
JPanel pnl = new JPanel(new MigLayout("fill"));
fill
是布局约束;它会影响所有细胞。
pnl.add(getLabel("Area 1"), "cell 0 0, growx");
pnl.add(getLabel("Area 2"), "cell 0 1, grow");
pnl.add(getLabel("Area 3"), "cell 1 0 1 2, grow");
现在我们定义组件如何填充它们所分配的区域 布局经理。 区域1标签水平填充其分配区域,另一个标签填充 两个标签填充两个尺寸的标记区域。
列,行增长
(列,行)grow
约束会影响特定列中的所有单元格
或排。
package com.zetcode;
import java.awt.EventQueue;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.JTextField;
import net.miginfocom.swing.MigLayout;
public class MigLayoutGrowEx extends JFrame {
public MigLayoutGrowEx() {
initUI();
setSize(300, 250);
setTitle("Grow constraint");
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setLocationRelativeTo(null);
}
private void initUI() {
JPanel pnl = new JPanel(new MigLayout("wrap", "[grow]", "[][grow]"));
JTextField field = new JTextField(10);
JTextArea area = new JTextArea(10, 10);
pnl.add(field, "growx");
pnl.add(new JScrollPane(area), "grow");
add(pnl);
}
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
@Override
public void run() {
MigLayoutGrowEx ex = new MigLayoutGrowEx();
ex.setVisible(true);
}
});
}
}
在示例中,我们有两个组件。文本字段预计会水平增长, 水平和垂直的文本区域。
JPanel pnl = new JPanel(new MigLayout("wrap", "[grow]", "[][grow]"));
在这一行中,我们指定第一列和第二列 网格增长。
pnl.add(field, "growx");
pnl.add(new JScrollPane(area), "grow");
现在我们定义文本字段水平填充其分配区域 文本区域填满了整个区域。
推送
push
约束与(列,行)grow
基本相同。该
区别在于push
方法指定了add()
。
package com.zetcode;
import java.awt.EventQueue;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.JTextField;
import net.miginfocom.swing.MigLayout;
public class MigLayoutPushEx extends JFrame {
public MigLayoutPushEx() {
initUI();
setSize(300, 250);
setTitle("Push constraint");
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setLocationRelativeTo(null);
}
private void initUI() {
JPanel pnl = new JPanel(new MigLayout("wrap"));
JTextField field = new JTextField(10);
JTextArea area = new JTextArea(10, 10);
pnl.add(field, "pushx, growx");
pnl.add(new JScrollPane(area), "push, grow");
add(pnl);
}
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
@Override
public void run() {
MigLayoutPushEx ex = new MigLayoutPushEx();
ex.setVisible(true);
}
});
}
}
示例与前一个示例相同。
JPanel pnl = new JPanel(new MigLayout("wrap"));
此处未指定增长。
pnl.add(field, "pushx, growx");
pnl.add(new JScrollPane(area), "push, grow");
使用组件指定所有内容&#39; add()
内的约束
方法