1

TL;DR 異なる DPI 設定では、アプリケーションのコンポーネントが重複する可能性があります。それを取り除くために、UI を更新した後は常に 0 になるコンポーネントの幅を確認したいと思います。質問の最後に単純化されたコード。

基本的な問題は、異なる DPI 設定では、プログラムのさまざまな部分が最も右側に到達することです。より高い DPI では動的に生成されたラベルであり、より低い DPI では固定幅のテキスト フィールドです。
DPI 設定の変更の可能性に対処するために、SpringLayout を使用しています。上記で説明したように、特定の設定でコンポーネントが重複するという問題があります。

それを克服するために、1 つのコンポーネントの左端が他のコンポーネントの右端より +10 ピクセル離れているかどうかを確認して、より多くのスペースを確保したいと考えました。

if (labelRight.getX() < (labellist.get(0).getX() + labellist.get(0).getWidth+10)){ 
//Use one SpringLayout setting for labelRight
} else //Use another SpringLayout setting for labelRight

問題は、コンポーネントが生成された後にコンポーネントの幅を確認することだと思います。ユーザーは、パネルのコンテンツの一部を変更するさまざまな設定から選択できます。labellistその領域の右端のラベルが含まれます。
問題の幅と幅チェックを表示する小さなテストプログラムを作成しました。

import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.ArrayList;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.SpringLayout;
import javax.swing.UIManager;

public class testsforSO extends JFrame {

    private static final long serialVersionUID = -857761460788731909L;
    ArrayList<JLabel> lbls = new ArrayList<>();
    int lblCount = 6; 
    JPanel panel = new JPanel();
    SpringLayout sl_panel = new SpringLayout();

    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                testsforSO frame = new testsforSO();
                frame.pack();
                frame.setVisible(true);
                frame.setSize(500, 500);
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (Exception e) {
                    e.printStackTrace();
                }

            }
        });
    }

    public testsforSO() {

        getContentPane().add(panel);

        updateUI();

        JButton incr = new JButton("Increment here!");
        incr.addActionListener(new ActionListener() {
            @Override
            public void actionPerformed(ActionEvent arg0) {
                for (int i=0; i<=lbls.size()-1; i++){
                    panel.remove(lbls.get(i));
                }

                lblCount++;
                lbls.clear();
                updateUI();
                panel.repaint();
                panel.revalidate();

                System.out.println("Width of slimest label: " + lbls.get(0).getWidth());
                System.out.println("Width of widest label : " + lbls.get(lbls.size()-1).getWidth());
            }
        });
        panel.add(incr);
        sl_panel.putConstraint(SpringLayout.NORTH, incr, 10, SpringLayout.NORTH, panel);
        sl_panel.putConstraint(SpringLayout.EAST, incr, -10, SpringLayout.EAST, panel);

        panel.setLayout(sl_panel);
    }

    private void updateUI(){
        for (int i = 0; i <= lblCount; i++) {
            String abc = new String();
            for (int j = 0; j <= i; j++) {
                abc += "xx";
            }
            JLabel bfrLbl = new JLabel(abc);
            lbls.add(bfrLbl);
            panel.add(bfrLbl);
        }

        for (int i = 0; i <= lbls.size() - 1; i++) {
            if (i > 0)
                sl_panel.putConstraint(SpringLayout.NORTH, lbls.get(i), 8, SpringLayout.SOUTH, lbls.get(i - 1));
            else
                sl_panel.putConstraint(SpringLayout.NORTH, lbls.get(i), 8, SpringLayout.NORTH, panel);
        }

    }
}

ボタンを押すと、UI が更新され、下部にもう 1 つのラベルが表示されます。それに応じて SpringLayout が適合し、パネルは後で再検証されます。ただし、幅の出力は 0 です。なぜですか。それに対して何ができますか?

4

1 に答える 1

0

さらに調査した結果、コンポーネントの幅を正しく読み取る方法を見つけました。

sl_panel.getConstraint(SpringLayout.WIDTH, lbls.get(0)).getValue();

トリックを行います。に比べて非常に大規模なラインのようです。

lbls.get(0).getWidth();

けれど。

于 2017-01-04T09:52:45.920 に答える