Qt22双缓冲机制

2024-09-02 20:36
文章标签 机制 缓冲 qt22

本文主要是介绍Qt22双缓冲机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Qt22双缓冲机制

  • 知识点
  • drawwidget
    • drawwidget.h
    • drawwidget.cpp
  • mainwindow
    • mainwindow.h
    • mainwindow.cpp
  • main.cpp
  • 运行图

知识点

双缓冲就是在内存区申请一块缓存;然后显卡直接从这块内存读取数据.。
这样就不用鼠标边画,经过IO来读取这个环节;

鼠标驱动 — 内存缓冲区— 显卡

drawwidget

drawwidget.h

#ifndef DRAWWIDGET_H
#define DRAWWIDGET_H#include <QMainWindow>
#include <QtGui>
#include <QMouseEvent>
#include <QPaintEvent>
#include <QResizeEvent>
#include <QColor>
#include <QPixmap>
#include <QPoint>
#include <QPainter>
#include <QPalette>
#include <QPen>class drawWidget : public QWidget
{Q_OBJECTpublic:explicit drawWidget(QWidget* parent = 0);public:void mousePressEvent(QMouseEvent*);void mouseMoveEvent(QMouseEvent*);void paintEvent(QPaintEvent*);void resizeEvent(QResizeEvent*);public slots:void setStyle(int);void setWidth(int);void setColor(QColor);void clear();
private:QPixmap* pix;QPoint startPos;QPoint endPos;int style;int weight;QColor color;};
#endif // DRAWWIDGET_H

drawwidget.cpp

#include "drawwidget.h"drawWidget::drawWidget(QWidget *parent): QWidget(parent)
{setAutoFillBackground(true);setPalette(QPalette(Qt::white));pix = new QPixmap(size());pix->fill(Qt::white);setMinimumSize(600,400);
}void drawWidget::mousePressEvent(QMouseEvent * e)
{startPos = e->pos();
}void drawWidget::mouseMoveEvent(QMouseEvent *e)
{QPainter *painter = new QPainter;QPen pen;pen.setStyle((Qt::PenStyle)style);pen.setWidth(weight);pen.setColor(color);painter->begin(pix);painter->setPen(pen);painter->drawLine(startPos,e->pos());painter->end();startPos = e->pos();update();}void drawWidget::paintEvent(QPaintEvent *)
{//把图片内存的数据  绘制到窗体控件中QPainter painter(this);painter.drawPixmap(QPoint(0,0),*pix);
}void drawWidget::resizeEvent(QResizeEvent *event)
{if(height()>pix->height() || width()>pix->width())//如果图片尺寸发生改变{QPixmap *newPix = new QPixmap(size());newPix->fill(Qt::white);QPainter p(newPix);p.drawPixmap(QPoint(0,0),*pix);pix = newPix;}QWidget::resizeEvent(event);
}void drawWidget::setStyle(int s)
{style = s;
}void drawWidget::setWidth(int w)
{weight = w;}void drawWidget::setColor(QColor c)
{color = c;
}void drawWidget::clear()
{QPixmap *clearPix = new QPixmap(size());clearPix->fill(Qt::white);pix = clearPix;update();
}

mainwindow

mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include <QMainWindow>
#include <QToolButton>
#include <QLabel>
#include <QComboBox>
#include <QSpinBox>
#include <QToolBar>
#include <QColorDialog>#include "drawwidget.h"class MainWindow : public QMainWindow
{Q_OBJECT
public:MainWindow(QWidget *parent = nullptr);~MainWindow();void createToolBar();signals:
public slots:void ShowStyle();void ShowColor();
private:drawWidget *drawwidget;QLabel* styleLabel;QComboBox* styleComboBox;QLabel* widthLabel;QSpinBox* widthSpinBox;QToolButton* colorBtn;QToolButton* clearBtn;
};#endif // MAINWINDOW_H

mainwindow.cpp

#include "mainwindow.h"MainWindow::MainWindow(QWidget *parent): QMainWindow{parent}
{drawwidget = new drawWidget;setCentralWidget(drawwidget);createToolBar();setMinimumSize(600,400);ShowStyle();drawwidget->setWidth(widthSpinBox->value());drawwidget->setColor(Qt::black);
}MainWindow::~MainWindow()
{}void MainWindow::createToolBar()
{QToolBar* toolBar = addToolBar("Tool");styleLabel = new QLabel(tr("线型风格:"));styleComboBox = new QComboBox;styleComboBox->addItem(tr("SolidLine"),static_cast<int>(Qt::SolidLine));styleComboBox->addItem(tr("DashLine"),static_cast<int>(Qt::DashLine));styleComboBox->addItem(tr("DotLine"),static_cast<int>(Qt::DotLine));styleComboBox->addItem(tr("DashDotLine"),static_cast<int>(Qt::DashDotLine));styleComboBox->addItem(tr("DashDotDotLine"),static_cast<int>(Qt::DashDotDotLine));connect(styleComboBox,static_cast<void (QComboBox::*)(int)>(&QComboBox::activated),this,&MainWindow::ShowStyle);widthLabel = new QLabel(tr("线宽:"));widthSpinBox =new QSpinBox;connect(widthSpinBox,static_cast<void (QSpinBox::*)(int)>(&QSpinBox::valueChanged),drawwidget,&drawWidget::setWidth);colorBtn = new QToolButton;QPixmap pixmap(20,20);pixmap.fill(Qt::black);colorBtn->setIcon(QIcon(pixmap));connect(colorBtn,&QToolButton::clicked,this,&MainWindow::ShowColor);clearBtn = new QToolButton;clearBtn->setText(tr("清除"));connect(clearBtn,&QToolButton::clicked,drawwidget,&drawWidget::clear);toolBar->addWidget(styleLabel);toolBar->addWidget(styleComboBox);toolBar->addWidget(widthLabel);toolBar->addWidget(widthSpinBox);toolBar->addWidget(colorBtn);toolBar->addWidget(clearBtn);}void MainWindow::ShowStyle()
{drawwidget->setStyle(styleComboBox->itemData(styleComboBox->currentIndex(),Qt::UserRole).toInt());}void MainWindow::ShowColor()
{QColor color =QColorDialog::getColor(static_cast<int>(Qt::black));if(color.isValid()){drawwidget->setColor(color);QPixmap p(20,20);p.fill(color);colorBtn->setIcon(QIcon(p));}}

main.cpp

#include "mainwindow.h"#include <QApplication>
#include <QFont>int main(int argc, char *argv[])
{QApplication a(argc, argv);QFont font("ZYSong18030",12);a.setFont(font);MainWindow w;w.show();return a.exec();
}

运行图

在这里插入图片描述

这篇关于Qt22双缓冲机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1130997

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

【Tools】大模型中的自注意力机制

摇来摇去摇碎点点的金黄 伸手牵来一片梦的霞光 南方的小巷推开多情的门窗 年轻和我们歌唱 摇来摇去摇着温柔的阳光 轻轻托起一件梦的衣裳 古老的都市每天都改变模样                      🎵 方芳《摇太阳》 自注意力机制(Self-Attention)是一种在Transformer等大模型中经常使用的注意力机制。该机制通过对输入序列中的每个元素计算与其他元素之间的相似性,

如何通俗理解注意力机制?

1、注意力机制(Attention Mechanism)是机器学习和深度学习中一种模拟人类注意力的方法,用于提高模型在处理大量信息时的效率和效果。通俗地理解,它就像是在一堆信息中找到最重要的部分,把注意力集中在这些关键点上,从而更好地完成任务。以下是几个简单的比喻来帮助理解注意力机制: 2、寻找重点:想象一下,你在阅读一篇文章的时候,有些段落特别重要,你会特别注意这些段落,反复阅读,而对其他部分

【Tools】大模型中的注意力机制

摇来摇去摇碎点点的金黄 伸手牵来一片梦的霞光 南方的小巷推开多情的门窗 年轻和我们歌唱 摇来摇去摇着温柔的阳光 轻轻托起一件梦的衣裳 古老的都市每天都改变模样                      🎵 方芳《摇太阳》 在大模型中,注意力机制是一种重要的技术,它被广泛应用于自然语言处理领域,特别是在机器翻译和语言模型中。 注意力机制的基本思想是通过计算输入序列中各个位置的权重,以确

FreeRTOS内部机制学习03(事件组内部机制)

文章目录 事件组使用的场景事件组的核心以及Set事件API做的事情事件组的特殊之处事件组为什么不关闭中断xEventGroupSetBitsFromISR内部是怎么做的? 事件组使用的场景 学校组织秋游,组长在等待: 张三:我到了 李四:我到了 王五:我到了 组长说:好,大家都到齐了,出发! 秋游回来第二天就要提交一篇心得报告,组长在焦急等待:张三、李四、王五谁先写好就交谁的

UVM:callback机制的意义和用法

1. 作用         Callback机制在UVM验证平台,最大用处就是为了提高验证平台的可重用性。在不创建复杂的OOP层次结构前提下,针对组件中的某些行为,在其之前后之后,内置一些函数,增加或者修改UVM组件的操作,增加新的功能,从而实现一个环境多个用例。此外还可以通过Callback机制构建异常的测试用例。 2. 使用步骤         (1)在UVM组件中内嵌callback函

Smarty模板引擎工作机制(一)

深入浅出Smarty模板引擎工作机制,我们将对比使用smarty模板引擎和没使用smarty模板引擎的两种开发方式的区别,并动手开发一个自己的模板引擎,以便加深对smarty模板引擎工作机制的理解。 在没有使用Smarty模板引擎的情况下,我们都是将PHP程序和网页模板合在一起编辑的,好比下面的源代码: <?php$title="深处浅出之Smarty模板引擎工作机制";$content=

Redis的rehash机制

在Redis中,键值对(Key-Value Pair)存储方式是由字典(Dict)保存的,而字典底层是通过哈希表来实现的。通过哈希表中的节点保存字典中的键值对。我们知道当HashMap中由于Hash冲突(负载因子)超过某个阈值时,出于链表性能的考虑,会进行Resize的操作。Redis也一样。 在redis的具体实现中,使用了一种叫做渐进式哈希(rehashing)的机制来提高字典的缩放效率,避