qml自定义组件

不管是component还是分文件编写的一个自定义组件,遵循如下:

a:不管哪一级的子对象 都可以直接调根节点下的方法和属性

b:不管哪一级的子对象 调用非根节点的方法和属性,前面要加上该节点的id,即id.方法()或id.属性的形式



import QtQuick 2.0
import QtQuick.Controls 2.12
Rectangle{
    id:yu
    x:15
    y:135
    width:150
    height: 100
    color: "green"
    property string txt: "xuhaitao"
    function jiafa(a ,b){
        btn02.xy02();

        return a+b
    }

    function da(){
        console.log("da ...")
    }

    Button{
        id:btn01
        width:100
        height: 50
        text:txt

        function xy01(){
            console.log("btn01 xy01  done...")
        }

        Button{
            id:btn02
            x:180
            width:50
            height: 50
            text:txt

            function xy02(){
                btn01.xy01();
                da();
                console.log("btn02 xy02  done...")
            }
        }

    }

}
import QtQuick 2.12
import QtQuick.Window 2.12
import QtQuick.Controls 2.12
import QtQuick 2.7
import QtQuick.Layouts 1.3

Window {
    visible: true
    width: 640
    height: 480
    title: qsTr("Hello World")


    HaHa{
        id:rect01
    }



    Button{
        id:btn01
        text: "dian ji"
        x:100
        onClicked: {
            console.log(rect01.jiafa(18,91))
            rect01.txt="xs"
        }
    }
}

运行结果:

FR:徐海涛(hunkxu)

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
假设需求是需要一个带有圆角边框的按钮,我们可以通过自定义组件来实现。 首先,创建一个新的 QML 文件,命名为 `RoundButton.qml`。在该文件中,定义一个带有圆角边框的矩形,并在其内部放置一个按钮。 ``` import QtQuick 2.0 import QtQuick.Controls 2.0 Item { property alias text: button.text property alias font: button.font property alias textColor: button.textColor property alias backgroundColor: button.backgroundColor property alias hoverEnabled: button.hoverEnabled Rectangle { id: background color: backgroundColor radius: 10 border.width: 2 border.color: "black" width: button.width + 20 height: button.height + 20 Button { id: button anchors.centerIn: parent text: "Button" font.pixelSize: 24 textColor: "white" hoverEnabled: true background: Rectangle { color: hoverEnabled ? "#2c3e50" : "#34495e" radius: 10 } } } } ``` 在这个自定义组件中,我们提供了一些属性,如文本、字体、文本颜色、背景颜色和悬停效果等。通过这些属性,可以在使用该组件时,方便地设置组件的各种属性。 接下来,在主 QML 文件中,我们可以使用这个自定义组件,像使用其他 QML 控件一样。 ``` import QtQuick 2.0 Rectangle { width: 400 height: 400 RoundButton { text: "Click me" font.pixelSize: 20 backgroundColor: "lightblue" textColor: "white" onClicked: console.log("Button clicked") } } ``` 在这个例子中,我们将自定义组件 `RoundButton` 添加到主 QML 文件中,并设置了它的一些属性,如文本、字体、背景颜色和文本颜色等。当用户点击按钮时,会触发 `onClicked` 信号,并在控制台输出一条信息。 通过这样的方式,我们可以方便地使用自定义组件,实现特定的需求,并且可以在多个项目中重复使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值