QT时钟绘制
Demo的效果

资源占用还能接受

运行久一点内存就下去了

下面是Demo的代码
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include<QRect>
#include<QDateTime>
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
this->drawpixmap();//先画画布,再初始化窗口
ui->setupUi(this);
this->setWindowTitle(tr("Deom"));
timer=new QTimer(this);
timer->start();//每秒触发一次
connect(timer,SIGNAL(timeout()),this,SLOT(update()));
}
MainWindow::~MainWindow()
{
delete ui;
}
void MainWindow::paintEvent(QPaintEvent *event)
{
//手动双缓冲
QPainter paint(this);
paint.setRenderHint(QPainter::Antialiasing,true);//反走样处理打开
//在50,50的位置画入画布/所以圆点位置在窗口的160,160
paint.drawPixmap(,,*pix);
recttext=,,,);
QTime time=QDateTime::currentDateTime().time();
int hour=time.hour();
int minute=time.minute();
int second=time.second();
)
{
paint.drawText(*recttext,Qt::AlignTop|Qt::AlignHCenter,"PM");
}
else
{
paint.drawText(*recttext,Qt::AlignTop|Qt::AlignHCenter,"AM");
}
QTransform transformminute;
//以圆点坐标160,160做旋转中心
//画时分秒针
transformminute.translate(,);
transformminute.rotate(minute*+0.1*second);
paint.setTransform(transformminute);
paint.drawLine(-,-6,,);
QTransform transformsecond;
transformsecond.translate(,);
transformsecond.rotate(*second);
paint.setTransform(transformsecond);
paint.drawLine(-,-8,,);
QTransform transformhour;
transformhour.translate(,);
transformhour.rotate(*hour+0.5*minute);//忽略秒对时针的摆
paint.setTransform(transformhour);
paint.drawLine(-,-,,);
}
void MainWindow::drawpixmap()
{
//画布大小220*220
pix=,);
//用窗口背景色填充画布背景
pix->fill(this->palette().background().color());
QPainter paint(pix);
paint.setRenderHint(QPainter::Antialiasing,true);//反走样处理打开
//画圆
//圆心为110,110
paint.drawEllipse(,,,);
//这个rect适用于旋转和画数字刻度的
QRect* rect=,-,,);
QTransform tran;
//以圆心为旋转中心
tran.translate(,);
;i<=;i++)
{
//总共12个刻度,12段,每段30度
tran.rotate();
paint.setTransform(tran);
//绘制数字刻度,垂直最上,水平居中,
paint.drawText(*rect,Qt::AlignTop|Qt::AlignHCenter,QString::number(i));
//绘制线条刻度,
paint.drawLine(,-,,-);
}
//画圆点
paint.setBrush(Qt::black);
paint.drawEllipse(-,-,,);
}
API的使用
定义绘制工具paint的绘制对象是this
QPainter paint(this);
定义一个QTransform
QTransform transformsecond;
这里把旋转中心设定为绘制对象160,160的位置的同时,绘制时也会把160,160作为绘制工具的原点0,0
transformsecond.translate(,);
绘制出来的图像会以设定的顺时针旋转30度显示
transformsecond.rotate();
设置到paint绘制工具上
paint.setTransform(transformsecond);
在绘制对象原点的0,-60上画线,因为绘制工具的原点转移到绘制对象160,160,所以实际上是在绘制对象的(160,100)到(160,160)处画线
paint.drawLine(,-,,);
demo源码链接:http://pan.baidu.com/s/1c0qLRFE
QT时钟绘制的更多相关文章
- canvas自适应圆形时钟绘制
前面的话 前面介绍过canvas粒子时钟的绘制,本文将详细介绍canvas自适应圆形时钟绘制 效果演示 最终自适应圆形时钟的效果如下所示 功能分析 下面来分析一下该圆形时钟的功能 [1]静态背景 对于 ...
- 环形进度条的实现方法总结和动态时钟绘制(CSS3、SVG、Canvas)
缘由: 在某一个游戏公司的笔试中,最后一道大题是,“用CSS3实现根据动态显示时间和环形进度[效果如下图所示],且每个圆环的颜色不一样,不需要考虑IE6~8的兼容性”.当时第一想法是用SVG,因为SV ...
- QT界面绘制学习记录
1. MVC结构中,model必须作为类的成员变量存在,不可再函数内部申明.否则,会出现函数调用结束,model找不到的错误. 2.QcomboBox可设置为左边空白,右侧一小箭头的形式.代码:com ...
- Qt如何绘制(简单深刻,fearlazy的系列文章)
我觉得绘制只需要考虑几个问题.简单地说就是谁在什么地方画什么? 在Qt中可以这么回答:QPainter在QPainterDevice中画想画的东西. 举个例子:用QtCreator向导新建一个项目,基 ...
- Canvas - 时钟绘制
导语:距离上一次写canvas,已经过去两年半,如今业务需要,再次拾起,随手记录. [思考] 时钟的绘制主要在于圆的绘制:1. 使用context.arc()方法直接绘制圆或圆弧: 2. 使用圆的方程 ...
- 使用Qt开发绘制多个设备的流量曲线图(附带项目图)
一.说明: 在实际项目中,主要是使用Qt开发CS程序,当然主要是客户端.公司项目中有这个需求是实时显示多个设备的流量曲线图,设备将流量信息发给服务端,服务端再将信息通过Socket发给Qt客户端,Qt ...
- QT OpenGL绘制三维图形(立方体、圆柱体、圆锥、球体、圆环等等)
本文使用QGLWidget来绘制各种三维基本图形,包括立方体.圆柱体.圆锥.球体.圆环等等,涉及包括基本绘制以及上色.纹理.旋转等操作. 使用的软件版本:QT5.12 + QT Creater4.8. ...
- 初识Qt文字绘制
1.新建一个Qt Gui应用,项目名称为myDraw,基类选择为QMainWindow,类名设置为MainWindow. 2.在mainwindow.h头文件中添加void paintEvent(QP ...
- 采用Qt快速绘制多条曲线(折线),跟随鼠标动态显示线上点的值(基于Qt的开源绘图控件QCustomPlot进行二次开发)
QCustomPlot是一个开源的基于Qt的第三方绘图库,能够绘制漂亮的2D图形. QCustomPlot的官方网址:https://www.qcustomplot.com/ 从官网下载QCustom ...
随机推荐
- Oracle -- 连接每行的内容
select wm_concat(message) from ( select rownum no, 'Case ''' || code || '''' || '' || chr(10) ...
- 创业做移动互联网App的4个注意事项
导语:大多数人对于做App还是比較盲目,有个想法立刻就去做了.做出来了才忽然想到市场和推广.我把做移动 互联网App注意事项情给大家列下. 文| 移动互联网李建华 近 来,常常有人问我关于推广的事情, ...
- 有状态的EJB对象和无状态的EJB对象
一,定义有状态Bean和无状态Bean 有状态Bean: @Stateful @Remote public class StatefulEjbBean implements StatefulEjb{ ...
- tps 与 事务平均响应时间关系对答(转)
问者:每秒处理的事务数和事务的平均响应时间 怎么个关系,有关系吗 kaku21:举个例子:一个高速路 有10个入口,每个入口每秒钟只能进1辆车,请问1秒钟最多能进几辆车?? 问者:10 kaku21: ...
- vscode webstrom 配置 eslint 使用 airbnb 规范
1.安装eslint npm eslint-plugin-react eslint-plugin-import babel-eslint -g 2.全局配置文件,放到c:/user/***/ { &q ...
- 【题解】POJ1934 Trip (DP+记录方案)
[题解]POJ1934 Trip (DP+记录方案) 题意: 传送门 刚开始我是这么设状态的(谁叫我DP没学好) \(dp(i,j)\)表示钦定选择\(i\)和\(j\)的LCS,然而你会发现这样钦定 ...
- spring mvc头
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...
- Memcached的优点
核心知识点 memcached总的特点:简单.稳定.专注 1.简单的通信协议 a.通信协议:TCP b.序列化协议:文本的自定义协议 2.丰富的客户端程序:几乎支持所有的网络编程语言 3.高性能的网络 ...
- Flask简介
一. Python 现阶段三大主流Web框架 Django Tornado Flask 对比 1.Django 主要特点是大而全,集成了很多组件,例如: Models Admin Form 等等, 不 ...
- 原生Base64编码/解码(OC与Swift)
Objective-C NSString *plainString = @"foo"; Encoding NSData *plainData = [plainString data ...