当前位置: 首页 > news >正文

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

QT应用篇

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


文章目录

  • QT应用篇
  • 前言
  • 一、qml需求
  • 二、使用组件
    • 1.Image组件
    • 2.Image中fillMode的使用
      • 例子
  • 总结


前言

记录自己学习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:0height: 60width:  144  //g_outflow_pressureclip: truehorizontalAlignment : Image.AlignLeftfillMode: Image.Tilesource: resourcesPath + "suction_empty.png"}
//数据不为零时显示的图片      
Image {x:0y:0height: 60width:  16 * Math.round(spinBox.value * 9 / outFlowSpinBox.value )  //spinBox.value 为实际负压值 outFlowSpinBox.value 为设置负压clip: truehorizontalAlignment : Image.AlignLeftfillMode: Image.Tilesource: resourcesPath + "suction_full.png"}
//两张图片进行叠加

2.Image中fillMode的使用

代码如下 :

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

原始代码

Image {x:0y:0height: 60width:  16 * Math.round(spinBox.value * 9 / outFlowSpinBox.value )  clip: truehorizontalAlignment : Image.AlignLeftfillMode: 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来实现想要的功能

http://www.lryc.cn/news/269015.html

相关文章:

  • SElinux工作原理简介并演示chcon、semanage、restorecon的使用方法
  • 表情串转换
  • 【娱乐小技巧】网页旋转90° 3步搞定
  • 移动管理系统软件哪家好?它是如何帮助企业降本增效的?
  • 电脑表格文件丢失如何找回?3个方法拯救丢失的文件!
  • VSCode 如何安装插件的历史版本
  • 关于edge浏览器以及插件推荐
  • Vue Tinymce富文本组件自定义操作按钮
  • 论文阅读:Blind Super-Resolution Kernel Estimation using an Internal-GAN
  • 韩国Neowine车规认证加密芯片ALPU-CV
  • 【每日一题】收集巧克力
  • 【开源】基于Vue+SpringBoot的贫困地区人口信息管理系统
  • 八股文打卡day7——计算机网络(7)
  • 南大通用数据库 GBase 8a 性能调优方法--Hash索引
  • openFeign调用接口时传递表单参数、Json参数、HttpServletRequest对象
  • 中国人民银行总行原稽核司副司长王书刚一行莅临国鑫走访交流
  • 单例模式学习
  • 基于Qt之QChart 图表(优美的曲线图案例)
  • Flink1.17实战教程(第四篇:处理函数)
  • WPF 已有资源字典文件,在xaml 里面引用
  • ImageJ几何测量
  • Docker 使用详解看了挺开悟的
  • Superset二次开发之部署问题汇总
  • Mybatis行为配置之Ⅲ—其他行为配置项说明
  • 高并发系统常见问题及解决方案(Java)
  • 【鸿蒙千帆起】《钢岚》成为首款基于 HarmonyOS NEXT 开发的战棋新游
  • 【QT】qt各模块描述
  • Go 泛型之明确使用时机与泛型实现原理
  • web3方向产品调研
  • 【计算机视觉】角点检测(Harris、SIFT)