博客
关于我
qml场景切换
阅读量:706 次
发布时间:2019-03-21

本文共 1979 字,大约阅读时间需要 6 分钟。

他们尝试使用单一根变量来统一控制多个界面的显示和切换,但在实际应用中遇到了一些问题。以下是针对这些问题的详细分析和解决方案:

  • 理解错误信息

    • 第一次错误提示:“QML Button: Cannot anchor to an item that isn't a parent or sibling.”
    • 第二次错误提示类似。这两种错误通常是由于在编号的嵌套结构中试图将按钮定位到一个不是父节点或兄弟的项目上。
  • 错误原因分析

    这些错误表明按钮在尝试定位时,所选的目标项目不是其父节点或兄弟节点。尽管在理论上可以拖动按钮并将其定位到目标项目上,但在实际编码中需要注意目标项目的层级结构。

  • 解决方法

    • 调整定位方式:不要使用anchors来定位按钮,而是使用xy属性将其绝对定位在屏幕上。这是因为每个界面都是一个独立的节点,它们可能不在同一个父层级上。
    • 统一根节点:确保所有的界面都具有相同的根节点。比如,在主.qml中,可以定义一个root节点,它是所有界面的共同父节点。
    • 使用Stack进行转换:使用QtQuick的Stack组件来管理多个界面。这样可以更直观地控制哪一个界面是可见的。
  • 优化代码结构

    以下是一个简化的解决方案示例:

    import QtQuick 2.5import QtQuick.Controls 1.4Rectangle {    id: root    width: 640    height: 480    color: "red"    property int viewShow: 0}Stack {    id: stack    anchors.fill: parent}View1 {    id: view1    anchors.fill: parent    visible: root.viewShow == 1}View2 {    id: view2    anchors.fill: parent    visible: root.viewShow == 2}View3 {    id: view3    anchors.fill: parent    visible: root.viewShow == 3}Button {    text: "1"    anchors.right: parent.right    anchors.top: parent.top    onClicked: {        root.viewShow = 1;        console.log("viewShow = ", viewShow);    }}Button {    text: "2"    anchors.right: parent.right    anchors.top: parent.top    onClicked: {        root.viewShow = 2;        console.log("viewShow = ", viewShow);    }}Button {    text: "3"    anchors.right: parent.right    anchors.top: parent.top    onClicked: {        root.viewShow = 3;        console.log("viewShow = ", viewShow);    }}Button {    text: "4"    anchors.right: parent.right    anchors.top: parent.top    onClicked: {        root.viewShow = 0;        console.log("viewShow = ", viewShow);    }}
  • 注意事项

    • 使用Stack组件可以更直观地管理多个界面的切换。
    • 每个界面应该具有相同的根节点,以便访问root.viewShow属性。
    • 当切换界面时,确保在根节点上更新viewShow值。
    • 在实际应用中,可能需要添加过渡效果来提升用户体验。
  • 测试验证

    • 在单独测试每个界面时,确保按钮的定位正确,并且点击事件能够正确切换视图。
    • 检查root.viewShow的值是否正确更新,并且每个界面的visible属性是否受到影响。
  • 进一步优化

    • 如果有更多的界面(例如4个或更多),可以将其分为多个页面,并使用Stack或其他布局组件来管理视图切换。
    • 确保所有按钮的定位方式正确,避免出现类似“无法定位到父节点或兄弟”的错误。
  • 通过以上方法,可以有效解决按钮定位错误的问题,同时实现多个界面的组件化管理和统一的视图切换控制。

    转载地址:http://ypwrz.baihongyu.com/

    你可能感兴趣的文章
    Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
    查看>>
    MySQL 是如何加锁的?
    查看>>
    MySQL 是怎样运行的 - InnoDB数据页结构
    查看>>
    mysql 更新子表_mysql 在update中实现子查询的方式
    查看>>
    MySQL 有什么优点?
    查看>>
    mysql 权限整理记录
    查看>>
    mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
    查看>>
    MYSQL 查看最大连接数和修改最大连接数
    查看>>
    MySQL 查看有哪些表
    查看>>
    mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
    查看>>
    MySql 查询以逗号分隔的字符串的方法(正则)
    查看>>
    MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
    查看>>
    mysql 查询,正数降序排序,负数升序排序
    查看>>
    MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
    查看>>
    mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
    查看>>
    mysql 死锁(先delete 后insert)日志分析
    查看>>
    MySQL 死锁了,怎么办?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 添加列,修改列,删除列
    查看>>