zoukankan      html  css  js  c++  java
  • QML笔记

    文章钢要

    1、qml基础知识

    2、qml语言技巧

    一、QML basic types

    QML Language提供的基础类型:int ,bool,string,double,real,var,url,enumeration,list,color

    QML Modules(QtQuick)提供的基础类型:date, point ,rect,size,Qt,QtObject,Component,Connections,Bingding

    导出到QML环境中的C++类型。

    注意事项:

    1、list类型必须和object类型关联使用

    2、enumeration必须 must be defined by a registered QML object type。

    3、id属性首字符必须是小写字母或下划线

    4、列表属性(list)是包含在【】内,以逗号分隔的多个元素集合。和js的数组类似。

    5、信号处理器on<Signal>形式:onClicked:{ Qt.quit(); }

    6、附加属性如:item{  Keys.enabled:false ;} ,Component.onCompleted:console.log("hello Qt");

    二、QML入门

    程序框架一:QQmlApplicationEngine 搭配 Window,QML有控制权

    main(int argc,char *argv[]){
      QGuiApplication app(argc,argv);
      QQmlApplicationEngine engine;
      engine.load(QUrl(QStringListeral("qrc://main.qml")));
      return app.exec();//主循环
    }
    import QtQuick.Window 2.1
    Window{
      360;
     height:240; MouseArea{ anchors.fill:parent; onClicked:{ Qt.quick(); } } Text{ text:"Hello Qt Quick"; anchors.centerIn:parent; } }

    程序框架二:Item作为QML根对象 (QQuickView 搭配 Item ),c++有控制权

    main(int argc, char * argv[]){
          QGuiApplication app(argc,argv);
          QQuickView viewer;
          viewer.setSource(QUrl("qrc://main.qml"));
          viewer.show();
          return app.exec();
    }    

    Window用于创建一个与OS相关的顶层窗口,text,Rectangle,image都是在里面表演的演员。

    Rectangle :color和gradient同时设置,那么gradient生效。如果设置color的属性为transparent,那么可以达到只绘制边框不填充的效果。

          border.width设置边框的宽度,border.color指定边框颜色 

    color:“#RRGGBB”,“#AARRGGBB”,Qt.rgba(0.8, 0.6, 0.4, 1.0)、Qt.lighter()

      类型参考:https://doc.qt.io/qt-5/qml-color.html

    item: 自带通用属性x,y,width,height,anchoring,button处理

       本身不可见,可以用它来分组其他可视图元

    anchors锚布局:top,bottom,verticalCenter,horizontalCenter,baseline

    响应按键:通过附加属性Keys来处理按键。特定按键信号returnPressed,普通信号pressed和released

        Keys.enabled:true

        keys.onEscapePressed:Qt.quit();

        Keys.onBackPressed:Qt.quit();

        keys.onPressed:{

        event参数:KeyEvent类型。

        event.key :case  Qt.Key_0, Qt.Key_1,,Qt.Key_2,,Qt.Key_3,,Qt.Key_4,,Qt.Key_A。等}

    Text:有font,text,color,elide(省略),textFormat,wrapMode,style等属性

    Button:activeFocusOnPress属性指定按钮被按下时获取焦点。

    ButtonStyle:有background(Component类型),control,label三个属性

        style:ButtonStyle{ background: Rectangle { } }

    Image: fillMode属性可以设置图片的填充模式,Image.Stretch(拉伸),PreserveAspectFit(等比缩放),Image.PreserveAspectCrop(最大填充,必要时裁剪)

        Tile(水平和垂直两个方向平铺,就像贴瓷砖那样),TileVertically(垂直平铺),TileHorizontally(水平平铺),Pad(原样不变)

        Image默认是阻塞加载图片,可以设置asynchronous属性true开启异步。当status的值为Image.Ready时 可屏蔽加载等候界面。

        Image{ source: "images/myImage.png")}

        Image{ onStatusChanged:{ } } //status属性变化时会发射statusChanged信号

    BusyIndicator:一个等待图元,耗时操作时使用

        running属性:true时显示

        style:可定制样式,默认是一个转圈圈的动画

    FileDialog:文件对话框,通过open() 方法设置visible为true。

        selectExisting:表示选择已有文件或文件夹

        selectMultiple:ture表示多选

        nameFilters:用于设定一个过滤器列表。nameFilters:[ "Image Files (*.jpg *.png *.gif) , “Bitmap Filter (*.bmp)” , " * (*.*)" ]  //过滤器列表

        selectedNameFilter:"Image Files (*.jpg  *.png  *.gif)";  //保存用户选择的过滤器

        fileUrl:保存该文件的路径,如果选择多个文件则该属性为空。

        fileUrls:是一个列表

        folder:文件夹的位置

    js 语法:Undefined类型只有一个值:undefined,声明的变量没有初始化时,就是该值

        如:var oneValue; if( oneValue == undefined){  } // 函数无明确返回值时,返回的也是undefined

        Null类型也只有衣蛾值,null   // property var reminderWindow:null

        类型转换:toString() ; // var integer = 3.1415;  console.log(integer.toString());

            parseInt()和parseFloat()把非数字的String转换成数字。

        强转:Boolean(),Number(),String()

     对象:Object是所有js类的基类,isPrototypeOf(object) ,判断对象是否为另一个对象的原型

          propertyIsEnumerable(property),判断给定的属性是否可以用for...in 语句进行枚举。

          toString(),返回对象的字符串表示,对于Rectangle.toString()返回其对应的C++类型名字或QML类型名字。

          valueOf(),返回最适合该对象的原始值,对于许多类,该方法返回的值都与toString一样。

        动态增加属性:var person = new object();   person.name = "zhangsan";  person.year = 20;

        动态增加方法:person.printInfo = function printInfo() {  };

        使用数组下标访问方法:person["printInfo"]() ; //这个有点意思

        for ...in :访问对象属性: for (var prop in person) {  console.log(prop  , " , ",  person[prop] )};

        字面量表示法:var person = { "name" : "zhangsan" ; "year" : 20 }

        console提供定时器,可以用于计算代码耗时

          console.time(tag) //启动定时器 ,字符串类型的tag是必需的

          console.timeEnd(tag) // 停止计时器

    三、测试

  • 相关阅读:
    漫谈 C++ 的 内存堆 实现原理
    我发起了一个 .Net 开源 数据库 项目 SqlNet
    谈谈 数据库原理
    论 数据库 B Tree 索引 在 固态硬盘 上 的 离散存储
    论 东坡肉 和 红烧肉 的 区别
    浅谈 操作系统原理
    引子 初识
    P2P Downloader
    利用 MessageRPC 和 ShareMemory 来实现 分布式并行计算
    MessageRPC
  • 原文地址:https://www.cnblogs.com/daiker/p/QML.html
Copyright © 2011-2022 走看看