正如标题中所解释的那样,我制作了一个简单的JSlider,并且我成功设置了最小值和最大值,以及一个小的节距,然后我将“setSnapToTicks”设置为true。没有任何问题,当用户松开鼠标时,我的旋钮移动到最近的刻度线上,这样就不容易了。
但是现在我想在没有释放鼠标的情况下获得此效果,旋钮必须按刻度移动而不关注这些刻度之间的值,我希望它仅在刻度值上“跳跃”。我刚做了很多搜索,我没有找到答案,我只是关于“setExtent”,它应该设置我正在搜索的那一步,但是在调试之后它没有用。 这是我对JSlider的简单声明:
sliderFlightLevel = new JSlider();
sliderFlightLevel.setValue(100);
sliderFlightLevel.setMinorTickSpacing(100);
sliderFlightLevel.setMinimum(100);
sliderFlightLevel.setMaximum(50000);
GridBagConstraints gbcSliderFlightLevel = new GridBagConstraints();
gbcSliderFlightLevel.gridwidth = 3;
gbcSliderFlightLevel.insets = new Insets(0, 10, 5, 10);
gbcSliderFlightLevel.fill = GridBagConstraints.HORIZONTAL;
gbcSliderFlightLevel.gridx = 0;
gbcSliderFlightLevel.gridy = 1;
mainPanel.add(sliderFlightLevel, gbcSliderFlightLevel);
感谢阅读,我希望我会得到一些帮助:)
答案 0 :(得分:1)
我认为此行为由组件的UI委托(SliderUI
)控制。你可以尝试另一种外观&感觉,或者您可以尝试配置您使用的那个。
您还可以在组件上安装另一个UI委托。
请参阅此real world example of customizing the behavior of a swing component。
修改强>
我想出了一个丑陋的黑客来完成这项工作。此代码完全依赖于类BasicSliderUI
的实现细节(大多数外观和感觉使用)。
import java.awt.event.MouseEvent;
import java.awt.event.MouseMotionListener;
import javax.swing.JSlider;
import javax.swing.plaf.metal.MetalSliderUI;
public class MetalSnapSliderUI extends MetalSliderUI {
private MouseMotionListener myMouseMotionListener = new MouseMotionListener() {
public void mouseDragged(MouseEvent e) {
trackListener.mouseDragged(e);
calculateThumbLocation();
slider.repaint();
}
public void mouseMoved(MouseEvent e) {
trackListener.mouseMoved(e);
}
};
@Override
protected void installListeners(JSlider slider) {
super.installListeners(slider);
slider.removeMouseMotionListener(trackListener);
slider.addMouseMotionListener(myMouseMotionListener);
}
@Override
protected void uninstallListeners(JSlider slider) {
super.uninstallListeners(slider);
slider.removeMouseMotionListener(myMouseMotionListener);
}
}
您需要在JSlider上安装此UI:
JSlider s = new JSlider();
s.setUI(new MetalSnapSliderUI());