自定义JScrollbar问题(更改旋钮/拇指)
问题描述:
我想更改JScrollBar的外观。
我这样做覆盖/扩展ScrollBarUI。
通过覆盖createIncreaseButton
和createDecreaseButton
来改变箭头按钮的外观是没有问题的。 我通过覆盖paintThumb和paintTrack方法来改变轨道的宽度。自定义JScrollbar问题(更改旋钮/拇指)
它现在看起来像<----o---->
(非常薄的轨迹线和一个椭圆形的拇指/旋钮)。
问题:
旋钮不能移动,直到尽头:
它是什么样子: <---o------>
它应该是什么样子:<---------o>
我知道这是因为我做了椭圆不伸展(原始矩形与宽度一起伸展)。
我完全无法改变拇指移动的计算,所以它可以移动到最后。
我会非常感谢帮助。
继承人的代码:
public class TestScrollBarMain extends JFrame {
public TestScrollBarMain() {
setDefaultCloseOperation(DISPOSE_ON_CLOSE);
JPanel p = new JPanel();
p.setPreferredSize(new Dimension(500, 500));
JScrollPane s = new JScrollPane(p);
MyScrollBar b = new MyScrollBar();
s.setVerticalScrollBar(b);
getContentPane().add(s);
setSize(100, 100);
setVisible(true);
}
public static void main(String[] args) {
new TestScrollBarMain();
}
public class MyScrollBarUI extends BasicScrollBarUI {
@Override
protected void paintThumb(final Graphics g, final JComponent c, final Rectangle thumbBounds) {
if (thumbBounds.isEmpty() || !this.scrollbar.isEnabled()) {
return;
}
g.translate(thumbBounds.x, thumbBounds.y);
g.setColor(this.thumbDarkShadowColor);
g.drawOval(2, 0, 14, 14);
g.setColor(this.thumbColor);
g.fillOval(2, 0, 14, 14);
g.setColor(this.thumbHighlightColor);
g.setColor(this.thumbLightShadowColor);
g.translate(-thumbBounds.x, -thumbBounds.y);
}
@Override
protected void paintTrack(final Graphics g, final JComponent c, final Rectangle trackBounds) {
g.setColor(Color.black);
g.fillRect(trackBounds.width/2, trackBounds.y, 3, trackBounds.height);
if (this.trackHighlight == BasicScrollBarUI.DECREASE_HIGHLIGHT) {
this.paintDecreaseHighlight(g);
} else if (this.trackHighlight == BasicScrollBarUI.INCREASE_HIGHLIGHT) {
this.paintIncreaseHighlight(g);
}
}
}
public class MyScrollBar extends JScrollBar {
MyScrollBar() {
super();
setUI(new MyScrollBarUI());
}
}
}
答
这包括你的MyScrollBarUI代码:
protected void setThumbBounds(int x, int y,int width,int height)
{
super.setThumbBounds(x, y, 14, 14);
}
protected Rectangle getThumbBounds()
{
return new Rectangle(super.getThumbBounds().x,super.getThumbBounds().y,14,14);
}
protected Dimension getMinimumThumbSize()
{
return new Dimension(14,14);
}
protected Dimension getMaximumThumbSize()
{
return new Dimension(14,14);
}
一个漂亮的外观为您的问题也很重要... – 2010-05-19 11:52:47
请提供paintThumb和paintTrack代码 – akf 2010-05-19 12:39:59