QML StackLayout

这篇博客介绍了如何在QML中利用QMLStackLayout组件进行页面切换。通过示例代码展示了如何创建菜单按钮并动态添加到布局中,以及如何在点击按钮时改变StackLayout的当前页面。示例还包含了颜色生成器的使用,为每个页面设置不同的背景颜色。
摘要由CSDN通过智能技术生成

QML StackLayout

示例

import QtQuick 2.14
import QtQuick.Window 2.14
import QtQuick.Controls 2.5
import QtQuick.Layouts 1.15
import "./common.js"  as FunJs

Window
{
    id: window
    width: 600
    height: 480
    visible: true
    title: "QML Demo"

    Item
    {
        id: rootItem
        anchors.fill: parent
        property var colorBuilder: FunJs.getColorBudider(Qt.rgba)

        Row
        {
            id: header
            Component
            {
                id: menuButton
                Button
                {
                    required property string menuText
                    required property var layout
                    required property int index

                    text: menuText
                    onClicked:
                    {
                        layout.currentIndex = index
                    }

                }
            }


            Component.onCompleted:
            {
                let munu = ["Home", "Help"]
                munu.forEach(function(item, index)
                {
                    menuButton.createObject(header, {layout:stacklayout, menuText:item, index: index})
                }
                )
            }
        }

        StackLayout {
            id: stacklayout
            anchors.top: header.bottom
            anchors.bottom: parent.bottom
            anchors.left: parent.left
            anchors.right: parent.right

           Component
           {
               id: pageComponent
               Rectangle{}
           }

           Component.onCompleted:
           {
               for(let i = 0; i < 2; ++i)
               {
                   pageComponent.createObject(stacklayout, {color: rootItem.colorBuilder()})
               }
           }
        }
    }
}
  • 效果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值