Qt文档阅读笔记-Qt Quick Controls - Wearable Demo实例解析

标签: Qt  C/C++  文档阅读笔记  C++  QML  文档阅读  

程序运行截图如下:

这个实例主要是用qml玩界面。

main.qml文件以及wearable.qml分别是由ApplicationWindow和StatckView。这个StackView用于做导航相关的。

代码如下:

  QQC2.ApplicationWindow {
      id: window
      ...
      header: NaviButton {
          id: homeButton
          ...
          onClicked: stackView.pop(null)
      }

      footer: NaviButton {
          id: backButton
          ...
          onClicked: stackView.pop()
      }

      QQC2.StackView {
          id: stackView
          ...
              onLaunched: stackView.push(page)
          }
      }

      DemoMode {
          stackView: stackView
      }

      DemoModeIndicator {
          id: demoModeIndicator
          y: settings.demoMode ? -height : -height * 2
          anchors.horizontalCenter: parent.horizontalCenter
          height: header.height
          z: window.header.z + 1
      }

      MouseArea {
          enabled: settings.demoMode
          anchors.fill: parent
          onClicked: {
              // Stop demo mode and return to the launcher page.
              settings.demoMode = false
              stackView.pop(null)
          }
      }
  }

wearable.cpp中应用QQuickStyle的风格:

 QQuickStyle::setStyle(QStringLiteral("qrc:/qml/Style"));

在C++代码中设置QQuickStyle风格是十分灵活的,他作用于整个应用。

 

通过实现qml/NaviButton.qml接口完成自定义button类型。在wearable.qml中home按钮以及back按钮都是自定义的。使用properties扩展可以实现控制滑动过度的相关功能:

  QQC2.AbstractButton {
      id: button

      property int edge: Qt.TopEdge
      property alias imageSource: image.source

      contentItem: Image {
          id: image
          ...
      }

      background: Rectangle {
          ...
      }

      transform: Translate {
          Behavior on y { NumberAnimation { } }
          y: enabled ? 0 : edge === Qt.TopEdge ? -button.height : button.height
      }
  }

图标绑定了Qt资源文件:/icons。index.theme文件包含了icon主题的内容:

 [Icon Theme]
  Name=Wearable
  Comment=Qt Quick Controls 2 Wearable Demo Icon Theme

  Directories=36x36,[email protected]

  [36x36]
  Size=36
  Type=Fixed

  [[email protected]]
  Size=36
  Scale=2
  Type=Fixed

同样在C++里的main函数中进行设置:

QIcon::setThemeName(QStringLiteral("wearable"));

Launcher页主要是使用了PathView这个组建。

  PathView {
      id: circularView

      signal launched(string page)
      ...
      model: ListModel {
          ListElement {
              title: qsTr("World Clock")
              icon: "worldclock"
              page: "WorldClock/WorldClockPage.qml"
          }
          ...
          ListElement {
              title: qsTr("Settings")
              icon: "settings"
              page: "Settings/SettingsPage.qml"
          }
      }

      delegate: QQC2.RoundButton {
          ...
          icon.width: 36
          icon.height: 36
          icon.name: model.icon
          ...
          onClicked: {
              if (PathView.isCurrentItem)
                  circularView.launched(Qt.resolvedUrl(page))
              else
                  circularView.currentIndex = index
          }
      }
      ...
  }

目前官方给出的信息中,个人觉得比较重要的就是这么多,后面将会对代码中的知识点进行分析。

版权声明:本文为qq78442761原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq78442761/article/details/103967263

智能推荐

HTML 表单元素的基本样式

HTML 表单元素的基本样式 原创 ixygj197875 发布于2018-02-22 17:48:53 阅读数 2296 收藏 更新于2018-05-20 15:35:58 分类专栏: 揭秘 CSS 揭秘 CSS 收起 表单元素主要包括 label、input、textarea、select、datalist、******、progress、meter、output等,以及对表单元素进行分组的 ...

php输出语句

php输出语句 常见的输出语句 echo(): 可以一次输出多个值,多个值之间用逗号分隔。echo是语言结构(language construct),而并不是真正的函数,因此不能作为表达式的一部分使用。 print(): 函数print()打印一个值(它的参数),如果字符串成功显示则返回true,否则返回false。 print_r(): 可以把字符串和数字简单地打印出来,而数组则以括起来的键和值...

工厂模式

简介 常见的实例化对象模式。 用工厂方法替代new操作的一种模式。 当我们使用new操作实例化对象时,调用构造函数完成初始化。若初始化仅是进行赋值等简单的操作,写入构造函数即可。但如果初始化时需要执行一长串复杂的代码,将多个工作装入一个方法,是不妥的。 创建实例与使用实例分离。将创建实例所需的大量初始化工作从基类的构造函数中分离出去。 简单工厂模式、工厂方法模式针对的是一个产品等级结构;而抽象工厂...

B1105 Spiral Matrix (画图)

B1105 Spiral Matrix (25分) //第一次只拿了21分 矩阵的长和宽,求最大因子,从sqrt(num)开始枚举. 每次循环一次,s++,t--,d--,r++ 测试点四运行超时,是因为输入一个数字的时候,需要直接输出这个数字。//1分 测试点二运行超时,最后一个数字不必再while循环一次,直接输出即可。//3分 最后一个测试点卡了好久/(ㄒoㄒ)/~~ 螺旋矩阵...

Java基础=>String,StringBuffer与StringBuilder的区别

字符串常量池 什么是字符串常量池? JVM为了减少字符串对象的重复创建,其维护了一块特殊的内存,这段内存被称为字符串常量池(存储在方法区中)。 具体实现 当代码中出现字符串时,JVM首先会对其进行检查。 如果字符串常量池中存在相同内容的字符串对象,如果有,则不再创建,直接返回这个对象的地址返回。 如果字符串常量池中不存在相同内容的字符串对象,则创建一个新的字符串对象并放入常量池,并返回新创建的字符...

猜你喜欢

java调用其他java项目的Https接口

项目中是这样的: 用户拿出二维码展示,让机器识别二维码, 机器调用开门的后台系统接口, 然后开门的后台系统接口需要调用管理系统的接口, 管理系统需要判断能不能开门.这两个系统是互相独立的.当时使用http调用是没有问题的.当时后来要求必须用https.废话不说,直接代码: 我的项目中调用的是 HttpsUtils.Get(utlStr) 这个接口 开门系统接口如下图:   管理系统的接口...

Hadoop1.2.1全分布式模式配置

一 集群规划 主机名            IP                               安装的软件 &nbs...

Go语言gin框架的安装

尝试安装了一下gin,把遇到的一些小问题来记录一下 安装步骤 首先来看看官方文档,链接点这里 可以看到安装步骤很简单,就一句话 在命令行中输入这句话运行等待就好。 问题来了,因为墙的问题,go get会很慢,所以命令行里面半天什么反应也没有,不要急,慢慢等着就会看到gin-gonic/gin这个目录出现 这个时候命令行还是没有结束,表示还在下一些东西。有的时候可能心急的人就停了(比如我),然后写个...

uni-app表单组件二

input(输入框) 属性名 类型 说明 平台差异 value String 输入框的初始内容 type String input 的类型 password Boolean(默认false) 是否是密码类型 placeholder String 输入框为空时占位符 placeholder-style String 指定 placeholder 的样式 placeholder-class Strin...

深入理解 JavaScript 代码执行机制

深入理解 JavaScript 代码执行机制 前言 本文仅为个人见解,如有错误的地方欢迎留言区探讨和指正。 1、餐前甜品 如下是一段 JavaScript 代码,如果你毫不犹豫的说出代码执行顺序。那么请直接滚动到底部,留下你的足迹,接受膜拜。如果还不是很确定,那么请往下继续查看。 2、磨刀不误砍柴工(了解浏览器原理) (1) 进程和线程 进程是cpu资源分配的最小单位(是能拥有资源和独立运行的最小...