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

盼望Meego火起来。

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

1、

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

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

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

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

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

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

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

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

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

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

5、Loader的 onStatusChanged和onLoaded事件

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

QML之使用Loader加载QML组件的更多相关文章

  1. QML中文件的加载(三种方法)

    在这里小小总结一下QML文件中如何加载QML文件与JavaScript文件. 1.QML文件中加载JavaScript文件 语法: import <ModuleIdentifier> &l ...

  2. Vue动态加载异步组件

    背景: 目前我们项目都是按组件划分的,然后各个组件之间封装成产品.目前都是采用iframe直接嵌套页面.项目中我们还是会碰到一些通用的组件跟业务之间有通信,这种情况下iframe并不是最好的选择,if ...

  3. as3 Loader 加载资源后内存泄露无法释放的问题。

    本人用Loader加载外部一个swf.之后unloadAndStop,Flash概要分析发现,内存没有被释放. 网上搜了一大堆文章,要么就是加载bitmapdata之后,自己dispose,要么就是加 ...

  4. Loader加载器

    今天学到了这个Loader,浅谈一下自己的看法: 1.定义 Loader是一个加载器,可以用来它访问数据,可以看做访问数据的机器(好比挖掘机).装再器从android3.0开始引进,它使得在activ ...

  5. [ActionScript 3.0] AS3.0 Loader加载子swf时是否需要指定新的应用程序域ApplicationDomain

    实际应用中, Loader加载子swf时是否需要指定新的应用程序域ApplicationDomain,需要择情况而定. 1.如果在本地将项目位置添加到flashplayer受信任位置(上一篇文章所述) ...

  6. (转载)Flash Loader加载完成不发送COMPLETE和ERROR事件的问题分析

    (转载)http://blog.dou.li/flash-loader%E5%8A%A0%E8%BD%BD%E5%AE%8C%E6%88%90%E4%B8%8D%E5%8F%91%E9%80%81co ...

  7. 1.引入必要的文件 2.加载 UI 组件的方式 4.Parser 解析器

    //引入 jQuery 核心库,这里采用的是 2.0 <scripttype="text/javascript"src="easyui/jquery.min.js& ...

  8. win7 Visual Studio 2008 安装程序时出现“ 加载安装组件时遇到问题。取消安装。”处理方法

    win7 Visual Studio 2008 安装程序时出现“ 加载安装组件时遇到问题.取消安装.”处理方法 vs2008试用期到期,卸载.重新安装都会出现“ 加载安装组件时遇到问题.取消安装.”无 ...

  9. netcore实践:跨平台动态加载native组件

    缘起netcore框架下实现基于zmq的应用. 在.net framework时代,我们进行zmq开发由很多的选择,比较常用的有clrzmq4和NetMQ. 其中clrzmq是基于libzmq的Int ...

随机推荐

  1. C# TextBox中的Validating与Validated事件[转]

    validating事件发生的时候,值还没有被真正存入,所以是空的,而validated事件发生的时候,值已经存入,所以能取出:一个相当于值的前因,一个相当于值的后果.也就是说,可以用validati ...

  2. 第七十九,CSS3背景渐变效果

    CSS3背景渐变效果 学习要点: 1.线性渐变 2.径向渐变 本章主要探讨HTML5中CSS3背景渐变功能,主要有两种渐变方式:线性渐变和径向 (放射性)渐变. 一.线性渐变 linear-gradi ...

  3. jQuery进行简单验证的正则表达式

    下面都是一些比较常用简单的验证,像那些特殊的复杂的情况这里不进行考虑 1.验证电话号码或者手机号码 ? 1 2 3 4 5 6 7 8 9 10 /**  * 验证电话号码(手机号码+电话号码)  * ...

  4. MongoDB高级操作

    参考MongoDB菜鸟教程 一.$type操作符 MongoDB 中可以使用的类型如下表所示: 类型 数字 备注 Double 1   String 2   Object 3   Array 4   ...

  5. sharepoint2010配置个人网站的offical方法 来自Jetluning的专栏

    Configuring My Site in SharePoint 201   SharePoint My Sites are commonly referred to as “Facebook fo ...

  6. 2015 ACM/ICPC Asia Regional Shenyang Online

    1001 Traversal 1002 Best Solver 1003 Minimum Cut 类似于POJ 3417的做法. 考虑每条新边对树边的覆盖次数. 每条树边被覆盖的次数其实就是断裂这条树 ...

  7. SQL STUFF函数 拼接字符串

    今日看到一篇文章,是关于和并列的,也研究了下,还是不错的 要这种效果. create table tb(idint, value varchar(10)) insert into tbvalues(1 ...

  8. TortoiseGit保存用户名及密码

    保存密码方式如下,需要setting中填写自己的名字,Email地址,并在.gitconfig中 [credential] 中设置helper = store

  9. arguments对象,caller 和 callee

    arguments对象是比较特别的一个对象,arguments非常类似Array,但实际上又不是一个Array实例. 它指的是函数对象里的参数,且只能在函数内部使用. 使用 检测函数的参数个数,引用属 ...

  10. Flask -- 会话

    会话session 在不同请求间存储特定用户的信息.它是在 Cookies 的基础上实现的,并且对 Cookies 进行密钥签名.这意味着用户可以查看你 Cookie 的内容,但却不能修改它,除非用户 ...