求教MouseArea覆盖Slider引起的鼠标移动事件冲突问题



  • Slider无响应。如果把MouseArea放在代码前面则Slider可以响应。
    但又会打印testMouseArea onExited。也就是说Slider区域不算testMouseArea区域。

    我做的是工具条上的Slider控件。工具条本身就在等鼠标事件。所以两个事件都要。和解?

    import QtQuick 2.7
    import QtQuick.Controls 2.1
    import QtQuick.Window 2.3

    ApplicationWindow {
    id: mainWindow
    visible: true
    width: 300
    height: 200

    Slider {
    	id: volumeSlider
    	from: 0
    	to: 100
    	onValueChanged: console.log("onSliderPositionChanged")
    }
    MouseArea {
    	id: testMouseArea
    	anchors.fill: parent;
    	hoverEnabled: true
    	propagateComposedEvents: true
    	onPositionChanged: {
    		console.log("on testMouseArea PositionChanged")
    		mouse.accepted = true
    	}
    	onEntered: console.log("testMouseArea onEntered")
    	onExited: console.log("testMouseArea onExited")
    }//--testMouseArea
    

    }




  • 告诉你一个方法,Slider位于MouseArea的上层,然后除了Slider的hover和press事件,其余的事件都走MouseArea。怎么做到?可以在事件中设置MouseAreavisible属性。
    还有一种做法就是Slider自定义背景background,里面包含了MouseArea


 

最近的回复

关注我们

微博
QQ群











召唤伊斯特瓦尔