博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
QML之使用Loader加载QML组件
阅读量:6382 次
发布时间:2019-06-23

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

呵呵,今晚是边看《裸婚时代》边敲代码,那电影看得...!钱真他妈不是个东西.

盼望Meego火起来。

QML的Loader元素经常备用来动态加载QML组件。可以使用source属性或者sourceComponent属性加载。这个元素最有用的地方是它能在qml组件需要的时候再创建,即延迟创建QML的时间。

 

1、

 

[css]   
 
  1. main.qml  
  2. ------------------------------------  
  3. import QtQuick 1.0  
  4.   
  5. Item {  
  6.     property bool isFirst : false;  
  7.     width: 200  
  8.     height: 200  
  9.   
  10.     Loader {  
  11.         id: pageLoader  
  12.     }  
  13.   
  14.     MouseArea {  
  15.         anchors.fill: parent  
  16.         onClicked: changePage();  
  17.     }  
  18.   
  19.     function changePage() {  
  20.         if(isFirst) {  
  21.             pageLoader.source = "Page1.qml"  
  22.         } else {  
  23.             pageLoader.source = "Page2.qml"  
  24.         }  
  25.   
  26.         isFirst = !isFirst;  
  27.     }  
  28.   
  29. }  
  30.   
  31.   
  32. Page1.qml  
  33. -------------------------------------  
  34. import QtQuick 1.0  
  35.   
  36. Rectangle {  
  37.     width: 100  
  38.     height: 62  
  39.     Text {  
  40.         anchors.centerIn: parent  
  41.         text: "Page1 Test"  
  42.     }  
  43. }  
  44.   
  45.   
  46. Page2.qml  
  47. ---------------------------------------  
  48. import QtQuick 1.0  
  49.   
  50. Rectangle {  
  51.     width: 100  
  52.     height: 62  
  53.     Text {  
  54.         anchors.centerIn: parent  
  55.         text: "Page1 Test"  
  56.     }  
  57. }  

 

 

2、上面的代码就能界面在Page1和Page2之间切换了,别忘了还能使用sourceComponent属性:

 

[css]   
 
  1. main.qml  
  2. --------------------------------------  
  3. import QtQuick 1.0  
  4.   
  5. Item {  
  6.     property bool isFirst : false;  
  7.     width: 200  
  8.     height: 200  
  9.   
  10.     Loader {  
  11.         id: pageLoader  
  12.         sourceComponent: rect  
  13.     }  
  14.   
  15.     MouseArea {  
  16.         anchors.fill: parent  
  17.         onClicked: changePage();  
  18.     }  
  19.   
  20.     function changePage() {  
  21.         if(isFirst) {  
  22.             pageLoader.source = "Page1.qml"  
  23.         } else {  
  24.             pageLoader.source = "Page2.qml"  
  25.         }  
  26.   
  27.         isFirst = !isFirst;  
  28.     }  
  29.   
  30.     Component {  
  31.         id: rect  
  32.         Rectangle {  
  33.             width: 200  
  34.             height: 50  
  35.             color: "red"  
  36.             Text {  
  37.                 text: "Default Page"  
  38.                 anchors.fill: parent  
  39.             }  
  40.         }  
  41.     }  
  42.   
  43. }  

 

上面的代码实现了默认加载组件功能.

 

 

3、接收来自加载的qml发出的信号

使用Connections元素可以接收到任何发送自加载组件的信号。

 

[css]   
 
  1. main.qml  
  2. ---------------------------------------  
  3. import QtQuick 1.0  
  4.   
  5. Item {  
  6.     property bool isFirst : false;  
  7.     width: 200  
  8.     height: 200  
  9.   
  10.     Loader {  
  11.         id: pageLoader  
  12.         source: "Page1.qml"  
  13.     }  
  14.   
  15.   
  16.     Connections {  
  17.         target: pageLoader.item  
  18.         onMessage: console.log(msg);  
  19.     }  
  20.   
  21. }  
  22.   
  23. Page1.qml  
  24. ----------------------------------------------  
  25. import QtQuick 1.0  
  26.   
  27. Rectangle {  
  28.     id: myItem  
  29.     signal message(string msg)  
  30.     width: 100; height: 100  
  31.   
  32.     MouseArea {  
  33.         anchors.fill: parent  
  34.         onClicked: myItem.message("clicked!");  
  35.     }  
  36. }  

 

 

 

4、加载与被加载组件中都有相同的事件,那么需要设置Loader的属性focus为true,且设置被加载组件 focus: true才能让事件不被传播到被加载组件。

 

 

[css]   
 
  1. main.qml  
  2. -------------------------------------  
  3. import QtQuick 1.0  
  4.   
  5. Item {  
  6.     property bool isFirst : false;  
  7.     width: 200  
  8.     height: 200  
  9.   
  10.     Loader {  
  11.         id: pageLoader  
  12.         source: "Page2.qml"  
  13.         focus: true  
  14.     }  
  15.     
  16.     Keys.onPressed: {  
  17.         console.log("Captured: ", event.text);  
  18.          event.accepted = true;  
  19.     }  
  20.   
  21. }  
  22.   
  23.   
  24. Page2.qml  
  25. ---------------------------------  
  26. import QtQuick 1.0  
  27.   
  28. Rectangle {  
  29.     width: 100  
  30.     height: 62  
  31.     Text {  
  32.         anchors.centerIn: parent  
  33.         text: "Page2 Test"  
  34.     }  
  35.     focus: true  
  36.     Keys.onPressed: {  
  37.         console.log("Loaded item captured: ", event.text);  
  38.         event.accepted = true;  
  39.     }  
  40. }  

 

 如果在Page2.qml中去掉event.accepted = true;那么main.qml和Page2.qml都会接收到按键事件,也就是说按键事件会传播到main.qml中

 

5、Loader的 onStatusChanged和onLoaded事件

 

 

[css]   
 
  1. main.qml  
  2. -------------------------------------  
  3. import QtQuick 1.0  
  4.   
  5. Item {  
  6.     property bool isFirst : false;  
  7.     width: 200  
  8.     height: 200  
  9.   
  10.     Loader {  
  11.         id: pageLoader  
  12.         source: "Page2.qml"  
  13.         focus: true  
  14.         onStatusChanged:  console.log(pageLoader.status == Loader.Ready)  
  15.         onLoaded: console.log("Loaded")  
  16.     }  
  17.   
  18.     MouseArea {  
  19.         anchors.fill: parent  
  20.         onClicked: changePage();  
  21.     }  
  22.   
  23.     function changePage() {  
  24.         if(isFirst) {  
  25.             pageLoader.source = "Page1.qml"  
  26.         } else {  
  27.             pageLoader.source = "Page2.qml"  
  28.         }  
  29.   
  30.         isFirst = !isFirst;  
  31.     }  
  32.   
  33.     Component {  
  34.         id: rect  
  35.         Rectangle {  
  36.             width: 200  
  37.             height: 50  
  38.             color: "red"  
  39.             Text {  
  40.                 text: "Default Page"  
  41.                 anchors.fill: parent  
  42.             }  
  43.         }  
  44.     }  
  45.   
  46.     Keys.onPressed: {  
  47.         console.log("Captured: ", event.text);  
  48.          event.accepted = true;  
  49.     }  
  50.   
  51. }  

 

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

你可能感兴趣的文章
iOS--collectionView简单瀑布流的实现
查看>>
我想,我需要试试
查看>>
app异常处理
查看>>
Redis 中三种特殊的数据类型
查看>>
Python篇-绘图
查看>>
Cris 的 Spark SQL 笔记
查看>>
Computer Vision 杂志对何恺明 Rethinking ImageNet Pre-training 的最新评论
查看>>
阿里云支付:可以更换绑定的支付宝账号吗?
查看>>
学web前端从哪里开始学起呢-好程序员
查看>>
5G网络数据中心系统需要什么光模块?
查看>>
kinmall分析区块链在去中心化和中心化要思考的问题
查看>>
Eclipse修改log缓冲大小
查看>>
C#开发奇技淫巧二:根据dll文件加载C++或者Delphi插件
查看>>
RESTful与网络请求过程
查看>>
.NET Core实战项目之CMS 第五章 入门篇-Dapper的快速入门看这篇就够了
查看>>
NATS连线协议详解
查看>>
vue插槽slot
查看>>
日历类报表可以这样实现
查看>>
linux常用命令
查看>>
CirruScript 写的: 函数式编程另类指南
查看>>