前言

汽车仪表盘几乎是qt写仪表盘控件中最常见的,一般来说先要求美工做好设计图,然后设计效果图给到程序员,由程序员根据效果来实现,主要靠贴图,这种方法有个好处就是做出来的效果比较逼真,和真实效果图基本上保持一致,而且程序员也不会那么累,基本上入门级别的程序员都可以搞定,效率比较高,缺点是如果用户需要更改某个部件的颜色,比如指针的颜色等,需要重新做效果图贴图才能实现,比较麻烦,还有一点就是如果效果图原图不是很大,则遇到特殊分辨率情况下,可能会有失真的情况,被强制拉伸等。

我一贯都喜欢用painter来绘制,以规避后面几点的缺点,也可以锻炼下自己的审美能力,所谓心中有坐标,万物皆painter。

实现的功能

  • 1:可设置范围值,支持负数值
  • 2:可设置精确度,最大支持小数点后3位
  • 3:可设置大刻度数量/小刻度数量
  • 4:可设置开始旋转角度/结束旋转角度
  • 5:可设置是否启用动画效果以及动画效果每次移动的步长
  • 6:可设置外圆背景/内圆背景/饼圆三种颜色/刻度尺颜色/文字颜色
  • 7:自适应窗体拉伸,刻度尺和文字自动缩放
  • 8:可自由拓展各种渐变色,各圆的半径
  • 9:三色圆环按照比例设置范围角度 用户可以自由设置三色占用比例
  • 10:圆环样式可选择 三色圆环 当前圆环
  • 11:指示器样式可选择 圆形指示器 指针指示器 圆角指针指示器 三角形指示器

效果图

头文件代码

  1. #ifndef GAUGECAR_H
  2. #define GAUGECAR_H
  3. /**
  4. * 汽车仪表盘控件 作者:feiyangqingyun(QQ:517216493) 2016-11-20
  5. * 1:可设置范围值,支持负数值
  6. * 2:可设置精确度,最大支持小数点后3位
  7. * 3:可设置大刻度数量/小刻度数量
  8. * 4:可设置开始旋转角度/结束旋转角度
  9. * 5:可设置是否启用动画效果以及动画效果每次移动的步长
  10. * 6:可设置外圆背景/内圆背景/饼圆三种颜色/刻度尺颜色/文字颜色
  11. * 7:自适应窗体拉伸,刻度尺和文字自动缩放
  12. * 8:可自由拓展各种渐变色,各圆的半径
  13. * 9:三色圆环按照比例设置范围角度 用户可以自由设置三色占用比例
  14. * 10:圆环样式可选择 三色圆环 当前圆环
  15. * 11:指示器样式可选择 圆形指示器 指针指示器 圆角指针指示器 三角形指示器
  16. */
  17. #include <QWidget>
  18. #ifdef quc
  19. #if (QT_VERSION < QT_VERSION_CHECK(5,7,0))
  20. #include <QtDesigner/QDesignerExportWidget>
  21. #else
  22. #include <QtUiPlugin/QDesignerExportWidget>
  23. #endif
  24. class QDESIGNER_WIDGET_EXPORT GaugeCar : public QWidget
  25. #else
  26. class GaugeCar : public QWidget
  27. #endif
  28. {
  29. Q_OBJECT
  30. Q_ENUMS(PieStyle)
  31. Q_ENUMS(PointerStyle)
  32. Q_PROPERTY(double minValue READ getMinValue WRITE setMinValue)
  33. Q_PROPERTY(double maxValue READ getMaxValue WRITE setMaxValue)
  34. Q_PROPERTY(double value READ getValue WRITE setValue)
  35. Q_PROPERTY(int precision READ getPrecision WRITE setPrecision)
  36. Q_PROPERTY(int scaleMajor READ getScaleMajor WRITE setScaleMajor)
  37. Q_PROPERTY(int scaleMinor READ getScaleMinor WRITE setScaleMinor)
  38. Q_PROPERTY(int startAngle READ getStartAngle WRITE setStartAngle)
  39. Q_PROPERTY(int endAngle READ getEndAngle WRITE setEndAngle)
  40. Q_PROPERTY(bool animation READ getAnimation WRITE setAnimation)
  41. Q_PROPERTY(double animationStep READ getAnimationStep WRITE setAnimationStep)
  42. Q_PROPERTY(QColor outerCircleColor READ getOuterCircleColor WRITE setOuterCircleColor)
  43. Q_PROPERTY(QColor innerCircleColor READ getInnerCircleColor WRITE setInnerCircleColor)
  44. Q_PROPERTY(QColor pieColorStart READ getPieColorStart WRITE setPieColorStart)
  45. Q_PROPERTY(QColor pieColorMid READ getPieColorMid WRITE setPieColorMid)
  46. Q_PROPERTY(QColor pieColorEnd READ getPieColorEnd WRITE setPieColorEnd)
  47. Q_PROPERTY(QColor coverCircleColor READ getCoverCircleColor WRITE setCoverCircleColor)
  48. Q_PROPERTY(QColor scaleColor READ getScaleColor WRITE setScaleColor)
  49. Q_PROPERTY(QColor pointerColor READ getPointerColor WRITE setPointerColor)
  50. Q_PROPERTY(QColor centerCircleColor READ getCenterCircleColor WRITE setCenterCircleColor)
  51. Q_PROPERTY(QColor textColor READ getTextColor WRITE setTextColor)
  52. Q_PROPERTY(bool showOverlay READ getShowOverlay WRITE setShowOverlay)
  53. Q_PROPERTY(QColor overlayColor READ getOverlayColor WRITE setOverlayColor)
  54. Q_PROPERTY(PieStyle pieStyle READ getPieStyle WRITE setPieStyle)
  55. Q_PROPERTY(PointerStyle pointerStyle READ getPointerStyle WRITE setPointerStyle)
  56. public:
  57. enum PieStyle {
  58. PieStyle_Three = 0, //三色圆环
  59. PieStyle_Current = 1 //当前圆环
  60. };
  61. enum PointerStyle {
  62. PointerStyle_Circle = 0, //圆形指示器
  63. PointerStyle_Indicator = 1, //指针指示器
  64. PointerStyle_IndicatorR = 2, //圆角指针指示器
  65. PointerStyle_Triangle = 3 //三角形指示器
  66. };
  67. explicit GaugeCar(QWidget *parent = 0);
  68. ~GaugeCar();
  69. protected:
  70. void paintEvent(QPaintEvent *);
  71. void drawOuterCircle(QPainter *painter);
  72. void drawInnerCircle(QPainter *painter);
  73. void drawColorPie(QPainter *painter);
  74. void drawCoverCircle(QPainter *painter);
  75. void drawScale(QPainter *painter);
  76. void drawScaleNum(QPainter *painter);
  77. void drawPointerCircle(QPainter *painter);
  78. void drawPointerIndicator(QPainter *painter);
  79. void drawPointerIndicatorR(QPainter *painter);
  80. void drawPointerTriangle(QPainter *painter);
  81. void drawRoundCircle(QPainter *painter);
  82. void drawCenterCircle(QPainter *painter);
  83. void drawValue(QPainter *painter);
  84. void drawOverlay(QPainter *painter);
  85. private slots:
  86. void updateValue();
  87. private:
  88. double minValue; //最小值
  89. double maxValue; //最大值
  90. double value; //目标值
  91. int precision; //精确度,小数点后几位
  92. int scaleMajor; //大刻度数量
  93. int scaleMinor; //小刻度数量
  94. int startAngle; //开始旋转角度
  95. int endAngle; //结束旋转角度
  96. bool animation; //是否启用动画显示
  97. double animationStep; //动画显示时步长
  98. QColor outerCircleColor; //外圆背景颜色
  99. QColor innerCircleColor; //内圆背景颜色
  100. QColor pieColorStart; //饼圆开始颜色
  101. QColor pieColorMid; //饼圆中间颜色
  102. QColor pieColorEnd; //饼圆结束颜色
  103. QColor coverCircleColor; //覆盖圆背景颜色
  104. QColor scaleColor; //刻度尺颜色
  105. QColor pointerColor; //指针颜色
  106. QColor centerCircleColor; //中心圆颜色
  107. QColor textColor; //文字颜色
  108. bool showOverlay; //显示遮罩层
  109. QColor overlayColor; //遮罩层颜色
  110. PieStyle pieStyle; //饼图样式
  111. PointerStyle pointerStyle; //指针样式
  112. bool reverse; //是否往回走
  113. double currentValue; //当前值
  114. QTimer *timer; //定时器绘制动画
  115. public:
  116. double getMinValue() const;
  117. double getMaxValue() const;
  118. double getValue() const;
  119. int getPrecision() const;
  120. int getScaleMajor() const;
  121. int getScaleMinor() const;
  122. int getStartAngle() const;
  123. int getEndAngle() const;
  124. bool getAnimation() const;
  125. double getAnimationStep() const;
  126. QColor getOuterCircleColor() const;
  127. QColor getInnerCircleColor() const;
  128. QColor getPieColorStart() const;
  129. QColor getPieColorMid() const;
  130. QColor getPieColorEnd() const;
  131. QColor getCoverCircleColor() const;
  132. QColor getScaleColor() const;
  133. QColor getPointerColor() const;
  134. QColor getCenterCircleColor() const;
  135. QColor getTextColor() const;
  136. bool getShowOverlay() const;
  137. QColor getOverlayColor() const;
  138. PieStyle getPieStyle() const;
  139. PointerStyle getPointerStyle() const;
  140. QSize sizeHint() const;
  141. QSize minimumSizeHint() const;
  142. public Q_SLOTS:
  143. //设置范围值
  144. void setRange(double minValue, double maxValue);
  145. void setRange(int minValue, int maxValue);
  146. //设置最大最小值
  147. void setMinValue(double minValue);
  148. void setMaxValue(double maxValue);
  149. //设置目标值
  150. void setValue(double value);
  151. void setValue(int value);
  152. //设置精确度
  153. void setPrecision(int precision);
  154. //设置主刻度数量
  155. void setScaleMajor(int scaleMajor);
  156. //设置小刻度数量
  157. void setScaleMinor(int scaleMinor);
  158. //设置开始旋转角度
  159. void setStartAngle(int startAngle);
  160. //设置结束旋转角度
  161. void setEndAngle(int endAngle);
  162. //设置是否启用动画显示
  163. void setAnimation(bool animation);
  164. //设置动画显示的步长
  165. void setAnimationStep(double animationStep);
  166. //设置外圆背景颜色
  167. void setOuterCircleColor(const QColor &outerCircleColor);
  168. //设置内圆背景颜色
  169. void setInnerCircleColor(const QColor &innerCircleColor);
  170. //设置饼圆三种颜色
  171. void setPieColorStart(const QColor &pieColorStart);
  172. void setPieColorMid(const QColor &pieColorMid);
  173. void setPieColorEnd(const QColor &pieColorEnd);
  174. //设置覆盖圆背景颜色
  175. void setCoverCircleColor(const QColor &coverCircleColor);
  176. //设置刻度尺颜色
  177. void setScaleColor(const QColor &scaleColor);
  178. //设置指针颜色
  179. void setPointerColor(const QColor &pointerColor);
  180. //设置中心圆颜色
  181. void setCenterCircleColor(const QColor &centerCircleColor);
  182. //设置文本颜色
  183. void setTextColor(const QColor &textColor);
  184. //设置是否显示遮罩层
  185. void setShowOverlay(bool showOverlay);
  186. //设置遮罩层颜色
  187. void setOverlayColor(const QColor &overlayColor);
  188. //设置饼图样式
  189. void setPieStyle(const PieStyle &pieStyle);
  190. //设置指针样式
  191. void setPointerStyle(const PointerStyle &pointerStyle);
  192. Q_SIGNALS:
  193. void valueChanged(int value);
  194. };
  195. #endif //GAUGECAR_H

核心代码

  1. void GaugeCar::paintEvent(QPaintEvent *)
  2. {
  3. int width = this->width();
  4. int height = this->height();
  5. int side = qMin(width, height);
  6. //绘制准备工作,启用反锯齿,平移坐标轴中心,等比例缩放
  7. QPainter painter(this);
  8. painter.setRenderHints(QPainter::Antialiasing | QPainter::TextAntialiasing);
  9. painter.translate(width / 2, height / 2);
  10. painter.scale(side / 200.0, side / 200.0);
  11. //绘制外圆
  12. drawOuterCircle(&painter);
  13. //绘制内圆
  14. drawInnerCircle(&painter);
  15. //绘制饼圆
  16. drawColorPie(&painter);
  17. //绘制覆盖圆 用以遮住饼圆多余部分
  18. drawCoverCircle(&painter);
  19. //绘制刻度线
  20. drawScale(&painter);
  21. //绘制刻度值
  22. drawScaleNum(&painter);
  23. //根据指示器形状绘制指示器
  24. if (pointerStyle == PointerStyle_Circle) {
  25. drawPointerCircle(&painter);
  26. } else if (pointerStyle == PointerStyle_Indicator) {
  27. drawPointerIndicator(&painter);
  28. } else if (pointerStyle == PointerStyle_IndicatorR) {
  29. drawPointerIndicatorR(&painter);
  30. } else if (pointerStyle == PointerStyle_Triangle) {
  31. drawPointerTriangle(&painter);
  32. }
  33. //绘制指针中心圆外边框
  34. drawRoundCircle(&painter);
  35. //绘制指针中心圆
  36. drawCenterCircle(&painter);
  37. //绘制当前值
  38. drawValue(&painter);
  39. //绘制遮罩层
  40. drawOverlay(&painter);
  41. }
  42. void GaugeCar::drawOuterCircle(QPainter *painter)
  43. {
  44. int radius = 99;
  45. painter->save();
  46. painter->setPen(Qt::NoPen);
  47. painter->setBrush(outerCircleColor);
  48. painter->drawEllipse(-radius, -radius, radius * 2, radius * 2);
  49. painter->restore();
  50. }
  51. void GaugeCar::drawInnerCircle(QPainter *painter)
  52. {
  53. int radius = 90;
  54. painter->save();
  55. painter->setPen(Qt::NoPen);
  56. painter->setBrush(innerCircleColor);
  57. painter->drawEllipse(-radius, -radius, radius * 2, radius * 2);
  58. painter->restore();
  59. }
  60. void GaugeCar::drawColorPie(QPainter *painter)
  61. {
  62. int radius = 60;
  63. painter->save();
  64. painter->setPen(Qt::NoPen);
  65. QRectF rect(-radius, -radius, radius * 2, radius * 2);
  66. if (pieStyle == PieStyle_Three) {
  67. //计算总范围角度,根据占比例自动计算三色圆环范围角度
  68. //可以更改比例
  69. double angleAll = 360.0 - startAngle - endAngle;
  70. double angleStart = angleAll * 0.7;
  71. double angleMid = angleAll * 0.15;
  72. double angleEnd = angleAll * 0.15;
  73. //增加偏移量使得看起来没有脱节
  74. int offset = 3;
  75. //绘制开始饼圆
  76. painter->setBrush(pieColorStart);
  77. painter->drawPie(rect, (270 - startAngle - angleStart) * 16, angleStart * 16);
  78. //绘制中间饼圆
  79. painter->setBrush(pieColorMid);
  80. painter->drawPie(rect, (270 - startAngle - angleStart - angleMid) * 16 + offset, angleMid * 16);
  81. //绘制结束饼圆
  82. painter->setBrush(pieColorEnd);
  83. painter->drawPie(rect, (270 - startAngle - angleStart - angleMid - angleEnd) * 16 + offset * 2, angleEnd * 16);
  84. } else if (pieStyle == PieStyle_Current) {
  85. //计算总范围角度,当前值范围角度,剩余值范围角度
  86. double angleAll = 360.0 - startAngle - endAngle;
  87. double angleCurrent = angleAll * ((currentValue - minValue) / (maxValue - minValue));
  88. double angleOther = angleAll - angleCurrent;
  89. //绘制当前值饼圆
  90. painter->setBrush(pieColorStart);
  91. painter->drawPie(rect, (270 - startAngle - angleCurrent) * 16, angleCurrent * 16);
  92. //绘制剩余值饼圆
  93. painter->setBrush(pieColorEnd);
  94. painter->drawPie(rect, (270 - startAngle - angleCurrent - angleOther) * 16, angleOther * 16);
  95. }
  96. painter->restore();
  97. }
  98. void GaugeCar::drawCoverCircle(QPainter *painter)
  99. {
  100. int radius = 50;
  101. painter->save();
  102. painter->setPen(Qt::NoPen);
  103. painter->setBrush(coverCircleColor);
  104. painter->drawEllipse(-radius, -radius, radius * 2, radius * 2);
  105. painter->restore();
  106. }
  107. void GaugeCar::drawScale(QPainter *painter)
  108. {
  109. int radius = 72;
  110. painter->save();
  111. painter->rotate(startAngle);
  112. int steps = (scaleMajor * scaleMinor);
  113. double angleStep = (360.0 - startAngle - endAngle) / steps;
  114. QPen pen;
  115. pen.setColor(scaleColor);
  116. pen.setCapStyle(Qt::RoundCap);
  117. for (int i = 0; i <= steps; i++) {
  118. if (i % scaleMinor == 0) {
  119. pen.setWidthF(1.5);
  120. painter->setPen(pen);
  121. painter->drawLine(0, radius - 10, 0, radius);
  122. } else {
  123. pen.setWidthF(0.5);
  124. painter->setPen(pen);
  125. painter->drawLine(0, radius - 5, 0, radius);
  126. }
  127. painter->rotate(angleStep);
  128. }
  129. painter->restore();
  130. }
  131. void GaugeCar::drawScaleNum(QPainter *painter)
  132. {
  133. int radius = 82;
  134. painter->save();
  135. painter->setPen(scaleColor);
  136. double startRad = (360 - startAngle - 90) * (M_PI / 180);
  137. double deltaRad = (360 - startAngle - endAngle) * (M_PI / 180) / scaleMajor;
  138. for (int i = 0; i <= scaleMajor; i++) {
  139. double sina = qSin(startRad - i * deltaRad);
  140. double cosa = qCos(startRad - i * deltaRad);
  141. double value = 1.0 * i * ((maxValue - minValue) / scaleMajor) + minValue;
  142. QString strValue = QString("%1").arg((double)value, 0, 'f', precision);
  143. double textWidth = fontMetrics().width(strValue);
  144. double textHeight = fontMetrics().height();
  145. int x = radius * cosa - textWidth / 2;
  146. int y = -radius * sina + textHeight / 4;
  147. painter->drawText(x, y, strValue);
  148. }
  149. painter->restore();
  150. }
  151. void GaugeCar::drawPointerCircle(QPainter *painter)
  152. {
  153. int radius = 6;
  154. int offset = 30;
  155. painter->save();
  156. painter->setPen(Qt::NoPen);
  157. painter->setBrush(pointerColor);
  158. painter->rotate(startAngle);
  159. double degRotate = (360.0 - startAngle - endAngle) / (maxValue - minValue) * (currentValue - minValue);
  160. painter->rotate(degRotate);
  161. painter->drawEllipse(-radius, radius + offset, radius * 2, radius * 2);
  162. painter->restore();
  163. }
  164. void GaugeCar::drawPointerIndicator(QPainter *painter)
  165. {
  166. int radius = 75;
  167. painter->save();
  168. painter->setOpacity(0.8);
  169. painter->setPen(Qt::NoPen);
  170. painter->setBrush(pointerColor);
  171. QPolygon pts;
  172. pts.setPoints(3, -5, 0, 5, 0, 0, radius);
  173. painter->rotate(startAngle);
  174. double degRotate = (360.0 - startAngle - endAngle) / (maxValue - minValue) * (currentValue - minValue);
  175. painter->rotate(degRotate);
  176. painter->drawConvexPolygon(pts);
  177. painter->restore();
  178. }
  179. void GaugeCar::drawPointerIndicatorR(QPainter *painter)
  180. {
  181. int radius = 75;
  182. painter->save();
  183. painter->setOpacity(1.0);
  184. QPen pen;
  185. pen.setWidth(1);
  186. pen.setColor(pointerColor);
  187. painter->setPen(pen);
  188. painter->setBrush(pointerColor);
  189. QPolygon pts;
  190. pts.setPoints(3, -5, 0, 5, 0, 0, radius);
  191. painter->rotate(startAngle);
  192. double degRotate = (360.0 - startAngle - endAngle) / (maxValue - minValue) * (currentValue - minValue);
  193. painter->rotate(degRotate);
  194. painter->drawConvexPolygon(pts);
  195. //增加绘制圆角直线,与之前三角形重叠,形成圆角指针
  196. pen.setCapStyle(Qt::RoundCap);
  197. pen.setWidthF(4);
  198. painter->setPen(pen);
  199. painter->drawLine(0, 0, 0, radius);
  200. painter->restore();
  201. }
  202. void GaugeCar::drawPointerTriangle(QPainter *painter)
  203. {
  204. int radius = 10;
  205. int offset = 38;
  206. painter->save();
  207. painter->setPen(Qt::NoPen);
  208. painter->setBrush(pointerColor);
  209. QPolygon pts;
  210. pts.setPoints(3, -5, 0 + offset, 5, 0 + offset, 0, radius + offset);
  211. painter->rotate(startAngle);
  212. double degRotate = (360.0 - startAngle - endAngle) / (maxValue - minValue) * (currentValue - minValue);
  213. painter->rotate(degRotate);
  214. painter->drawConvexPolygon(pts);
  215. painter->restore();
  216. }
  217. void GaugeCar::drawRoundCircle(QPainter *painter)
  218. {
  219. int radius = 18;
  220. painter->save();
  221. painter->setOpacity(0.8);
  222. painter->setPen(Qt::NoPen);
  223. painter->setBrush(pointerColor);
  224. painter->drawEllipse(-radius, -radius, radius * 2, radius * 2);
  225. painter->restore();
  226. }
  227. void GaugeCar::drawCenterCircle(QPainter *painter)
  228. {
  229. int radius = 15;
  230. painter->save();
  231. painter->setPen(Qt::NoPen);
  232. painter->setBrush(centerCircleColor);
  233. painter->drawEllipse(-radius, -radius, radius * 2, radius * 2);
  234. painter->restore();
  235. }
  236. void GaugeCar::drawValue(QPainter *painter)
  237. {
  238. int radius = 100;
  239. painter->save();
  240. painter->setPen(textColor);
  241. QFont font;
  242. font.setPixelSize(18);
  243. painter->setFont(font);
  244. QRectF textRect(-radius, -radius, radius * 2, radius * 2);
  245. QString strValue = QString("%1").arg((double)currentValue, 0, 'f', precision);
  246. painter->drawText(textRect, Qt::AlignCenter, strValue);
  247. painter->restore();
  248. }
  249. void GaugeCar::drawOverlay(QPainter *painter)
  250. {
  251. if (!showOverlay) {
  252. return;
  253. }
  254. int radius = 90;
  255. painter->save();
  256. painter->setPen(Qt::NoPen);
  257. QPainterPath smallCircle;
  258. QPainterPath bigCircle;
  259. radius -= 1;
  260. smallCircle.addEllipse(-radius, -radius, radius * 2, radius * 2);
  261. radius *= 2;
  262. bigCircle.addEllipse(-radius, -radius + 140, radius * 2, radius * 2);
  263. //高光的形状为小圆扣掉大圆的部分
  264. QPainterPath highlight = smallCircle - bigCircle;
  265. QLinearGradient linearGradient(0, -radius / 2, 0, 0);
  266. overlayColor.setAlpha(100);
  267. linearGradient.setColorAt(0.0, overlayColor);
  268. overlayColor.setAlpha(30);
  269. linearGradient.setColorAt(1.0, overlayColor);
  270. painter->setBrush(linearGradient);
  271. painter->rotate(-20);
  272. painter->drawPath(highlight);
  273. painter->restore();
  274. }

控件介绍

  1. 超过130个精美控件,涵盖了各种仪表盘、进度条、进度球、指南针、曲线图、标尺、温度计、导航条、导航栏,flatui、高亮按钮、滑动选择器、农历等。远超qwt集成的控件数量。
  2. 每个类都可以独立成一个单独的控件,零耦合,每个控件一个头文件和一个实现文件,不依赖其他文件,方便单个控件以源码形式集成到项目中,较少代码量。qwt的控件类环环相扣,高度耦合,想要使用其中一个控件,必须包含所有的代码。
  3. 全部纯Qt编写,QWidget+QPainter绘制,支持Qt4.6到Qt5.12的任何Qt版本,支持mingw、msvc、gcc等编译器,不乱码,可直接集成到Qt Creator中,和自带的控件一样使用,大部分效果只要设置几个属性即可,极为方便。
  4. 每个控件都有一个对应的单独的包含该控件源码的DEMO,方便参考使用。同时还提供一个所有控件使用的集成的DEMO。
  5. 每个控件的源代码都有详细中文注释,都按照统一设计规范编写,方便学习自定义控件的编写。
  6. 每个控件默认配色和demo对应的配色都非常精美。
  7. 超过120个可见控件,6个不可见控件。
  8. 部分控件提供多种样式风格选择,多种指示器样式选择。
  9. 所有控件自适应窗体拉伸变化。
  10. 集成自定义控件属性设计器,支持拖曳设计,所见即所得,支持导入导出xml格式。
  11. 自带activex控件demo,所有控件可以直接运行在ie浏览器中。
  12. 集成fontawesome图形字体+阿里巴巴iconfont收藏的几百个图形字体,享受图形字体带来的乐趣。
  13. 所有控件最后生成一个dll动态库文件,可以直接集成到qtcreator中拖曳设计使用。

SDK下载



Qt编写自定义控件1-汽车仪表盘的更多相关文章

  1. Qt编写自定义控件3-速度仪表盘

    前言 速度仪表盘,写作之初的本意是用来展示当前测试的网速用的,三色圆环+数码管显示当前速度,Qt自带了数码管控件QLCDNumber,直接集成即可,同时还带有动画功能,其实也可以用在汽车+工业领域等, ...

  2. Qt编写自定义控件10-云台仪表盘

    前言 做过安防视频监控的同学都清楚,在视频监控系统软件上都可以看到一个云台控制区域,可以对球机进行下下左右等八个方位的运动控制,还可以进行复位,一般都是美工作图好,然后贴图的形式加入到软件中,好处是程 ...

  3. Qt编写自定义控件4-旋转仪表盘

    前言 旋转仪表盘,一般用在需要触摸调节设置值的场景中,其实Qt本身就提供了QDial控件具有类似的功能,本控件最大的难点不在于绘制刻度和指针等,而在于自动计算当前用户按下处的坐标转换为当前值,这个功能 ...

  4. Qt编写自定义控件12-进度仪表盘

    前言 进度仪表盘主要应用场景是标识一个任务进度完成的状况等,可以自由的设置范围值和当前值,为了美观还提供了四种指示器(圆形指示器/指针指示器/圆角指针指示器/三角形指示器),各种颜色都可以设置,其中的 ...

  5. Qt编写自定义控件54-时钟仪表盘

    一.前言 这个控件没有太多的应用场景,主要就是练手,论美观的话比不上之前发过的一个图片时钟控件,所以此控件也是作为一个基础的绘制demo出现在Qt源码中,我们可以在Qt的安装目录下找到一个时钟控件的绘 ...

  6. Qt编写自定义控件51-可输入仪表盘

    一.前言 这个控件是近期定制的控件,还是比较实用的控件之一,用户主要是提了三点需求,一点是切换焦点的时候控件放大突出显示,一点是可直接输入或者编辑值,还有一点是支持上下键及翻页键和鼠标滚轮来动态修改值 ...

  7. Qt编写自定义控件50-迷你仪表盘

    一.前言 这个控件取名叫迷你仪表盘,是以为该控件可以缩小到很小很小的区域显示,非常适合小面积区域展示仪表数据使用,还可以手动触摸调节进度,是我个人觉得最漂亮小巧的一个控件.初次看到类似的控件是在一个音 ...

  8. Qt编写自定义控件49-飞机仪表盘

    一.前言 飞行仪表是测定和表示飞机数据的工具,飞机中必不可少的一部分,飞行员根据飞行仪表表示的数据才能正确地做出判断.一般飞机仪表包括高度表+空速表+垂直速率表+姿态仪+航向指示表+转弯协调表. 这次 ...

  9. Qt编写自定义控件44-天气仪表盘

    一.前言 天气仪表盘控件是所有控件中唯一一个使用了svg矢量图的控件,各种天气图标采用的矢量图,颜色变换采用动态载入svg的内容更改生成的,其实也可以采用图形字体来做,本次控件为了熟悉下svg在Qt中 ...

随机推荐

  1. Linux C Socket TCP编程介绍及实例

    转自:https://blog.csdn.net/lell3538/article/details/53335231 { printf("向服务器发送数据:%s\n",sendbu ...

  2. 奇怪吸引子---Qi

    奇怪吸引子是混沌学的重要组成理论,用于演化过程的终极状态,具有如下特征:终极性.稳定性.吸引性.吸引子是一个数学概念,描写运动的收敛类型.它是指这样的一个集合,当时间趋于无穷大时,在任何一个有界集上出 ...

  3. phpstorm10使用服务激活

    现在官网已经更新到WebStorm 11.PhpStorm 10,找到一个很便捷的方法,不需要注册码了.安装完成,打开软件看到输入注册码界面的时候,切换到第二个选项,输入:http://idea.la ...

  4. (亲测解决)每次打开excel文件都会出现两个窗口,一个是空白的sheet1,另一个是自己的文档

    版权声明:本文为博主原创文章,转载请注明出处! https://blog.csdn.net/sinat_34104446/article/details/80210424 一.问题描述每次打开Exce ...

  5. phpBB3.2 自动检测浏览器语言

    这是根据HTTP request header里的Accept-Language信息来处理的. 首先看一下Accept-Language的格式 Accept-Language: <languag ...

  6. Linux-文件描述符的本质及与文件指针的区别

    文章参考:文件描述符的本质.文件描述符和文件指针的区别.文件描述符fd和文件指针flip的理解 推荐:task_struct 和文件系统的关系 系统中文件相关表 右侧的表称为i节点表,在整个系统中只有 ...

  7. OpenCV 学习笔记 06 图像检索以及基于图像描述符的搜索

    OpenCV 可以检测图像的主要特征,然后提取这些特征,使其成为图像描述符,这些图像特征可作为图像搜索的数据库:此外可以利用关键点将图像拼接 stitch 起来,组成一个更大的图像.如将各照片组成一个 ...

  8. 1 翻译系列:什么是Code First(EF 6 Code First 系列)

    原文链接:http://www.entityframeworktutorial.net/code-first/what-is-code-first.aspx EF 6 Code-First系列文章目录 ...

  9. input框触发回车事件

    window.event只能在IE下运行,不能在firefox下运行,这是因为firefox的event只能在事件发生的现场使用.   在firefox里直接调用event对象会报undefined. ...

  10. vue中全选和取消

    1.效果预览 2.index.html <!DOCTYPE html> <html lang="en"> <head> <meta cha ...