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






相关文章
|
6月前
高亮提示、聚焦控件并滚动到浏览器中刚刚好可以查看到该控件的位置
高亮提示、聚焦控件并滚动到浏览器中刚刚好可以查看到该控件的位置
|
索引 容器
Bootstrap4----网络系统、图像形状、轮播、滚动监听、多媒体对象、下拉菜单导航及按钮
Bootstrap4----网络系统、图像形状、轮播、滚动监听、多媒体对象、下拉菜单导航及按钮
|
算法 Windows
Winform控件优化之实现无锯齿的圆角窗体(或任意图形的无锯齿丝滑的窗体或控件)【借助LayeredWindow】
在一般能搜到的所有实现圆角窗体的示例中,都有着惨不忍睹的锯齿...而借助于Layered Windows,是可以实现丝滑无锯齿效果的Form窗体的,其具体原理就是分层窗体....
1590 0
Winform控件优化之实现无锯齿的圆角窗体(或任意图形的无锯齿丝滑的窗体或控件)【借助LayeredWindow】
|
3月前
|
前端开发 JavaScript
基于Vue3实现鼠标按下某个元素进行拖动,实时改变左侧或右侧元素的宽度,以及点击收起或展开的功能
本文介绍了如何在Vue3项目中实现一个鼠标拖动调整元素宽度的功能,并展示了点击按钮收起或展开侧边栏的效果,提供了完整的实现代码和操作演示。
550 0
基于Vue3实现鼠标按下某个元素进行拖动,实时改变左侧或右侧元素的宽度,以及点击收起或展开的功能
|
6月前
|
定位技术 iOS开发
在地图页面,自动布局控件开始是隐藏或在屏幕外需要正常显示时再为正常的显示状态的,需要在显示之前加入
在地图页面,自动布局控件开始是隐藏或在屏幕外需要正常显示时再为正常的显示状态的,需要在显示之前加入
47 0
|
6月前
简单讲述ondragstart、drag、ondragend、ondragenter、ondragover、ondrop、ondragleave七个与拖拽相关的监听事件,并运用实现拖拽过程放置样式变化
简单讲述ondragstart、drag、ondragend、ondragenter、ondragover、ondrop、ondragleave七个与拖拽相关的监听事件,并运用实现拖拽过程放置样式变化
|
6月前
【sgDragMove】自定义组件:自定义拖拽组件,仅支持拖拽、设置吸附屏幕边界距离。
【sgDragMove】自定义组件:自定义拖拽组件,仅支持拖拽、设置吸附屏幕边界距离。
|
图形学
|
移动开发
移动端开发H5页面点击按钮后出现闪烁或黑色背景的解决办法
移动端开发H5页面点击按钮后出现闪烁或黑色背景的解决办法
|
前端开发 JavaScript Serverless
移动端弹出阴影遮罩的几点问题和解决方法
在做移动端的立即购买页面时,点击底部固定栏立即购买按钮需要弹出一个阴影遮罩,在遮罩顶部有一个固定在底部的页面,所以总共是3层页面:最底层浏览页->阴影遮罩页->最上层的立即购买选择规格数量页;效果如下图:
226 0
移动端弹出阴影遮罩的几点问题和解决方法