最近在画RHI的时候,发现需要保存上一次的QPainter画的内容,查资料发现双缓冲可以解决这个问题,特此记录一下。
双缓冲机制其实就是先画在pixmap上,再画到widget上。
注意:pixmap不能translate,他的左上角坐标固定为(0,0),且不可更改。
但是widget可以平移。
步骤:
其它函数将图画在pixmap上。
paintEvent函数将pixmap画在widget上。
双缓冲机制的使用场合:
- 所需绘制的内容较复杂,并且需频繁刷新。
- 每次只需刷新整个控件的一小部分。
void MainWindow::paintEvent(QPaintEvent *)
{
QPainter painter(this);
painter.drawPixmap(0,0,*m_pixmap);
}
//构造函数
m_pixmap = new QPixmap(size());
m_pixmap->fill(Qt::white);
timer = new QTimer(this);
connect(timer,&QTimer::timeout,this,&MainWindow::dealTimeOut);
//其它函数
void MainWindow::graphChart()
{
double scaleFactor = 1 / curScale;
QPainter painter(m_pixmap);
painter.translate(this->width()/2,this->height()/2);
painter.setRenderHint(QPainter::Antialiasing, true);
int r = m_pixmap->width()/4 ;
painter.drawEllipse(-r,-r,2*r,2*r);
painter.scale(scaleFactor, scaleFactor);
int num = 4;
// painter.setPen(Qt::red);
// painter.drawLine(0,0,r*cos(angle1*PI/180),-r*sin(angle1*PI/180));
qDebug()<<" angle1 "<<angle1<<" angle2 "<<angle2 <<r*cos(angle1*PI/180)<<r*sin(angle1*PI/180);
painter.setPen(Qt::NoPen);
for(int i = num;i > 0;i--)
{
painter.setBrush(QColor(122,50+30*i,100+20*i));
painter.drawPie(-r*i/num,-r*i/num,2*r*i/num,2*r*i/num,angle1*16,angle2*16);
qDebug()<<" r*i/num "<<r*i/num;
}
}
void MainWindow::dealTimeOut()
{
if(angle1 >360)
{
angle1 -= 5;
}
else
{
angle1+=5;
}
angle2 = angle1-5;
graphChart();
update();
}