有没有一种方法可以检测用户是否停止了窃听?可能是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>


现在,由于我进行测试,代码有点混乱。

最佳答案

我能想到的最简单的方法是定义自己的控件,添加一个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()添加到Controller。

07-23 17:38