Testing QImages vs QPixmaps and format conversion to solve upside down text bug

This commit is contained in:
Mark Watkins 2013-01-19 01:27:44 +10:00
parent ff68433fba
commit 9560709770
6 changed files with 57 additions and 48 deletions

View File

@ -814,22 +814,22 @@ void gToolTip::paint() //actually paints it.
rect.setY(0); rect.setY(0);
rect.setHeight(h); rect.setHeight(h);
} }
if (!m_pixmap.isNull()) { if (!m_image.isNull()) {
m_graphview->deleteTexture(m_textureID); m_graphview->deleteTexture(m_textureID);
m_textureID=0; m_textureID=0;
m_pixmap=QPixmap(); m_image=QImage();
m_invalidate=true; m_invalidate=true;
} }
} else { } else {
rect.setCoords(0,0,rect.width()+m_spacer*2,rect.height()+m_spacer*2); rect.setCoords(0,0,rect.width()+m_spacer*2,rect.height()+m_spacer*2);
painter.end(); painter.end();
if (!m_pixmap.isNull()) { if (!m_image.isNull()) {
m_graphview->deleteTexture(m_textureID); m_graphview->deleteTexture(m_textureID);
} }
m_pixmap=QPixmap(rect.width()+2,rect.height()+2); m_image=QImage(rect.width()+2,rect.height()+2,QImage::Format_ARGB32_Premultiplied);
m_pixmap.fill(Qt::transparent); m_image.fill(Qt::transparent);
painter.begin(&m_pixmap); painter.begin(&m_image);
} }
lines_drawn_this_frame+=4; lines_drawn_this_frame+=4;
@ -839,7 +839,6 @@ void gToolTip::paint() //actually paints it.
brush.setStyle(Qt::SolidPattern); brush.setStyle(Qt::SolidPattern);
painter.setBrush(brush); painter.setBrush(brush);
painter.drawRoundedRect(rect,5,5); painter.drawRoundedRect(rect,5,5);
painter.setBrush(Qt::black); painter.setBrush(Qt::black);
@ -847,17 +846,18 @@ void gToolTip::paint() //actually paints it.
painter.end(); painter.end();
if (usepixmap) { if (usepixmap) {
m_textureID=m_graphview->bindTexture(m_pixmap,GL_TEXTURE_2D,GL_RGBA,QGLContext::InvertedYBindOption); m_image=QGLWidget::convertToGLFormat(m_image);
m_textureID=m_graphview->bindTexture(m_image,GL_TEXTURE_2D,GL_RGBA,QGLContext::NoBindOption);
m_invalidate=false; m_invalidate=false;
} }
} }
if (usepixmap) { if (usepixmap) {
x-=m_spacer+m_pixmap.width()/2; x-=m_spacer+m_image.width()/2;
y-=m_pixmap.height()/2; y-=m_image.height()/2;
if (y<0) y=0; if (y<0) y=0;
if (x<0) x=0; if (x<0) x=0;
if ((x+m_pixmap.width()) > (m_graphview->width()-10)) x=m_graphview->width()-10 - m_pixmap.width(); if ((x+m_image.width()) > (m_graphview->width()-10)) x=m_graphview->width()-10 - m_image.width();
if (usepixmap && !m_pixmap.isNull()) { if (usepixmap && !m_image.isNull()) {
glEnable(GL_BLEND); glEnable(GL_BLEND);
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
glEnable(GL_TEXTURE_2D); glEnable(GL_TEXTURE_2D);
@ -2273,10 +2273,10 @@ void gGraphView::DrawTextQue()
// unbind the texture // unbind the texture
myPixmapCache * pc=pixmap_cache[key]; myPixmapCache * pc=pixmap_cache[key];
deleteTexture(pc->textureID); deleteTexture(pc->textureID);
QPixmap *pm=pc->pixmap; QImage & pm=pc->image;
pixmap_cache_size-=pm->width() * pm->height() * (pm->depth()/8); pixmap_cache_size-=pm.width() * pm.height() * (pm.depth()/8);
// free the pixmap // free the pixmap
delete pc->pixmap; //delete pc->pixmap;
// free the myPixmapCache object // free the myPixmapCache object
delete pc; delete pc;
@ -2302,7 +2302,7 @@ void gGraphView::DrawTextQue()
// Generate the pixmap cache "key" // Generate the pixmap cache "key"
QString hstr=QString("%4:%5:%6%7").arg(q.text).arg(q.color.name()).arg(q.font->key()).arg(q.antialias); QString hstr=QString("%4:%5:%6%7").arg(q.text).arg(q.color.name()).arg(q.font->key()).arg(q.antialias);
QPixmap * pm=NULL; QImage pm;
//Random_note: test add to qmake for qt5 stuff DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x040900 //Random_note: test add to qmake for qt5 stuff DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x040900
@ -2321,24 +2321,32 @@ void gGraphView::DrawTextQue()
QRect rect=fm.boundingRect(q.text); QRect rect=fm.boundingRect(q.text);
w=rect.width(); w=rect.width();
h=rect.height(); h=rect.height();
pm=new QPixmap(w+4,h+4); pm=QImage(w+4,h+4,QImage::Format_ARGB32_Premultiplied);
pm->fill(Qt::transparent);
QPainter painter(pm); pm.fill(Qt::transparent);
QPainter painter(&pm);
// Hmmm.. Maybe I need to be able to turn this on/off? // Hmmm.. Maybe I need to be able to turn this on/off?
painter.setRenderHint(QPainter::TextAntialiasing, q.antialias);
QBrush b(q.color); QBrush b(q.color);
painter.setBrush(b); painter.setBrush(b);
//QFont font=*q.font;
//if (!q.antialias) {
// q.font->setStyleStrategy(QFont::NoAntialias);
//} else q.font->setStyleStrategy(QFont::PreferAntialias);
//painter.setFont(font);
painter.setFont(*q.font); painter.setFont(*q.font);
painter.setRenderHint(QPainter::TextAntialiasing, q.antialias);
painter.drawText(2,h,q.text); painter.drawText(2,h,q.text);
painter.end(); painter.end();
pc->pixmap=pm; pc->image=QGLWidget::convertToGLFormat(pm);
pixmap_cache_size+=pm->width()*pm->height()*(pm->depth()/8); pixmap_cache_size+=pm.width()*pm.height()*(pm.depth()/8);
pc->textureID=bindTexture(*pm,GL_TEXTURE_2D,GL_RGBA,QGLContext::InvertedYBindOption); pc->textureID=bindTexture(pc->image,GL_TEXTURE_2D,GL_RGBA,QGLContext::NoBindOption);
pixmap_cache[hstr]=pc; pixmap_cache[hstr]=pc;
} }
@ -2351,16 +2359,16 @@ void gGraphView::DrawTextQue()
glEnable(GL_TEXTURE_2D); glEnable(GL_TEXTURE_2D);
if (q.angle!=0) { if (q.angle!=0) {
glPushMatrix(); glPushMatrix();
glTranslatef(q.x-pc->pixmap->height()*2+4,q.y+pc->pixmap->width()/2+4, 0); glTranslatef(q.x-pc->image.height()*2+4,q.y+pc->image.width()/2+4, 0);
glRotatef(-q.angle,0,0,1); glRotatef(-q.angle,0,0,1);
drawTexture(QPoint(0,pc->pixmap->height()/2),pc->textureID); drawTexture(QPoint(0,pc->image.height()/2),pc->textureID);
glPopMatrix(); glPopMatrix();
//glTranslatef(marginLeft()+4,originY+height/2+x/2, 0); //glTranslatef(marginLeft()+4,originY+height/2+x/2, 0);
//glRotatef(-90,0,0,1); //glRotatef(-90,0,0,1);
//m_graphview->drawTexture(QPoint(0,y/2),titleImageTex); //m_graphview->drawTexture(QPoint(0,y/2),titleImageTex);
} else { } else {
// TODO: setup for rotation if angle specified. // TODO: setup for rotation if angle specified.
drawTexture(QPoint(q.x,q.y-pc->pixmap->height()+4),pc->textureID); drawTexture(QPoint(q.x,q.y-pc->image.height()+4),pc->textureID);
} }
glDisable(GL_TEXTURE_2D); glDisable(GL_TEXTURE_2D);
glDisable(GL_BLEND); glDisable(GL_BLEND);

View File

@ -496,7 +496,7 @@ protected:
QString m_text; QString m_text;
bool m_visible; bool m_visible;
int m_spacer; int m_spacer;
QPixmap m_pixmap; QImage m_image;
GLuint m_textureID; GLuint m_textureID;
bool m_invalidate; bool m_invalidate;
protected slots: protected slots:
@ -804,7 +804,7 @@ protected slots:
struct myPixmapCache struct myPixmapCache
{ {
quint64 last_used; quint64 last_used;
QPixmap *pixmap; QImage image;
GLuint textureID; GLuint textureID;
}; };

View File

@ -59,9 +59,9 @@ void gXAxis::paint(gGraph & w,int left,int top, int width, int height)
// Unbind any previous texture // Unbind any previous texture
if (m_textureID) w.graphView()->deleteTexture(m_textureID); if (m_textureID) w.graphView()->deleteTexture(m_textureID);
m_pixmap=QPixmap(width+22,height+4); m_image=QImage(width+22,height+4,QImage::Format_ARGB32_Premultiplied);
m_pixmap.fill(Qt::transparent); m_image.fill(Qt::transparent);
painter.begin(&m_pixmap); painter.begin(&m_image);
painter.setPen(Qt::black); painter.setPen(Qt::black);
} }
double px,py; double px,py;
@ -247,17 +247,18 @@ void gXAxis::paint(gGraph & w,int left,int top, int width, int height)
if (usepixmap) { if (usepixmap) {
painter.end(); painter.end();
m_textureID=w.graphView()->bindTexture(m_pixmap,GL_TEXTURE_2D,GL_RGBA,QGLContext::InvertedYBindOption); m_image=QGLWidget::convertToGLFormat(m_image);
m_textureID=w.graphView()->bindTexture(m_image,GL_TEXTURE_2D,GL_RGBA,QGLContext::NoBindOption);
} }
w.invalidate_xAxisImage=false; w.invalidate_xAxisImage=false;
} }
if (usepixmap && !m_pixmap.isNull()) { if (usepixmap && !m_image.isNull()) {
glEnable(GL_BLEND); glEnable(GL_BLEND);
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
glEnable(GL_TEXTURE_2D); glEnable(GL_TEXTURE_2D);
w.graphView()->drawTexture(QPoint(left-20,(top+height)-m_pixmap.height()+4),m_textureID); w.graphView()->drawTexture(QPoint(left-20,(top+height)-m_image.height()+4),m_textureID);
glDisable(GL_TEXTURE_2D); glDisable(GL_TEXTURE_2D);
glDisable(GL_BLEND); glDisable(GL_BLEND);
} }

View File

@ -44,7 +44,7 @@ class gXAxis:public Layer
qint64 tz_offset; qint64 tz_offset;
float tz_hours; float tz_hours;
QPixmap m_pixmap; QImage m_image;
GLuint m_textureID; GLuint m_textureID;
}; };
#endif // GXAXIS_H #endif // GXAXIS_H

View File

@ -129,7 +129,7 @@ gYAxis::gYAxis(QColor col)
{ {
m_line_color=col; m_line_color=col;
m_text_color=col; m_text_color=col;
yAxisImageTex=0; m_textureID=0;
m_yaxis_scale=1; m_yaxis_scale=1;
} }
@ -145,9 +145,9 @@ void gYAxis::paint(gGraph & w,int left,int top, int width, int height)
if (w.graphView()->usePixmapCache()) { if (w.graphView()->usePixmapCache()) {
if (w.invalidate_yAxisImage) { if (w.invalidate_yAxisImage) {
if (!yAxisImage.isNull()) { if (!m_image.isNull()) {
w.graphView()->deleteTexture(yAxisImageTex); w.graphView()->deleteTexture(m_textureID);
yAxisImage=QPixmap(); m_image=QImage();
} }
@ -170,10 +170,10 @@ void gYAxis::paint(gGraph & w,int left,int top, int width, int height)
GetTextExtent(fd,x,y); GetTextExtent(fd,x,y);
yh=y; yh=y;
yAxisImage=QPixmap(width,height+y+4); m_image=QImage(width,height+y+4,QImage::Format_ARGB32_Premultiplied);
yAxisImage.fill(Qt::transparent); m_image.fill(Qt::transparent);
QPainter paint(&yAxisImage); QPainter paint(&m_image);
double max_yticks=round(height / (y+14.0)); // plus spacing between lines double max_yticks=round(height / (y+14.0)); // plus spacing between lines
@ -249,16 +249,16 @@ void gYAxis::paint(gGraph & w,int left,int top, int width, int height)
} }
} }
paint.end(); paint.end();
//yAxisImage=QGLWidget::convertToGLFormat(pixmap.toImage().mirrored(false,true)); m_image=QGLWidget::convertToGLFormat(m_image);
yAxisImageTex=w.graphView()->bindTexture(yAxisImage,GL_TEXTURE_2D,GL_RGBA,QGLContext::InvertedYBindOption); m_textureID=w.graphView()->bindTexture(m_image,GL_TEXTURE_2D,GL_RGBA,QGLContext::NoBindOption);
w.invalidate_yAxisImage=false; w.invalidate_yAxisImage=false;
} }
if (!yAxisImage.isNull()) { if (!m_image.isNull()) {
glEnable(GL_BLEND); glEnable(GL_BLEND);
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
glEnable(GL_TEXTURE_2D); glEnable(GL_TEXTURE_2D);
w.graphView()->drawTexture(QPoint(left,(top+height)-yAxisImage.height()+5),yAxisImageTex); w.graphView()->drawTexture(QPoint(left,(top+height)-m_image.height()+5),m_textureID);
glDisable(GL_TEXTURE_2D); glDisable(GL_TEXTURE_2D);
glDisable(GL_BLEND); glDisable(GL_BLEND);
} }

View File

@ -112,8 +112,8 @@ class gYAxis:public Layer
gVertexBuffer * lines; gVertexBuffer * lines;
virtual bool mouseMoveEvent(QMouseEvent * event); virtual bool mouseMoveEvent(QMouseEvent * event);
QPixmap yAxisImage; QImage m_image;
GLuint yAxisImageTex; GLuint m_textureID;
}; };