有谁知道如何让图标位于左端并在图标和文本之间留出一些空间(或文本右对齐)?

问题描述 投票:0回答:3

我正在尝试创建一个带有图标和一些文本的

JButton
。我的问题是,我希望图标左对齐,文本右对齐(不需要右对齐,但我不希望文本粘在图标上)。

我自己无法做到这一点,所以我尝试了一个稍微不同的解决方案。我使用

iconTextGap
在图标和文本之间创建一些空间,原则上工作正常,但是当我创建多个按钮时,所有按钮都具有最宽的宽度,图标不再位于最左边(除了具有最长文本的按钮)。

我包含了一个代码来证明这一点:

import java.awt.GridBagConstraints;
import java.awt.GridBagLayout;
import java.awt.Insets;
import java.io.File;
import java.net.MalformedURLException;

import javax.swing.BorderFactory;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.SwingConstants;


public class Main{

 private JFrame frame;
 private JPanel buttonPanel;
 private GridBagConstraints constraints;

 public Main() throws MalformedURLException{
    
    frame = new JFrame();
    
    buttonPanel = new JPanel();
    frame.add(buttonPanel);
    
    buttonPanel.setLayout(new GridBagLayout());
    constraints = new GridBagConstraints();
    
    constraints.insets = new Insets(5, 5, 3, 5);
    constraints.fill = GridBagConstraints.HORIZONTAL;
    constraints.gridx = 0;
    constraints.gridy = 0;
    
    
    String[] text = { "some Text", "this text is longer" };
    
    for (int i = 0; i < text.length; i++) {
        JButton button= new JButton(text[i], new ImageIcon(new File("icon.png").toURI().toURL()));
        button.setAlignmentX(SwingConstants.WEST);
        button.setIconTextGap(30);
        button.setBorder(BorderFactory.createEmptyBorder(5, 5, 5, 10));
        
        
        buttonPanel.add(button, constraints);
        constraints.gridy++;
    }
    
    frame.pack();
    frame.setVisible(true);
    
    
}

 public static void main(String[] args){
    try {
        new Main();
    } catch (Exception e) {
        e.printStackTrace();
    }
 }
    
}

有谁知道如何让图标位于左端并在图标和文本之间留出一些空间(或文本右对齐)?

java swing icons alignment jbutton
3个回答

2
投票

此问题的经典解决方案是使用具有允许对齐组件(例如

BorderLayout
)的布局的附加面板。然后将按钮和标签放入其中并进行相应的布局对齐。打包或验证框架。


1
投票

尝试将按钮属性中的边距设置为小于默认值, 然后将 iconTextGap 设置为最右边的水平位置

© www.soinside.com 2019 - 2024. All rights reserved.