QT应用篇 二、QML用Image组件实现Progress Bar 的效果

QT应用篇

一、QT上位机串口编程
二、QML用Image组件实现Progress Bar 的效果
三、QML自定义显示SpinBox的加减按键图片及显示值效果



前言

记录自己学习QML的一些小技巧方便日后查找

QT的 qml 使用图片来达到类似进度条Progress Bar 的效果


一、qml需求

需要实现显示某一数据值类似数据中的条形图的增减效果
在这里插入图片描述

二、使用组件

1.Image组件

代码如下:

import QtQuick 2.12
import QtQuick.Controls 2.12
import QtQuick.Shapes 1.12
import QtMultimedia 5.12
...
...
...
//数据为0时的图片
Image {
   
	      x:0 
	      y:0
	      height: 60
	      width:  144  //g_outflow_pressure
	      clip: true
	      horizontalAlignment : Image.AlignLeft
	      fillMode: Image.Tile
	      source: resourcesPath + "suction_empty.png"
      }
//数据不为零时显示的图片      
Image {
   
        x:0
        y:0
        height: 60
        width:  16 * Math.round(spinBox.value * 9 / outFlowSpinBox.value )  //spinBox.value 为实际负压值 outFlowSpinBox.value 为设置负压
        clip: true
        horizontalAlignment : Image.AlignLeft
        fillMode: Image.Tile
        source: resourcesPath + "suction_full.png"
      }
//两张图片进行叠加

2.Image中fillMode的使用

代码如下 :

Image.Stretch:图片拉伸自适应;(默认的)
Image.PreserveAspectFit:按比例缩放,不裁剪
Image.PreserveAspectCrop:均匀缩放,必要时裁剪
Image.Tile:像贴瓷砖一样
Image.TileVertically:水平拉伸,垂直平铺
Image.TileHorizontally:垂直拉伸,水平平铺
Image.Pad:原始图像不做处理

原始代码

Image {
   
	    x:0
	    y:0
	    height: 60
	    width:  16 * Math.round(spinBox.value * 9 / outFlowSpinBox.value )  
	    clip: true
	    horizontalAlignment : Image.AlignLeft
	    fillMode: Image.Tile //实现效果关键代码
	    source: resourcesPath + "suction_full.png"
	  }

例子

主要展示四个效果

Image.Stretch
Image.PreserveAspectFit
Image.PreserveAspectCrop:
Image.Tile

① Image.Stretch:图片拉伸自适应;(默认的)

实现效果:
在这里插入图片描述


②Image.PreserveAspectFit:按比例缩放,不裁剪

实现的效果:
mage.PreserveAspectFit


③Image.PreserveAspectCrop:均匀缩放,必要时裁剪

实现的效果:Image.PreserveAspectCrop


④Image.Tile:贴瓷砖

实现的效果
在这里插入图片描述


总结

通过使用Image组件的fillMode来实现想要的功能

相关推荐

  1. QT教程】QML音视频效果实现

    2023-12-29 21:10:02       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-29 21:10:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-29 21:10:02       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-29 21:10:02       87 阅读
  4. Python语言-面向对象

    2023-12-29 21:10:02       96 阅读

热门阅读

  1. PageHelper 使用示例

    2023-12-29 21:10:02       58 阅读
  2. 09-网络安全框架及模型-(SSE-CMM)

    2023-12-29 21:10:02       41 阅读
  3. Android APP耗电量采集数据模板

    2023-12-29 21:10:02       55 阅读
  4. 在 Python 中编写循环Loops的艺术

    2023-12-29 21:10:02       64 阅读
  5. 算法练习Day22 (Leetcode/Python-回溯算法)

    2023-12-29 21:10:02       53 阅读
  6. Flask 密码重设系统

    2023-12-29 21:10:02       58 阅读
  7. python高级代码

    2023-12-29 21:10:02       57 阅读
  8. 6、LLaVA

    6、LLaVA

    2023-12-29 21:10:02      58 阅读
  9. Linux shell查看各文件夹容量大小

    2023-12-29 21:10:02       63 阅读