Qt Qwdget 汽车仪表知识点拆解1 速度表示
先贴上效果图,注意,没有写逻辑,所以这些都是乱动的
这里线主要说一下中间显示速度的显示制作的方式,在这里,自己专门写了一个数字的仪表
考虑的一般的汽车是没有办法把瞬时速度提升到四位数的,所以我这里就放了三位数,完了根据实时数据,更新这三个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 速度表示的更多相关文章
- Qt Qwdget 汽车仪表知识点拆解6 自定义控件
先贴上效果图,注意,没有写逻辑,都是乱动的 这里说一下控件自定义 图中标出的部分都是自定义的控件 这里如果我们有批量类似的功能,就可以使用自定义控件的方式,这里我已下面的自定义控件说一下,上面的在上一 ...
- Qt Qwdget 汽车仪表知识点拆解2 图像放大
先贴上效果图,注意,没有写逻辑,都是乱动的 这里讲下 这个小汽车的进入过程,其实这个说白了就没有技术含量了,本来应该趁着这个机会学习一下Qt的动画机制,不过随机一想,这个自己写也累不到那里去 下面说下 ...
- Qt Qwdget 汽车仪表知识点拆解8 淡入效果
先贴上效果图,注意,没有写逻辑,都是乱动的 看下面的开始,开始的时候有一个带入的效果,这里有一个坑, 网上大部分都是调用下面这个函数 setWindowOpacity(); 但是,你会发现,在你的子窗 ...
- Qt Qwdget 汽车仪表知识点拆解7 图像绘制,旋转
先贴上效果图,注意,没有写逻辑,都是乱动的 看下最中心的指针旋转,这里使用的QPainter的绘制函数 要显示复杂的效果,需要分层 void Widget::draw_number_pointer() ...
- Qt Qwdget 汽车仪表知识点拆解5 标题栏图标闪烁
先贴上效果图,注意,没有写逻辑,都是乱动的 看下最上面的部分,有一些仪表图标在闪烁,如果一个一个写,也是可以实现的,不过感觉要累死的节奏 这里我写了一个我自己的Label,完了把把这些QLabel提升 ...
- Qt Qwdget 汽车仪表知识点拆解4 另类进度条实现
先贴上效果图,注意,没有写逻辑,都是乱动的 注意看一下,右面的这两个进度条,有瑕疵,就是我没有把图片处理干净,这里犹豫我不知道这个具体的弧度,也没法绘制,就偷懒了 现在上面放一个UI,把两个进度条抠空 ...
- Qt Qwdget 汽车仪表知识点拆解3 进度条编写
先贴上效果图,注意,没有写逻辑,都是乱动的 这篇我来说说左侧的这个进度条的实现原理,其实更简单,哈哈哈 有一个大的widget,根据素材,我放了10个label 剩下的就是写一个函数,根据数据的不同, ...
- Qt中常用知识点
1:QRegExp 正则表达式 QRegExp regExp("[a-zA-Z][1-9][0-9]{0,2}"); xxx->setValidator(new QRegEx ...
- [转]Qt 5.5 操作 Excel 的速度 效率问题
转自:http://blog.csdn.net/li494816491/article/details/50274305 1. QAxObject *_excelObject1 =newQAxObje ...
随机推荐
- 行云管家V4.9正式发布:监控全面提升,首页、主机详情大幅优化,新增大量实用功能.md
让大家久等啦!4.9版本中我们对监控模块进行了重构,在数据准确性与稳定性方面做了大幅提升.我们也对首页及主机详情页面做了大幅重构,以追求为您提供极致的用户体验.同时我们在新版本中增加了如:运维报表.用 ...
- focal loss和retinanet
这个是自己用的focal loss的代码和公式推导:https://github.com/zimenglan-sysu-512/Focal-Loss 这个是有retinanet:https://git ...
- transform,animate
1.transform 用来定义变换 IE10及以上支持 示例:transform: rotate | scale | skew | translate |matrix; 一.旋转rotate 正数 ...
- 三、详述 IntelliJ IDEA 的使用界面
是否还记得在博文“IntelliJ IDEA 安装目录的核心文件讲解”中,这张充满神秘色彩的图片呢?进入她,让咱们一起感受她的魅力吧! 如上图所示,打开 IntelliJ IDEA 后,首先迎接咱们的 ...
- 使用cmd命令进行运行java(cmd命令输出Hello word)
使用cmd命令输出Hello word 条件,按照好jdk和jre的环境下,如果没有安装,请安装,简单安装教程链接:https://www.cnblogs.com/weibanggang/p/9392 ...
- Android学习笔记_3_四种布局
Android布局是应用界面开发的重要一环,在Android中,共有四种布局方式, 分别是:FrameLayout( 帧布局 ).LinearLayout (线性布局).TableLayout(表格布 ...
- 前端静态文件如何应对HTTPS的到来
近几年,越来越多的网站开始支持https,我们可以看到国外的比如github.谷歌.facebook:国内的有百度.淘宝.博客园.coding.net.worktile等一系列的网站. 我再最近的开发 ...
- 网页静态化技术Freemarker
1.为什么要使用网页静态化技术 网页静态化解决方案在实际开发中运用比较多,例如新闻网站,门户网站中的新闻频道或者是文章类的频道. 对于电商网站的商品详细页来说,至少几百万个商品,每个商品又有大量的信息 ...
- Oracle树形结构数据---常见处理情景
Oracle树形结构数据---常见处理情景 1.查看表数据结构 SELECT * FROM QIANCODE.TREE_HIS_TABLE T ORDER BY T.NODE_LEVEL; ...
- Mongodb在window上启动
MongoDB 是目前在IT行业非常流行的一种非关系型数据库(NoSql),其灵活的数据存储方式备受当前IT从业人员的青睐.这里主要讲如何在windows平台下安装MongoDB. 安装最新版本mon ...