automotive.qml Example File

imagine/automotive/qml/automotive.qml

  /****************************************************************************
  **
  ** Copyright (C) 2017 The Qt Company Ltd.
  ** Contact: https://www.qt.io/licensing/
  **
  ** This file is part of the examples of the Qt Toolkit.
  **
  ** $QT_BEGIN_LICENSE:BSD$
  ** Commercial License Usage
  ** Licensees holding valid commercial Qt licenses may use this file in
  ** accordance with the commercial license agreement provided with the
  ** Software or, alternatively, in accordance with the terms contained in
  ** a written agreement between you and The Qt Company. For licensing terms
  ** and conditions see https://www.qt.io/terms-conditions. For further
  ** information use the contact form at https://www.qt.io/contact-us.
  **
  ** BSD License Usage
  ** Alternatively, you may use this file under the terms of the BSD license
  ** as follows:
  **
  ** "Redistribution and use in source and binary forms, with or without
  ** modification, are permitted provided that the following conditions are
  ** met:
  **   * Redistributions of source code must retain the above copyright
  **     notice, this list of conditions and the following disclaimer.
  **   * Redistributions in binary form must reproduce the above copyright
  **     notice, this list of conditions and the following disclaimer in
  **     the documentation and/or other materials provided with the
  **     distribution.
  **   * Neither the name of The Qt Company Ltd nor the names of its
  **     contributors may be used to endorse or promote products derived
  **     from this software without specific prior written permission.
  **
  **
  ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  ** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  ** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  ** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  ** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  ** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  ** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  ** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  ** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  ** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  ** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
  **
  ** $QT_END_LICENSE$
  **
  ****************************************************************************/

  import QtQuick 2.9
  import QtQuick.Layouts 1.3
  import QtQuick.Controls 2.3
  import QtQuick.Controls.Imagine 2.3
  import QtQuick.Window 2.0

  ApplicationWindow {
      id: window
      width: 1280
      height: 720
      minimumWidth: 1180
      minimumHeight: 663
      visible: true
      title: "Qt Quick Controls 2 - Imagine Style Example: Automotive"

      readonly property color colorGlow: "#1d6d64"
      readonly property color colorWarning: "#d5232f"
      readonly property color colorMain: "#6affcd"
      readonly property color colorBright: "#ffffff"
      readonly property color colorLightGrey: "#888"
      readonly property color colorDarkGrey: "#333"

      readonly property int fontSizeExtraSmall: Qt.application.font.pixelSize * 0.8
      readonly property int fontSizeMedium: Qt.application.font.pixelSize * 1.5
      readonly property int fontSizeLarge: Qt.application.font.pixelSize * 2
      readonly property int fontSizeExtraLarge: Qt.application.font.pixelSize * 5

      Component.onCompleted: {
          x = Screen.width / 2 - width / 2
          y = Screen.height / 2 - height / 2
      }

      Shortcut {
          sequence: "Ctrl+Q"
          onActivated: Qt.quit()
      }

      Frame {
          id: frame
          anchors.fill: parent
          anchors.margins: 90

          RowLayout {
              id: mainRowLayout
              anchors.fill: parent
              anchors.margins: 24
              spacing: 36

              Container {
                  id: leftTabBar

                  currentIndex: 1

                  Layout.fillWidth: false
                  Layout.fillHeight: true

                  ButtonGroup {
                      buttons: columnLayout.children
                  }

                  contentItem: ColumnLayout {
                      id: columnLayout
                      spacing: 3

                      Repeater {
                          model: leftTabBar.contentModel
                      }
                  }

                  FeatureButton {
                      id: navigationFeatureButton
                      text: qsTr("Navigation")
                      icon.name: "navigation"
                      Layout.fillHeight: true
                  }

                  FeatureButton {
                      text: qsTr("Music")
                      icon.name: "music"
                      checked: true
                      Layout.fillHeight: true
                  }

                  FeatureButton {
                      text: qsTr("Message")
                      icon.name: "message"
                      Layout.fillHeight: true
                  }

                  FeatureButton {
                      text: qsTr("Command")
                      icon.name: "command"
                      Layout.fillHeight: true
                  }

                  FeatureButton {
                      text: qsTr("Settings")
                      icon.name: "settings"
                      Layout.fillHeight: true
                  }
              }

              StackLayout {
                  currentIndex: leftTabBar.currentIndex

                  Layout.preferredWidth: 150
                  Layout.maximumWidth: 150
                  Layout.fillWidth: false

                  Item {}

                  ColumnLayout {
                      spacing: 16

                      ButtonGroup {
                          id: viewButtonGroup
                          buttons: viewTypeRowLayout.children
                      }

                      RowLayout {
                          id: viewTypeRowLayout
                          spacing: 3

                          Layout.bottomMargin: 12

                          Button {
                              text: qsTr("Compact")
                              font.pixelSize: fontSizeExtraSmall
                              checked: true

                              Layout.fillWidth: true
                          }
                          Button {
                              text: qsTr("Full")
                              font.pixelSize: fontSizeExtraSmall
                              checkable: true

                              Layout.fillWidth: true
                          }
                      }

                      GlowingLabel {
                          text: qsTr("VOLUME")
                          color: "white"
                          font.pixelSize: fontSizeMedium
                      }

                      Dial {
                          id: volumeDial
                          from: 0
                          value: 42
                          to: 100
                          stepSize: 1

                          Layout.alignment: Qt.AlignHCenter
                          Layout.minimumWidth: 64
                          Layout.minimumHeight: 64
                          Layout.preferredWidth: 128
                          Layout.preferredHeight: 128
                          Layout.maximumWidth: 128
                          Layout.maximumHeight: 128
                          Layout.fillHeight: true

                          Label {
                              text: volumeDial.value.toFixed(0)
                              color: "white"
                              font.pixelSize: Qt.application.font.pixelSize * 3
                              anchors.centerIn: parent
                          }
                      }

                      ButtonGroup {
                          id: audioSourceButtonGroup
                      }

                      RowLayout {
                          Layout.topMargin: 16

                          GlowingLabel {
                              id: radioOption
                              text: qsTr("RADIO")
                              color: "white"
                              font.pixelSize: fontSizeMedium
                              horizontalAlignment: Label.AlignLeft

                              Layout.fillWidth: true
                          }
                          GlowingLabel {
                              text: qsTr("AUX")
                              color: colorLightGrey
                              font.pixelSize: fontSizeMedium * 0.8
                              horizontalAlignment: Label.AlignHCenter
                              glowEnabled: false

                              Layout.alignment: Qt.AlignBottom
                              Layout.fillWidth: true
                          }
                          GlowingLabel {
                              text: qsTr("MP3")
                              color: colorDarkGrey
                              font.pixelSize: fontSizeMedium * 0.6
                              horizontalAlignment: Label.AlignRight
                              glowEnabled: false

                              Layout.alignment: Qt.AlignBottom
                              Layout.fillWidth: true
                          }
                      }

                      Frame {
                          id: stationFrame
                          leftPadding: 1
                          rightPadding: 1
                          topPadding: 1
                          bottomPadding: 1

                          Layout.fillWidth: true
                          Layout.fillHeight: true
                          Layout.preferredHeight: 128

                          ListView {
                              clip: true
                              anchors.fill: parent

                              ScrollIndicator.vertical: ScrollIndicator {
                                  parent: stationFrame
                                  anchors.top: parent.top
                                  anchors.right: parent.right
                                  anchors.rightMargin: 1
                                  anchors.bottom: parent.bottom
                              }

                              model: ListModel {
                                  ListElement { name: "V-Radio"; frequency: "105.5 MHz" }
                                  ListElement { name: "World News"; frequency: "93.4 MHz" }
                                  ListElement { name: "TekStep FM"; frequency: "95.0 MHz" }
                                  ListElement { name: "Classic Radio"; frequency: "89.9 MHz" }
                                  ListElement { name: "Buena Vista FM"; frequency: "100.8 MHz" }
                                  ListElement { name: "Drive-by Radio"; frequency: "99.1 MHz" }
                                  ListElement { name: "Unknown #1"; frequency: "104.5 MHz" }
                                  ListElement { name: "Unknown #2"; frequency: "91.2 MHz" }
                                  ListElement { name: "Unknown #3"; frequency: "93.8 MHz" }
                                  ListElement { name: "Unknown #4"; frequency: "80.4 MHz" }
                                  ListElement { name: "Unknown #5"; frequency: "101.1 MHz" }
                                  ListElement { name: "Unknown #6"; frequency: "92.2 MHz" }
                              }
                              delegate: ItemDelegate {
                                  id: stationDelegate
                                  width: parent.width
                                  height: 22
                                  text: model.name
                                  font.pixelSize: fontSizeExtraSmall
                                  topPadding: 0
                                  bottomPadding: 0

                                  contentItem: RowLayout {
                                      Label {
                                          text: model.name
                                          font: stationDelegate.font
                                          horizontalAlignment: Text.AlignLeft
                                          Layout.fillWidth: true
                                      }
                                      Label {
                                          text: model.frequency
                                          font: stationDelegate.font
                                          horizontalAlignment: Text.AlignRight
                                          Layout.fillWidth: true
                                      }
                                  }
                              }
                          }
                      }

                      Frame {
                          Layout.fillWidth: true

                          RowLayout {
                              anchors.fill: parent

                              Label {
                                  text: qsTr("Sort by")
                                  font.pixelSize: fontSizeExtraSmall

                                  Layout.alignment: Qt.AlignTop
                              }

                              ColumnLayout {
                                  RadioButton {
                                      text: qsTr("Name")
                                      font.pixelSize: fontSizeExtraSmall
                                  }
                                  RadioButton {
                                      text: qsTr("Frequency")
                                      font.pixelSize: fontSizeExtraSmall
                                  }
                                  RadioButton {
                                      text: qsTr("Favourites")
                                      font.pixelSize: fontSizeExtraSmall
                                      checked: true
                                  }
                              }
                          }
                      }
                  }
              }

              Rectangle {
                  color: colorMain
                  implicitWidth: 1
                  Layout.fillHeight: true
              }

              ColumnLayout {
                  Layout.preferredWidth: 350
                  Layout.fillWidth: true
                  Layout.fillHeight: true

                  GlowingLabel {
                      id: timeLabel
                      text: qsTr("11:02")
                      font.pixelSize: fontSizeExtraLarge

                      Layout.alignment: Qt.AlignHCenter

                      GlowingLabel {
                          text: qsTr("AM")
                          font.pixelSize: fontSizeLarge
                          anchors.left: parent.right
                          anchors.leftMargin: 8
                      }
                  }

                  Label {
                      text: qsTr("01/01/2018")
                      color: colorLightGrey
                      font.pixelSize: fontSizeMedium

                      Layout.alignment: Qt.AlignHCenter
                      Layout.topMargin: 2
                      Layout.bottomMargin: 10
                  }

                  Image {
                      source: "qrc:/icons/car.png"
                      fillMode: Image.PreserveAspectFit

                      Layout.fillHeight: true

                      Column {
                          x: parent.width * 0.88
                          y: parent.height * 0.56
                          spacing: 3

                          Image {
                              source: "qrc:/icons/warning.png"
                              anchors.horizontalCenter: parent.horizontalCenter

                              layer.enabled: true
                              layer.effect: CustomGlow {
                                  spread: 0.2
                                  samples: 40
                                  color: colorWarning
                              }
                          }

                          GlowingLabel {
                              text: qsTr("Door open")
                              color: colorWarning
                              glowColor: Qt.rgba(colorWarning.r, colorWarning.g, colorWarning.b, 0.4)
                          }
                      }
                  }
              }

              Rectangle {
                  color: colorMain
                  implicitWidth: 1
                  Layout.fillHeight: true
              }

              ColumnLayout {
                  Row {
                      spacing: 8

                      Image {
                          source: "qrc:/icons/weather.png"
                      }

                      Column {
                          spacing: 8

                          Row {
                              anchors.horizontalCenter: parent.horizontalCenter

                              GlowingLabel {
                                  id: outsideTempValueLabel
                                  text: qsTr("31")
                                  font.pixelSize: fontSizeExtraLarge
                              }

                              GlowingLabel {
                                  text: qsTr("°C")
                                  font.pixelSize: Qt.application.font.pixelSize * 2.5
                                  anchors.baseline: outsideTempValueLabel.baseline
                              }
                          }

                          Label {
                              text: qsTr("Osaka, Japan")
                              color: colorLightGrey
                              font.pixelSize: fontSizeMedium
                          }
                      }
                  }

                  ColumnLayout {
                      id: airConRowLayout
                      spacing: 8

                      Layout.preferredWidth: 128
                      Layout.preferredHeight: 380
                      Layout.fillHeight: true

                      Item {
                          Layout.fillHeight: true
                      }

                      SwitchDelegate {
                          text: qsTr("AC")
                          leftPadding: 0
                          rightPadding: 0
                          topPadding: 0
                          bottomPadding: 0

                          Layout.fillWidth: true
                      }

                      // QTBUG-63269
                      Item {
                          implicitHeight: temperatureValueLabel.implicitHeight
                          Layout.fillWidth: true
                          Layout.topMargin: 16

                          Label {
                              text: qsTr("Temperature")
                              anchors.baseline: temperatureValueLabel.bottom
                              anchors.left: parent.left
                          }

                          GlowingLabel {
                              id: temperatureValueLabel
                              text: qsTr("24°C")
                              font.pixelSize: fontSizeLarge
                              anchors.right: parent.right
                          }
                      }

                      Slider {
                          value: 0.35
                          Layout.fillWidth: true
                      }

                      // QTBUG-63269
                      Item {
                          implicitHeight: powerValueLabel.implicitHeight
                          Layout.fillWidth: true
                          Layout.topMargin: 16

                          Label {
                              text: qsTr("Power")
                              anchors.baseline: powerValueLabel.bottom
                              anchors.left: parent.left
                          }

                          GlowingLabel {
                              id: powerValueLabel
                              text: qsTr("10%")
                              font.pixelSize: fontSizeLarge
                              anchors.right: parent.right
                          }
                      }

                      Slider {
                          value: 0.25
                          Layout.fillWidth: true
                      }

                      SwitchDelegate {
                          text: qsTr("Low")
                          leftPadding: 0
                          rightPadding: 0
                          topPadding: 0
                          bottomPadding: 0

                          Layout.fillWidth: true
                          Layout.topMargin: 16
                      }

                      SwitchDelegate {
                          text: qsTr("High")
                          checked: true
                          leftPadding: 0
                          rightPadding: 0
                          topPadding: 0
                          bottomPadding: 0

                          Layout.fillWidth: true
                      }

                      SwitchDelegate {
                          text: qsTr("Defog")
                          leftPadding: 0
                          rightPadding: 0
                          topPadding: 0
                          bottomPadding: 0

                          Layout.fillWidth: true
                      }

                      SwitchDelegate {
                          text: qsTr("Recirculate")
                          leftPadding: 0
                          rightPadding: 0
                          topPadding: 0
                          bottomPadding: 0

                          Layout.fillWidth: true
                      }

                      Item {
                          Layout.fillHeight: true
                      }
                  }
              }

              Container {
                  id: rightTabBar

                  currentIndex: 1

                  Layout.fillHeight: true

                  ButtonGroup {
                      buttons: rightTabBarContentLayout.children
                  }

                  contentItem: ColumnLayout {
                      id: rightTabBarContentLayout
                      spacing: 3

                      Repeater {
                          model: rightTabBar.contentModel
                      }
                  }

                  Item {
                      Layout.fillHeight: true
                  }

                  FeatureButton {
                      text: qsTr("Windows")
                      icon.name: "windows"

                      Layout.maximumHeight: navigationFeatureButton.height
                      Layout.fillHeight: true
                  }
                  FeatureButton {
                      text: qsTr("Air Con.")
                      icon.name: "air-con"
                      checked: true

                      Layout.maximumHeight: navigationFeatureButton.height
                      Layout.fillHeight: true
                  }
                  FeatureButton {
                      text: qsTr("Seats")
                      icon.name: "seats"

                      Layout.maximumHeight: navigationFeatureButton.height
                      Layout.fillHeight: true
                  }
                  FeatureButton {
                      text: qsTr("Statistics")
                      icon.name: "statistics"

                      Layout.maximumHeight: navigationFeatureButton.height
                      Layout.fillHeight: true
                  }
              }
          }
      }
  }