HMI-27-【运动模式】解决转速表指针弧光

简介: 今天我们要解决的是液晶仪表中运动模式下,转速表指针问题,因为转速表不是标准的圆,需要处理一下下。因为这个代码时间有点长,现在还得好好缓缓,好多接口还得在回去看舒适模式,尽量还是保持统一。


HMI-27-【运动模式】解决转速表指针弧光

今天我们要解决的是液晶仪表中运动模式下,转速表指针问题,因为转速表不是标准的圆,需要处理一下下。因为这个代码时间有点长,现在还得好好缓缓,好多接口还得在回去看舒适模式,尽量还是保持统一。



HMI-27-【运动模式】解决转速表指针弧光实现指针转动改进版本整体进度最后第一阶段成果展示

关键字:QPainterrotateOpacitydrawPixmapQt

实现指针转动

其实实现指针转动好很好实现,只需要在一个label上绘制即可,代码如下:

voidMDS_Left::drawPonter(intangle)

{

   QPainterpainter(ui->label_pointer);

   painter.setRenderHint((QPainter::SmoothPixmapTransform));

   painter.setRenderHint(QPainter::HighQualityAntialiasing);

   painter.translate(269,246);

   painter.save();

   painter.rotate(angle);

   painter.drawPixmap(-274,-123,164,248,QPixmap(":/Sport/Resources/MeterDisplay/Sport/MDSL/pointer.png"));

   painter.setOpacity(m_shadeOpacity);

   painter.drawPixmap(-264,-0,208,239,QPixmap(":/Sport/Resources/MeterDisplay/Sport/MDSL/pointershade.png"));

   painter.restore();

}

这样设置效果不是很理想:

改进版本

这个版本主要是吧指针和弧光分开,不过弧光效果还是没有控制好,目前也只能是这样了,除非得重新做一个弧光,不过我的美工能力有限,暂时无能为力。后面有美工牛逼症的小伙伴可以接着在优化一下。看下代码

voidMDS_Left::drawPonter(intangle)

{

 

   doublescale=1-qAbs(0.4*angle/120.0);

   QPainterpainter(ui->label_pointer);

   painter.setRenderHint((QPainter::SmoothPixmapTransform));

   painter.setRenderHint(QPainter::HighQualityAntialiasing);

   painter.translate(269,246);

   painter.save();

   painter.rotate(angle);

   painter.drawPixmap((-164-25),-138,90,280,QPixmap(":/Sport/Resources/MeterDisplay/Sport/MDSL/hu.png"));

   painter.drawPixmap((-164-110*scale),-22*scale,130*scale,44*scale,QPixmap(":/Sport/Resources/MeterDisplay/Sport/MDSL/pointer.png"));

   painter.setOpacity(m_shadeOpacity);

   painter.drawPixmap((-164-100*(scale*1.1)),-0,208*(scale*1.1),239,QPixmap(":/Sport/Resources/MeterDisplay/Sport/MDSL/pointershade.png"));

   painter.restore();

}

最后

今天就是大年二十八了,提前祝大家新年快乐。

说明:

本项目中所使借鉴原型来自:[吉利] 博瑞GE | 仪表HMI设计吉利汽车HMI项目

设计图的所有权和解释权都归吉利汽车所有。

本项目所有资源文件均有打不死的小海复刻制作。

本项目代码暂时不会开源,有需要的源码的可与我联系,左上角二维码加微信。

本项目仅限学习交流、禁止商业使用。



相关文章
|
算法
用函数数组指针来实现计算器的功能(简易模式)(不过稍微改改也能算比较复杂的)
整个代码块并不算多难理解,有兴趣的可以看看我写的扫雷(比这稍微复杂点,但与比赛相比差远了)。它的思路很简单,就是构造一个函数指针数组,然后把4个函数放到里面去,再在想用的时候把它调用出来。
82 0
用指针检测大小端模式
#include #include //用指针的方式检测机器的大小端模式 int small_port() { int a = 1 ; char b = *((char *)(&a)) ; return b ; } int main(void) { int i = small_...
938 0
|
5月前
|
C语言
指针进阶(C语言终)
指针进阶(C语言终)
|
1月前
|
C语言
无头链表二级指针方式实现(C语言描述)
本文介绍了如何在C语言中使用二级指针实现无头链表,并提供了创建节点、插入、删除、查找、销毁链表等操作的函数实现,以及一个示例程序来演示这些操作。
24 0
|
2月前
|
存储 人工智能 C语言
C语言程序设计核心详解 第八章 指针超详细讲解_指针变量_二维数组指针_指向字符串指针
本文详细讲解了C语言中的指针,包括指针变量的定义与引用、指向数组及字符串的指针变量等。首先介绍了指针变量的基本概念和定义格式,随后通过多个示例展示了如何使用指针变量来操作普通变量、数组和字符串。文章还深入探讨了指向函数的指针变量以及指针数组的概念,并解释了空指针的意义和使用场景。通过丰富的代码示例和图形化展示,帮助读者更好地理解和掌握C语言中的指针知识。
|
3月前
|
C语言
【C初阶——指针5】鹏哥C语言系列文章,基本语法知识全面讲解——指针(5)
【C初阶——指针5】鹏哥C语言系列文章,基本语法知识全面讲解——指针(5)
|
3月前
|
C语言
【C初阶——指针4】鹏哥C语言系列文章,基本语法知识全面讲解——指针(4)
【C初阶——指针4】鹏哥C语言系列文章,基本语法知识全面讲解——指针(4)
|
3月前
|
存储 编译器 C语言
【C初阶——指针3】鹏哥C语言系列文章,基本语法知识全面讲解——指针(3)
【C初阶——指针3】鹏哥C语言系列文章,基本语法知识全面讲解——指针(3)
|
4月前
|
编译器 C语言
【C语言初阶】指针篇—下
【C语言初阶】指针篇—下
|
4月前
|
存储 C语言
【C语言初阶】指针篇—上
【C语言初阶】指针篇—上