qml鼠标拖动事件,拖动到对应位置给目标换色

Item {
    id:container
    objectName: "rootRect";
    width: 800;
    height: 500;

    property variant arry: ["red","#00ff00","yellow","black","#f046f0"]

    property variant temp: [0,0]
    Row{
        spacing: 10
        Repeater{
            id:rep
            model: arry.length
            Rectangle{
                color:arry[index]
                width: 30
                height: width
                Drag.active: dragArea.drag.active
                Drag.hotSpot.x: 10
                Drag.hotSpot.y:10
                Drag.source: rep.itemAt(index)
                MouseArea{
                    id:dragArea
                    anchors.fill: parent
                    drag.target: parent
                    acceptedButtons: Qt.LeftButton|Qt.RightButton

                    onPressed: {
                        if(mouse.button===Qt.LeftButton)
                        {
                            temp[0]=rep.itemAt(index).x;
                            temp[1]=rep.itemAt(index).y;
                        }
                    }

                    onReleased: {
                        if(mouse.button===Qt.LeftButton)
                        {
                            rep.itemAt(index).x=temp[0];
                            rep.itemAt(index).y= temp[1];
                        }
                    }
                }
            }
        }
    }

    DropArea{
        x:375
        y:275
        width: 50
        height: 50
        Rectangle{
            id:area;anchors.fill: parent
            border.color: "black"
        }
        onEntered: area.color=drag.source.color
    }

}

 

转载于:https://my.oschina.net/urlove/blog/3082827

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值