Qt Quick之可视化坐标系

本文介绍了QtQuick中的可视化坐标系统,包括Item坐标系和场景坐标系。Item坐标系以左上角为原点,X轴向右,Y轴向下。场景坐标系则基于窗口左上角。转换坐标可通过Item::mapFromItem和Item::mapToItem函数完成。示例展示了矩形之间的相对位置,帮助理解坐标转换概念。
摘要由CSDN通过智能技术生成

概念----Qt Quick中的可视化坐标系

Item坐标系

在Qt Quick中,默认的可视化坐标系就是Item坐标系。该笛卡尔坐标系的原点在Item的左上角。X轴朝右,Y轴朝下,因此右下角点的坐标为(width,height)。

单个item的位置通过其父的坐标系统中指定。意味着对于非兄弟item的坐标值x,y需要通过转化到同一坐标系下。场景坐标系常常用作中间坐标系,来完成这个转换。

场景坐标系

场景坐标系坐标原点位于场景渲染的窗口的左上角。窗口中,场景坐标系常常与根节点的item坐标系重合。

使用item的函数可以将item坐标转化到场景坐标系下的坐标。详见Item::mapFromItem和Item::mapToItem实现到场景坐标系的转换或者到其他Item坐标系的转换。

样例

下面的QML代码创建一组矩形,点用来标记:

Rectangle {
      width: 200
      height: 200
      color: "red"

      Rectangle {
          x: 100
          y: 100
          width: 100
          height: 100
          color: "blue"

          Rectangle {
              width: 50
              height: 50
              color: "green"
          }
      }
  }

 

在这张图片中,黑色的点位于红色矩形的Item坐标系的原点。如果红色矩形是场景的根Item,黑色的点也是场景坐标系的原点。

蓝色矩形的位置在白色的点处,坐标(100,100)是相对于红色矩形的左上角。

绿色矩形没有显式指定x,y值,默认位置为(0,0)。由于它处于其父坐标系的原点处,它处在蓝色矩形的左上角位置。也是白色的点所在的红色矩形坐标系下的(100,100)点。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值