先贴上效果图,注意,没有写逻辑,所以这些都是乱动的

这里线主要说一下中间显示速度的显示制作的方式,在这里,自己专门写了一个数字的仪表

考虑的一般的汽车是没有办法把瞬时速度提升到四位数的,所以我这里就放了三位数,完了根据实时数据,更新这三个label的资源文件,在这个新的类中,只有一个函数,那就是设置数字

void set_number(int num = 0);

下面是实现方法,这个方法应该还可以优化,不过懒得优化了,先把功能堆出来。

void Number_1::set_number(int num)
{
int temp1 = num;
int temp2 = num;
switch (num%10) {
case 0:
ui->label_3->setStyleSheet("border-image:url(:/source/number/0.png)");
break;
case 1:
ui->label_3->setStyleSheet("border-image:url(:/source/number/1.png)");
break;
case 2:
ui->label_3->setStyleSheet("border-image:url(:/source/number/2.png)");
break;
case 3:
ui->label_3->setStyleSheet("border-image:url(:/source/number/3.png)");
break;
case 4:
ui->label_3->setStyleSheet("border-image:url(:/source/number/4.png)");
break;
case 5:
ui->label_3->setStyleSheet("border-image:url(:/source/number/5.png)");
break;
case 6:
ui->label_3->setStyleSheet("border-image:url(:/source/number/6.png)");
break;
case 7:
ui->label_3->setStyleSheet("border-image:url(:/source/number/7.png)");
break;
case 8:
ui->label_3->setStyleSheet("border-image:url(:/source/number/8.png)");
break;
case 9:
ui->label_3->setStyleSheet("border-image:url(:/source/number/9.png)");
break;
default:
break;
}
switch (temp1/10) {
case 0:
ui->label_2->setStyleSheet("border-image:url(:/source/number/0.png)");
break;
case 1:
ui->label_2->setStyleSheet("border-image:url(:/source/number/1.png)");
break;
case 2:
ui->label_2->setStyleSheet("border-image:url(:/source/number/2.png)");
break;
case 3:
ui->label_2->setStyleSheet("border-image:url(:/source/number/3.png)");
break;
case 4:
ui->label_2->setStyleSheet("border-image:url(:/source/number/4.png)");
break;
case 5:
ui->label_2->setStyleSheet("border-image:url(:/source/number/5.png)");
break;
case 6:
ui->label_2->setStyleSheet("border-image:url(:/source/number/6.png)");
break;
case 7:
ui->label_2->setStyleSheet("border-image:url(:/source/number/7.png)");
break;
case 8:
ui->label_2->setStyleSheet("border-image:url(:/source/number/8.png)");
break;
case 9:
ui->label_2->setStyleSheet("border-image:url(:/source/number/9.png)");
break;
default:
break;
}
switch (temp2/100) {
case 0:
ui->label_1->setStyleSheet("border-image:url(:/source/number/0.png)");
break;
case 1:
ui->label_1->setStyleSheet("border-image:url(:/source/number/1.png)");
break;
case 2:
ui->label_1->setStyleSheet("border-image:url(:/source/number/2.png)");
break;
case 3:
ui->label_1->setStyleSheet("border-image:url(:/source/number/3.png)");
break;
case 4:
ui->label_1->setStyleSheet("border-image:url(:/source/number/4.png)");
break;
case 5:
ui->label_1->setStyleSheet("border-image:url(:/source/number/5.png)");
break;
case 6:
ui->label_1->setStyleSheet("border-image:url(:/source/number/6.png)");
break;
case 7:
ui->label_1->setStyleSheet("border-image:url(:/source/number/7.png)");
break;
case 8:
ui->label_1->setStyleSheet("border-image:url(:/source/number/8.png)");
break;
case 9:
ui->label_1->setStyleSheet("border-image:url(:/source/number/9.png)");
break;
default:
break;
}
if(num<10)
{
ui->label_3->move(64,0);
ui->label_2->hide();
ui->label_1->hide(); }
else if(num >=10 && num <100)
{
ui->label_2->show();
ui->label_1->hide();
ui->label_2->move(32,0);
ui->label_3->move(96,0);
}
else
{
ui->label_1->show();
ui->label_2->show();
ui->label_1->move(0,0);
ui->label_2->move(64,0);
ui->label_3->move(128,0);
}
}

在主程序中调用如下

number_center = new Number_1(ui->widget_center);
number_center->setGeometry(0,0,192,72);
number_center->show();

好了,这个速度显示的界面就搞定了

Qt Qwdget 汽车仪表知识点拆解1 速度表示的更多相关文章

  1. Qt Qwdget 汽车仪表知识点拆解6 自定义控件

    先贴上效果图,注意,没有写逻辑,都是乱动的 这里说一下控件自定义 图中标出的部分都是自定义的控件 这里如果我们有批量类似的功能,就可以使用自定义控件的方式,这里我已下面的自定义控件说一下,上面的在上一 ...

  2. Qt Qwdget 汽车仪表知识点拆解2 图像放大

    先贴上效果图,注意,没有写逻辑,都是乱动的 这里讲下 这个小汽车的进入过程,其实这个说白了就没有技术含量了,本来应该趁着这个机会学习一下Qt的动画机制,不过随机一想,这个自己写也累不到那里去 下面说下 ...

  3. Qt Qwdget 汽车仪表知识点拆解8 淡入效果

    先贴上效果图,注意,没有写逻辑,都是乱动的 看下面的开始,开始的时候有一个带入的效果,这里有一个坑, 网上大部分都是调用下面这个函数 setWindowOpacity(); 但是,你会发现,在你的子窗 ...

  4. Qt Qwdget 汽车仪表知识点拆解7 图像绘制,旋转

    先贴上效果图,注意,没有写逻辑,都是乱动的 看下最中心的指针旋转,这里使用的QPainter的绘制函数 要显示复杂的效果,需要分层 void Widget::draw_number_pointer() ...

  5. Qt Qwdget 汽车仪表知识点拆解5 标题栏图标闪烁

    先贴上效果图,注意,没有写逻辑,都是乱动的 看下最上面的部分,有一些仪表图标在闪烁,如果一个一个写,也是可以实现的,不过感觉要累死的节奏 这里我写了一个我自己的Label,完了把把这些QLabel提升 ...

  6. Qt Qwdget 汽车仪表知识点拆解4 另类进度条实现

    先贴上效果图,注意,没有写逻辑,都是乱动的 注意看一下,右面的这两个进度条,有瑕疵,就是我没有把图片处理干净,这里犹豫我不知道这个具体的弧度,也没法绘制,就偷懒了 现在上面放一个UI,把两个进度条抠空 ...

  7. Qt Qwdget 汽车仪表知识点拆解3 进度条编写

    先贴上效果图,注意,没有写逻辑,都是乱动的 这篇我来说说左侧的这个进度条的实现原理,其实更简单,哈哈哈 有一个大的widget,根据素材,我放了10个label 剩下的就是写一个函数,根据数据的不同, ...

  8. Qt中常用知识点

    1:QRegExp 正则表达式 QRegExp regExp("[a-zA-Z][1-9][0-9]{0,2}"); xxx->setValidator(new QRegEx ...

  9. [转]Qt 5.5 操作 Excel 的速度 效率问题

    转自:http://blog.csdn.net/li494816491/article/details/50274305 1. QAxObject *_excelObject1 =newQAxObje ...

随机推荐

  1. likelihood(似然) and likelihood function(似然函数)

    知乎上关于似然的一个问题:https://www.zhihu.com/question/54082000 概率(密度)表达给定下样本随机向量的可能性,而似然表达了给定样本下参数(相对于另外的参数)为真 ...

  2. js实现div滚动条在页面刷新 滚动条位置固定

    思想:1.通过div的onscroll事件记录滚动条的scrollTop值,设置到document.cookie 2.页面加载时再读取document.cookie的值,设置给div的scrollTo ...

  3. 【洛谷P2831】[NOIP2016]愤怒的小鸟

    愤怒的小鸟 题目链接 本来是刷状压DP的,然而不会.. 搜索是比较好想的,直接dfs就行了 我们可以知道两只猪确定一条抛物线 依次处理每一只猪,有以下几种方法: 1.先看已经建立的抛物线是否能打到这只 ...

  4. 【luogu P1137 旅行计划】 题解

    题目链接:https://www.luogu.org/problemnew/show/P1137 topsort + DP #include <queue> #include <cs ...

  5. 【luogu P3372 线段树1】 模板

    线段树的模板题 题目链接:https://www.luogu.org/problemnew/show/P3372 update区间修改,query区间求和 #include <iostream& ...

  6. Android onMeasure 方法的测量规范MeasureSpec

    一个MeasureSpec封装了父布局传递给子布局的布局要求,每个MeasureSpec代表了一组宽度和高度的要求.一个MeasureSpec由大小和模式组成.它有三种模式:UNSPECIFIED(未 ...

  7. 使用百度新闻RSS

    function getbaidu() { $result=""; //RSS源地址列表数组 $rssfeed = array("http://news.baidu.co ...

  8. HTML5--应用网页模板

    因为刚开始写博客,只想着把知识点记录在这,也想给你们一些参考,在布局上有些没有思考太多;回过头来看,实在是不忍直视,对不住之前阅读的100+,既然昨天的事无法挽回,那就从现在开始从新整改吧!也希望大家 ...

  9. 菜鸟笔记 -- Chapter 6.3 对象

    6.3 对象 Java是一门面向对象的程序设计语言,对象是由类抽象出来的,所有的问题都是通过对象来处理的,对象可以操作类的属性和方法解决相应的问题,所以了解对象的产生.操作和生存周期对学习Java语言 ...

  10. Windows远程桌面连接命令mstsc

    常用的:1. mstsc /v: 192.168.0.1 连接数满了之后使用的:2. mstsc /v: 192.168.0.1 /console -admin Mstsc 命令参考Updated: ...