1

有没有办法检测用户是否停止滑动?也许bij鼠标输入检查或其他东西。我在 onSliderChange 事件中尝试了鼠标 isButton0Release 和 hasFocus 来检查用户是否停止滑动,但这不起作用。

到目前为止我得到了什么

@NiftyEventSubscriber(id = "speedSlider")
public void onSliderChange(String id, SliderChangedEvent event) 
{   boolean test2 = event.getSlider().hasFocus();
    boolean test = nifty.getMouseInputEventQueue().getLastMouseDownEvent().isButton0Release();
    System.out.println("before " + test2);
    int speed = (int)event.getValue();
    speedTextField.getRenderer(TextRenderer.class).setText(speed + "");
    if(test2){
        System.out.println("after " + test2);
        main.setSimSpeed(speed);
    }
}

和xml中的滑块

                <panel id="speed_up_down_panel" height="30px" width="180px" childLayout="center">         
                <control id="speedSlider" name="horizontalSlider" width="150px" min="1" initial="1" buttonStepSize="1">
                    <image id="#position" filename="Interface/sliderbutton.png" visibleToMouse="true" width="40px" height="40px"></image>
                </control>
            </panel> 

现在代码有点乱,因为我在测试。

4

1 回答 1

0

我能想到的最简单的方法是定义自己的添加onRelease事件处理程序的控件:

<?xml version="1.0" encoding="UTF-8"?>
<nifty-controls xmlns="http://nifty-gui.lessvoid.com/nifty-gui">
<controlDefinition name="horizontalSlider" style="nifty-horizontal-slider"
    controller="de.lessvoid.nifty.controls.slider.SliderControl"
    inputMapping="de.lessvoid.nifty.controls.scrollbar.ScrollbarInputMapping">

    <panel style="#panel">
        <interact onMouseWheel="mouseWheel()"/>
        <image style="#left">
            <interact onClickRepeat="upClick()"/>
        </image>
        <image id="#background" style="#background">
            <interact onClick="mouseClick()" onClickMouseMove="mouseClick()"/>
            <image id="#position" style="#position">
                <interact onClick="mouseClick()" onClickMouseMove="mouseClick()"
                    onRelease="onRelease()"/>
                    <!-- ^ ^ ^ ADD THIS ^ ^ ^ -->
            </image>
        </image>
        <image style="#right">
            <interact onClickRepeat="downClick()"/>
        </image>
    </panel>
</controlDefinition>

注意:我只是复制了 SliderControl 的原始定义并添加onRelease<interact>标签中。见:https ://github.com/nifty-gui/nifty-gui/blob/1.4/nifty-controls/src/main/resources/nifty-controls/nifty-slider.xml

现在使用 XML 中的这一行加载这个新控件:(
将其插入到加载的行之后nifty-default-controls.xml

<useControls filename="Interface/NewSlider.xml" />

public void onRelease()然后向你的控制器添加一个方法。

于 2016-01-10T22:07:07.187 回答