如何将JSlider选定值设置为全局变量?

时间:2012-12-22 16:14:38

标签: java swing global-variables return jslider

有谁知道我如何能够在JSlider的事件处理程序中发送所选值stateChanged并将其设置为全局变量?

例如

public class Slider extends JPanel {

    public JSlider slider;
    public UserFrame frame;
    public double[] priceRange;

    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        new Slider();
    }

    public Slider() throws ClassNotFoundException, SQLException {
        slider = new JSlider();
        priceRange = new double[2];

        slider.setBorder(BorderFactory.createTitledBorder("Maximum Price in SEK"));

    /*
     * The minimum and maximum values are queried from the database. Those
     * values are then rounded up (maximum) to the nearest 10 SEK.
     * For example, if the minimum is 67 SEK and the maximum 95 SEK, then
     * the displayed range is [70, 100].
     */
        int min = (getMinimumPrice() / 10) * 10 + 10;
        int max = (getMaximumPrice() / 10) * 10 + 10;

        slider.setMajorTickSpacing(10);
        slider.setMinorTickSpacing(5);
        slider.setMinimum(min);
        slider.setMaximum(max);
        slider.setPaintTicks(true);
        slider.setPaintLabels(true);
        add(slider);
    }

    public void stateChanged(ChangeEvent e) {
        JSlider source = (JSlider)e.getSource();
        if (!source.getValueIsAdjusting()) {
            slider.getModel().setValue(slider.getModel().getValue());
            priceRange[0] = slider.getModel().getValue();
        }
    }
}

...等等,忽略方法getMinimumgetMaximum他们只是检索我的数据库中的最高和最低值,但是让我说我​​想要在用户发布时发生的所有事情JSlider旋钮将其设置为priceRange[0]。我怎么能这样?我已经尝试创建一个模型,并设置每次使用stateChanged我也在我的主要代码集中的actionListener外部分配类似的东西......

priceRange[0] = slider.getModel().getValue();

然后打印出结果并获得最小值我也设置了它。

我真的很感激任何进一步的建议。

祝你假期愉快! :)

所有最好的, 马库斯

1 个答案:

答案 0 :(得分:2)

只需删除以下行:

slider.getModel().setValue(slider.getModel().getValue());
priceRange[0] = slider.getModel().getValue();

并插入此代码:

priceRange[0] = (double)slider.getValue();
祝你好运!

P.S。你在哪里实现了ChangeListener界面?

相关问题