[Qt2D绘图]-06QPainter的复合模式&&双缓冲绘图&&绘图中的其他问题
void Widget::paintEvent(QPaintEvent *)
{
QPainter painter; QImage image(,,QImage::Format_ARGB32_Premultiplied);
// 使用绘图设备,绘制到绘图设备上
painter.begin(&image);
// 绘制一个矩形
painter.setBrush(Qt::green);
painter.drawRect(,,,); //在四个角分别绘制一个矩形,使用不同的复合模式(composition)
painter.setBrush(QColor(,,,));
//composition没有设置则使用默认的SourceOver
painter.drawRect(,,,);
//QPainter::CompositionMode_SourceIn
painter.setCompositionMode(QPainter::CompositionMode_SourceIn);
painter.drawRect(,,,);
//QPainter::CompositionMode_DestinationOver
painter.setCompositionMode(QPainter::CompositionMode_DestinationOver);
painter.drawRect(,,,);
//QPainter::CompositionMode_Xor
painter.setCompositionMode(QPainter::CompositionMode_Xor);
painter.drawRect(,,,);
painter.end(); // 绘制到当前部件(当前绘图设备是QWidget的子类,也就是部件)
painter.begin(this);
painter.drawImage(,,image);
}
#include "widget.h"
#include "ui_widget.h" #include <QMouseEvent>
#include <QPainter> Widget::Widget(QWidget *parent) : QWidget(parent), ui(new Ui::Widget) {
ui->setupUi(this);
pix_buffer_ = QPixmap(, );
pix_buffer_.fill(Qt::white);
temp_pix_buffer_ = pix_buffer_;
is_drawing_ = false;
} Widget::~Widget() { delete ui; } void Widget::mousePressEvent(QMouseEvent *event) {
if(event->button() == Qt::LeftButton){
//当鼠标左键按下时获取当前位置作为矩形的开始点
start_point_ = event->pos();
is_drawing_ = true;
}
} void Widget::mouseMoveEvent(QMouseEvent *event) {
if(event->button() & Qt::LeftButton){
//当按着鼠标左键进行移动时,获取当前位置作为结束点,绘制矩形
end_point_ = event->pos();
//将缓冲区的内容复制到临时缓冲区,这样进行动态绘制时
//每次都是在缓冲区图像的基上进行绘制,就不会产生拖影现象了
temp_pix_buffer_ = pix_buffer_;
// 更新显示
update();
}
} void Widget::mouseReleaseEvent(QMouseEvent *event) {
if(event->button()== Qt::LeftButton){
//当鼠标左键松开时,获取当前位置为结束点,完成矩形绘制
end_point_ = event->pos();
//标记已经结束绘图
is_drawing_ = false;
update();
}
} void Widget::paintEvent(QPaintEvent *) {
int x = start_point_.x();
int y = start_point_.y();
int width = end_point_.x();
int height = end_point_.y(); QPainter painter;
painter.setPen(QColor(Qt::red));
painter.begin(&temp_pix_buffer_);
painter.drawRect(x,y,width,height);
painter.end(); painter.begin(this);
painter.drawPixmap(,,temp_pix_buffer_);
//如果已经完成了绘制,那么更新缓冲区
if(!is_drawing_){
pix_buffer_ = temp_pix_buffer_;
}
}
- repaint()函数或者update()函数被调用;
- 被隐藏的部件现在被重新显示;
- other
QPainter painter(this);
// 剪切矩形中的内容
painter.setClipRect(,,,);
painter.drawText(,,"tudouTestTestTest");
[Qt2D绘图]-06QPainter的复合模式&&双缓冲绘图&&绘图中的其他问题的更多相关文章
- VC使用双缓冲避免绘图闪烁的正确使用方法【转】
使用内存DC绘图,然后实现双缓冲,避免绘图闪烁,这个小技术简单但很有效.但是仍然有很多人说使用了双缓冲,图片却仍然有闪烁,分析了几个这样的例子,发现 其实不是双缓冲的技术问题,而是使用者没有正确理解和 ...
- VC使用双缓冲制作绘图控件
最近用VC做了一个画图的控件.控件在使用的时候遇到点问题.在控件里画了图之后切换到其他页面,等再切换回来的时候,发现控件里画的图都不见了.这是因为VC里面,当缩小.遮挡页面后客户区域就会失效,当再次显 ...
- Android开发之用双缓冲技术绘图
双缓冲技术主要用在画图,动画效果上,其原理就是:将资源先载入到缓冲区,然后再将缓冲区整个载入到View上面去. 双缓冲技术可以有效防止闪烁,提高显示质量. DrawView.java: package ...
- VC GDI双缓冲机制绘图防屏幕闪烁实现步骤
在OnDraw(CDC* pDC) 中添加如下代码 CDC MemDC; //首先定义一个显示设备对象 CBitmap MemBitmap;//定义一个位图对象 //随后建立与屏幕显示兼容的内存显示设 ...
- Qt组件中的双缓冲无闪烁绘图
双缓冲绘图在Qt4中,所有的窗口部件默认都使用双缓冲进行绘图.使用双缓冲,可以减轻绘制的闪烁感.在有些情况下,用户要关闭双缓冲,自己管理绘图.下面的语句设置了窗口部件的Qt::WA_PaintOn ...
- C#-gdi绘图,双缓冲绘图,Paint事件的触发
一. 画面闪烁问题与双缓冲技术 1.1 导致画面闪烁的关键原因分析: 1 绘制窗口由于大小位置状态改变进行重绘操作时 绘图窗口内容或大小每改变一次,都要调用Paint事件进行重绘操作,该操作会使画面 ...
- [Android学习笔记]双缓冲绘图技术
双缓冲技术绘图: 什么情况下产生的双缓冲技术?当数据量很大时,绘图可能需要花费很长的时间,这样屏幕就会出现卡顿,闪烁等现象. 什么是双缓冲技术?双缓冲是在内存中创建一个与屏幕绘制区域一致的对象,先将图 ...
- java的双缓冲技术
Java的强大特性让其在游戏编程和多媒体动画处理方面也毫不逊色.在Java游戏编程和动画编程中最常见的就是对于屏幕闪烁的处理.本文从J2SE的一个再现了屏幕闪烁的Java Appilication简单 ...
- C# GDI+双缓冲技术
我想有很多搞图形方面的朋友都会用到双缓冲技术的时候,而且有的时候她的确是个头疼的问题.最近我也要用双缓冲技术,程序怎么调试都不合适,当要对图形进行移动时,总是会出现闪烁抖动.在网上找了些资料,说得都不 ...
随机推荐
- python_lesson2 多进程探索 (multiprocessing包)
进程池 进程池 (Process Pool)可以创建多个进程.这些进程就像是随时待命的士兵,准备执行任务(程序).一个进程池中可以容纳多个待命的士兵. import multiproces ...
- Docker数据管理与挂载管理
介绍如何在 Docker 内部以及容器之间管理数据:在容器中管理数据主要有两种方式:数据卷(Volumes).挂载主机目录 (Bind mounts) 镜像来源 [root@docker01 ~]# ...
- Java中设置多个Access-Control-Allow-Origin跨域访问
1.如果服务端是Java开发的,添加如下设置允许跨域即可,但是这样做是允许所有域名都可以访问,不够安全. response.setHeader("Access-Control-Allow-O ...
- Redis:rdb和aof
由于redis的数据都直接存储在内存里,在服务器发生宕机时内存的数据会瞬间清空,那么必须要有重启时恢复数据的方法. redis通过持久化机制将数据存储到磁盘中从而在服务器重启时恢复数据,这篇文章主要简 ...
- 安全测试中session和cookie
很多朋友做过安全测试应该都知道session和cookies他们的不同点: 1.存取方式不同.----cookie不支持中文,需要编码,仅支持ascll值.session能够存取任何类型的数据,包括j ...
- 从 Tapable 中得到的启发
Tapable Why Tapable 前端开发中 Webpack 本质上是基于事件流的运行机制,它的工作流程是将特定的任务分发到指定的事件钩子中去完成.而实现这一切的核心就是 tapable,Web ...
- fatal error C1189: #error : This file requires _WIN32_WINNT to be #defined at least to 0x0403. Value 0x0501 or higher is recommended.
说了原因,下面是修改方法,就是在stdafx.h文件中修改相关的定义,修改完后的效果应该如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 #ifndef WINVER ...
- PHP实现邮箱验证码验证功能
*文章来源:https://blog.egsec.cn/archives/623 (我的主站) *本文将主要说明:PHP实现邮箱验证码验证功能,通过注册或登录向用户发送身份确认验证码,并通过判断输入 ...
- TensorFlow中的显存管理器——BFC Allocator
背景 作者:DeepLearningStack,阿里巴巴算法工程师,开源TensorFlow Contributor] 使用GPU训练时,一次训练任务无论是模型参数还是中间结果都需要占用大量显存.为了 ...
- 注册表写入自定义协议,网页打开exe
新建文件:Register.reg,写入代码: Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\exe1] @="exe1 P ...