Qml实用技巧:在可视元素之前半透明覆盖一个可视元素,阻止鼠标透(界面)传(防止点击到被遮挡的按钮)

简介: Qml实用技巧:在可视元素之前半透明覆盖一个可视元素,阻止鼠标透(界面)传(防止点击到被遮挡的按钮)

需求

       需要一个半遮挡的界面,遮挡住原来的界面,因为把用来被遮挡的界面写成了组件,所以将其设置为需要遮挡的界面的子对象

BUG

       每次点击后面和前面的按钮都可以触发,如下:

Item {
    Rectangle {
        width: 200;
        height: 200;
        color: "yellow";
        Button {
            anchors.top: parent.top;
            text: "bottom";
            onClicked: {
                console.log("onClicked bottom");
            }
        }
        // 本人把遮挡的部分当作组件写成单独的文件了,用的时候当作需要被遮挡的子对象
        Rectangle {
            anchors.fill: parent;
            color: "#80000000"
            Button {
                text:"top";
                anchors.bottom: parent.bottom;
                onClicked: {
                    console.log("onClicked top");
                }
            }
        }
    }
}

图片.png

解决方法一(笔者推荐方法)

       改变MouseArea范围,如下:

Item {
    Rectangle {
        width: 200;
        height: 200;
        color: "yellow";
        Button {
            anchors.top: parent.top;
            text: "bottom";
            onClicked: {
                console.log("onClicked bottom");
            }
        }
        // 本人把遮挡的部分当作组件写成单独的文件了,用的时候当作需要被遮挡的子对象
        Rectangle {
            anchors.fill: parent;
            color: "#80000000"
            MouseArea {                 // 新增代码
                anchors.fill: parent;   // 新增代码
                Button {
                    text:"top";
                    anchors.bottom: parent.bottom;
                    onClicked: {
                        console.log("onClicked top");
                    }
                }
            }                           // 新增代码
        }
    }
}

图片.png

解决方法二

       使底层disable,这里特别要注意,如果父元素被disable那么子元素就会disable(单独设置enable也无效),所以不能使用父子关系

Item {
    Rectangle {
        id: bottomButton;
        width: 200;
        height: 200;
        color: "yellow";
        Button {
            anchors.top: parent.top;
            text: "bottom";
            onClicked: {
                console.log("onClicked bottom");
                bottomButton.enabled = false;
            }
        }
        // 本人把遮挡的部分当作组件写成单独的文件了,用的时候当作需要被遮挡的子对象
    }
    Rectangle {
        anchors.fill: bottomButton;
        color: "#80000000"
//        MouseArea {                 // 新增代码
//            anchors.fill: parent;   // 新增代码
            Button {
                text:"top";
                anchors.bottom: parent.bottom;
                onClicked: {
                    console.log("onClicked top");
                }
            }
//        }                           // 新增代码
    }
}

图片.png






相关文章
|
5月前
高亮提示、聚焦控件并滚动到浏览器中刚刚好可以查看到该控件的位置
高亮提示、聚焦控件并滚动到浏览器中刚刚好可以查看到该控件的位置
|
索引 容器
Bootstrap4----网络系统、图像形状、轮播、滚动监听、多媒体对象、下拉菜单导航及按钮
Bootstrap4----网络系统、图像形状、轮播、滚动监听、多媒体对象、下拉菜单导航及按钮
|
算法 Windows
Winform控件优化之实现无锯齿的圆角窗体(或任意图形的无锯齿丝滑的窗体或控件)【借助LayeredWindow】
在一般能搜到的所有实现圆角窗体的示例中,都有着惨不忍睹的锯齿...而借助于Layered Windows,是可以实现丝滑无锯齿效果的Form窗体的,其具体原理就是分层窗体....
1459 0
Winform控件优化之实现无锯齿的圆角窗体(或任意图形的无锯齿丝滑的窗体或控件)【借助LayeredWindow】
|
2月前
|
前端开发 JavaScript
基于Vue3实现鼠标按下某个元素进行拖动,实时改变左侧或右侧元素的宽度,以及点击收起或展开的功能
本文介绍了如何在Vue3项目中实现一个鼠标拖动调整元素宽度的功能,并展示了点击按钮收起或展开侧边栏的效果,提供了完整的实现代码和操作演示。
313 0
基于Vue3实现鼠标按下某个元素进行拖动,实时改变左侧或右侧元素的宽度,以及点击收起或展开的功能
|
2月前
|
图形学
小功能⭐️不用传参,Unity获得鼠标悬浮处的物体、UI!
小功能⭐️不用传参,Unity获得鼠标悬浮处的物体、UI!
|
5月前
简单讲述ondragstart、drag、ondragend、ondragenter、ondragover、ondrop、ondragleave七个与拖拽相关的监听事件,并运用实现拖拽过程放置样式变化
简单讲述ondragstart、drag、ondragend、ondragenter、ondragover、ondrop、ondragleave七个与拖拽相关的监听事件,并运用实现拖拽过程放置样式变化
|
图形学
|
11月前
|
前端开发
css动画效果代码淡入淡出折叠展开点击悬浮
css动画效果代码淡入淡出折叠展开点击悬浮
|
移动开发
移动端开发H5页面点击按钮后出现闪烁或黑色背景的解决办法
移动端开发H5页面点击按钮后出现闪烁或黑色背景的解决办法
QT 事件过滤器实现鼠标悬浮时两个按钮背景互换
QT 事件过滤器实现鼠标悬浮时两个按钮背景互换
QT 事件过滤器实现鼠标悬浮时两个按钮背景互换