Combobox箭头按钮与nimbus LaF中的字体大小相对应

时间:2014-09-09 11:07:56

标签: java swing jcombobox look-and-feel nimbus

我在我的应用程序中使用JCombobox和Nimbus LaF。 我已经为不同的状态覆盖了ArrowButton的Combobox和Foregroundpainter的Backgroundpainter。 画家们工作得很好。但是当我增加字体的大小时,Combobox的箭头按钮会伸展,看起来不太好。

如何使其不可拉伸?

我使用过Nimbus LaF的画家,我必须提供自己的paintContext。

以下是显示问题的代码。

public class ComboTest {

    public ComboTest(){

      String labels[] = { "A", "B", "C", "D" };

    JFrame frame = new JFrame("ComboBox Demo");

    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

    JComboBox comboBox = new JComboBox(labels);

    frame.add(comboBox, BorderLayout.NORTH);

    frame.setSize(300, 100);

    frame.setVisible(true);
        }

    public static void main(String[] args)
    {

        try {
             UIManager.setLookAndFeel(NimbusLookAndFeel.class.getName()); 

           }

        catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
       }

    UIManager.getLookAndFeelDefaults().put("defaultFont", new Font("Segoe UI", Font.PLAIN,16));

// if i put the different font size than it is strecthing, with the size 12 it looks good.

    //UIManager.getLookAndFeelDefaults().put("defaultFont", new Font("SegoeUI",Font.PLAIN,12));

    UIManager.getLookAndFeelDefaults().put("ComboBox:\"ComboBox.arrowButton"[Pressed].foregroundPainter", new ComboArrowPainter(1));

    javax.swing.SwingUtilities.invokeLater(new Runnable() {

    public void run() { 

            new ComboTest();

      }
         });
    }

    }

这是ArrowPainter的类,我从Nimbus获取

public class ComboArrowPainter extends AbstractRegionPainter {

    static final int FOREGROUND_PRESSED = 1;

      private int state; //refers to one of the static final ints above

      private PaintContext ctx;
      //the following 4 variables are reused during the painting code of the layers

      private Path2D path = new Path2D.Float();

      private Color color31 = decodeColor("textForeground", 0.0f, -0.6357143f, 0.45098037f, 0);

      public ComboArrowPainter(int state) {

    super();

         this.state = state;

          this.ctx = new PaintContext(new Insets(6,10,6,10), new Dimension(19,19), false);;
      }

    private Object[] componentColors;

      @Override

      protected void doPaint(Graphics2D g, JComponent c, int width, int height, Object[] extendedCacheKeys) {

     //populate componentColors array with colors calculated in getExtendedCacheKeys call

          componentColors = extendedCacheKeys;

          paintForegroundPressed(g); 

         }

    @Override

      protected final PaintContext getPaintContext() {

          return ctx;

      }

      private void paintForegroundPressed(Graphics2D g) {

          path = decodePath8();

          g.setPaint(color31);

          g.fill(path);

      }

      private Path2D decodePath8() {

          path.reset();

          path.moveTo(decodeX(1.0242647f), decodeY(1.3526785f));

          path.lineTo(decodeX(2.0f), decodeY(0.8333333f));

          path.lineTo(decodeX(2.0f), decodeY(1.8571429f));

          path.lineTo(decodeX(1.0242647f), decodeY(1.3526785f));

          path.closePath();

          return path;

      }

    }

1 个答案:

答案 0 :(得分:0)

幸运的是,我找到了解决方案。我已经计算了fontsize的组件大小。我们已将该值用作Paintcontext。这里是画家类的更新构造函数,将保持不变。

public ComboArrowPainter(int state, int FontSize) {
             super();
             this.state = state;
             double value = FontSize*1.31031746;
             int topBottomInsssetValue =(int) Math.ceil((value)/2);
             this.ctx = new PaintContext(new Insets(6,topBottomInsssetValue,6,topBottomInsssetValue), new Dimension(19,19), false); 

    }