这超出了我的范围(原谅,已经很晚了)。我是一个WindowsSliderUI的子类,因为我希望它绘制一个更大的拇指(是正确的单词吗?)(那是有效的)并且还在它上方显示滑块的值(例如,像gtk外观和感觉一样)(那已经坏了)。我正在覆盖paint()方法,目前它看起来像这样:(很长,我的变化接近底部):
Rectangle knobBounds = thumbRect;
int w = knobBounds.width;
int h = knobBounds.height;
g.translate(knobBounds.x, knobBounds.y);
if ( slider.isEnabled() ) {
g.setColor(slider.getBackground());
}
else {
g.setColor(slider.getBackground().darker());
}
Boolean paintThumbArrowShape =
(Boolean)slider.getClientProperty("Slider.paintThumbArrowShape");
if ((!slider.getPaintTicks() && paintThumbArrowShape == null) ||
paintThumbArrowShape == Boolean.FALSE) {
// "plain" version
g.fillRect(0, 0, w, h);
//THE ONES THAT MATTER
g.setColor(Color.BLACK);
String val = slider.getValue()+"";
g.drawString(val, 0, 0);
g.setColor(Color.RED);
g.drawLine(0, 0, 30, 8);
//END
g.setColor(Color.black);
g.drawLine(0, h-1, w-1, h-1);
g.drawLine(w-1, 0, w-1, h-1);
g.setColor(getHighlightColor());
g.drawLine(0, 0, 0, h-2);
g.drawLine(1, 0, w-2, 0);
g.setColor(getShadowColor());
g.drawLine(1, h-2, w-2, h-2);
g.drawLine(w-2, 1, w-2, h-3);
}
我想要的只是将值显示在拇指上方。然而,现在发生的事情是字符串最初显示,但是当我拖动滑块时,它会停留在同一个地方(不会改变值),直到我释放鼠标按钮,此时它会在正确的位置重新绘制值。而且为了使我的头更有趣,drawLine()方法工作正常 - 当我拖动它时,线总是在拇指上。 现在,这可能是一个微不足道的错误(我真的不好,累了),但请帮助我找到它。请注意,如果你对整个问题有更好的解决方法,请告诉我。正如我所说,我对此并不擅长,而且我倾向于让事情变得更加复杂。
非常感谢
答案 0 :(得分:5)
我不知道完整的答案,但是你打电话给
g.drawString(val, 0, 0);
看起来很狡猾。您为drawString指定的坐标是字符串中最左侧字符的基线,而不是字符串的左上角。通常,像你这样的调用不会显示任何内容,因为所有或大部分字符串都是在剪切矩形之外绘制的。
也许你的意思是这样的:
final int height = g.getFontMetrics().getAscent();
g.drawString(s, 0, height);