diff --git a/Graphs/gFlagsLine.cpp b/Graphs/gFlagsLine.cpp index eff54910..99e7c857 100644 --- a/Graphs/gFlagsLine.cpp +++ b/Graphs/gFlagsLine.cpp @@ -80,30 +80,37 @@ void gFlagsGroup::paint(gGraph &w, int left, int top, int width, int height) linetop+=barh; } - lines->add(left-1, top, left-1, top+height); - lines->add(left+width, top+height, left+width, top); + GLBuffer *outlines=w.lines(); + QColor blk=Qt::black; + outlines->add(left-1, top, left-1, top+height, blk); + outlines->add(left-1, top+height, left+width,top+height, blk); + outlines->add(left+width,top+height, left+width, top, blk); + outlines->add(left+width, top, left-1, top, blk); + + //lines->add(left-1, top, left-1, top+height); + //lines->add(left+width, top+height, left+width, top); } gFlagsLine::gFlagsLine(ChannelID code,QColor flag_color,QString label,bool always_visible,FlagType flt) :Layer(code),m_label(label),m_always_visible(always_visible),m_flt(flt),m_flag_color(flag_color) { addGLBuf(quads=new GLBuffer(flag_color,2048,GL_QUADS)); - addGLBuf(lines=new GLBuffer(flag_color,1024,GL_LINES)); + //addGLBuf(lines=new GLBuffer(flag_color,1024,GL_LINES)); quads->setAntiAlias(true); - lines->setAntiAlias(true); + //lines->setAntiAlias(true); GetTextExtent(m_label,m_lx,m_ly); //m_static.setText(m_label);; } gFlagsLine::~gFlagsLine() { - delete lines; + //delete lines; delete quads; } void gFlagsLine::paint(gGraph & w,int left, int top, int width, int height) { if (!m_visible) return; if (!m_day) return; - + lines=w.lines(); double minx; double maxx; @@ -144,7 +151,7 @@ void gFlagsLine::paint(gGraph & w,int left, int top, int width, int height) if (X > maxx) break; x1=(X - minx) * xmult + left; if (m_flt==FT_Bar) { - lines->add(x1,bartop,x1,bottom); + lines->add(x1,bartop,x1,bottom,m_flag_color); if (lines->full()) { verts_exceeded=true; break; } } else if (m_flt==FT_Span) { x2=(Y-minx)*xmult+left; diff --git a/Graphs/gGraphView.cpp b/Graphs/gGraphView.cpp index 4c3164d4..1edc27d7 100644 --- a/Graphs/gGraphView.cpp +++ b/Graphs/gGraphView.cpp @@ -55,11 +55,16 @@ GLBuffer::GLBuffer(QColor color,int max,int type) m_antialias=true; m_forceantialias=false; buffer=new GLshort [max+8]; + if (m_type==GL_LINES) { + colors=new GLubyte[max*4+(8*4)]; + } else colors=NULL; m_cnt=0; + m_colcnt=0; m_size=1; } GLBuffer::~GLBuffer() { + if (colors) delete [] colors; delete [] buffer; } void GLBuffer::add(GLshort s) @@ -91,6 +96,42 @@ void GLBuffer::add(GLshort x1, GLshort y1, GLshort x2, GLshort y2) } } +void GLBuffer::add(GLshort x, GLshort y,QColor & color) +{ + if (m_cnt0) { @@ -114,13 +155,30 @@ void GLBuffer::draw() glScissor(s1,s2,s3,s4); glEnable(GL_SCISSOR_TEST); } - glEnableClientState(GL_VERTEX_ARRAY); + glVertexPointer(2, GL_SHORT, 0, buffer); - glColor4ub(m_color.red(),m_color.green(),m_color.blue(),m_color.alpha()); + + if (m_colcnt<=0) { + glColor4ub(m_color.red(),m_color.green(),m_color.blue(),m_color.alpha()); + } else { + glColorPointer(4, GL_UNSIGNED_BYTE, 0, colors); + } + + glEnableClientState(GL_VERTEX_ARRAY); + if (m_colcnt>0) { + glEnableClientState(GL_COLOR_ARRAY); + } glDrawArrays(m_type, 0, m_cnt >> 1); + + if (m_colcnt>0) { + glDisableClientState(GL_COLOR_ARRAY); + } glDisableClientState(GL_VERTEX_ARRAY); + + //qDebug() << "I Drawed" << m_cnt << "vertices"; m_cnt=0; + m_colcnt=0; if (m_scissor) { glDisable(GL_SCISSOR_TEST); m_scissor=false; @@ -310,17 +368,15 @@ void gThread::run() { m_running=true; while (m_running) { - //mutex.lock(); - if (mutex.tryLock(500)) { - if (!m_running) break; - int originX=m_lastbounds.x(); - int originY=m_lastbounds.y(); - int width=m_lastbounds.width(); - int height=m_lastbounds.height(); - graph->paint(originX,originY,width,height); - graph->threadDone(); - } - this->yieldCurrentThread(); + mutex.lock(); // this will hang until a paint event unlocks it.. + + if (!m_running) break; + int originX=m_lastbounds.x(); + int originY=m_lastbounds.y(); + int width=m_lastbounds.width(); + int height=m_lastbounds.height(); + graph->paint(originX,originY,width,height); + graph->threadDone(); } } void gThread::paint(int originX, int originY, int width, int height) @@ -373,7 +429,7 @@ bool gGraph::isEmpty() } void gGraph::threadDone() { -// m_graphview->masterlock->release(1); + m_graphview->masterlock->release(1); } void gGraph::drawGLBuf() @@ -466,7 +522,7 @@ void gGraph::paint(int originX, int originY, int width, int height) originY+=m_margintop; width-=m_marginleft+m_marginright; height-=m_margintop+m_marginbottom; - int lsize=m_layers.size(); + //int lsize=m_layers.size(); for (int i=0;iadd(originX+m_selection.x()+m_selection.width(),originY+height-top-bottom, originX+m_selection.x(),originY+height-top-bottom); } - m_graphview->masterlock->release(1); - /*m_graphview->gl_mutex.lock(); - ((QGLContext *)m_graphview->context())->makeCurrent(); - drawGLBuf(); - m_graphview->gl_mutex.unlock(); */ + //m_graphview->gl_mutex.lock(); + /*QGLFormat fmt=m_graphview->format(); + QGLContext ctx(fmt); + ctx.create(m_graphview->context()); + ctx.doneCurrent(); + ctx.makeCurrent(); */ + //m_graphview->makeCurrent(); + //drawGLBuf(); + //ctx.doneCurrent(); + //m_graphview->gl_mutex.unlock(); } void gGraph::AddLayer(Layer * l,LayerPosition position, short width, short height, short order, bool movable, short x, short y) @@ -918,6 +979,15 @@ void gGraph::DrawStaticText(QStaticText & text, short x, short y) { m_graphview->DrawStaticText(text,x,y); } +GLBuffer * gGraph::lines() +{ + return m_graphview->lines; +} +GLBuffer * gGraph::backlines() +{ + return m_graphview->backlines; +} + // Sets a new Min & Max X clipping, refreshing the graph and all it's layers. void gGraph::SetXBounds(qint64 minx, qint64 maxx) @@ -958,6 +1028,9 @@ gGraphView::gGraphView(QWidget *parent, gGraphView * shared) : m_idealthreads=QThread::idealThreadCount(); if (m_idealthreads<=0) m_idealthreads=1; masterlock=new QSemaphore(m_idealthreads); + + lines=new GLBuffer(QColor(0,0,0,0),100000,GL_LINES); // big fat shared line list + backlines=new GLBuffer(QColor(0,0,0,0),10000,GL_LINES); // big fat shared line list } gGraphView::~gGraphView() { @@ -966,6 +1039,7 @@ gGraphView::~gGraphView() } delete masterlock; m_graphs.clear(); + delete lines; if (m_scrollbar) { this->disconnect(SIGNAL(sliderMoved(int)),this); } @@ -1220,7 +1294,6 @@ void gGraphView::paintGL() threaded=true; } else threaded=false; - threaded=true; for (int i=0;iisEmpty() || !m_graphs[i]->visible()) continue; numgraphs++; @@ -1234,17 +1307,19 @@ void gGraphView::paintGL() if ((py + h + graphSpacer) >= 0) { w=width(); - masterlock->acquire(1); // book an available CPU if (threaded) { + masterlock->acquire(1); // book an available CPU m_graphs[i]->threadStart(); // this only happens once.. It stays dormant when not in use. m_graphs[i]->thread()->paint(px,py,width()-titleWidth,h); } else { m_graphs[i]->paint(px,py,width()-titleWidth,h); } - bool r=m_graphs[i]->thread()->isRunning(); + //qDebug() << "Threads operational" << m_idealthreads-masterlock->available(); // draw the splitter handle + gl_mutex.lock(); + glBegin(GL_QUADS); glColor4f(.5,.5,.5,1.0); glVertex2f(0,py+h); @@ -1259,6 +1334,7 @@ void gGraphView::paintGL() glVertex2f(w,py+h+graphSpacer); glVertex2f(0,py+h+graphSpacer); glEnd(); + gl_mutex.unlock(); } py=ceil(py+h+graphSpacer); } @@ -1269,14 +1345,18 @@ void gGraphView::paintGL() AddTextQue(m_emptytext,(width()/2)-x/2,(height()/2)+y/2,0.0,col,bigfont); } - // if (threaded) { + if (threaded) { masterlock->acquire(m_idealthreads); // ask for all the CPU's back.. masterlock->release(m_idealthreads); - //} + } + //((QGLContext*)context())->makeCurrent(); + + backlines->draw(); for (int i=0;idrawGLBuf(); } + lines->draw(); DrawTextQue(); //glDisable(GL_TEXTURE_2D); //glDisable(GL_DEPTH_TEST); diff --git a/Graphs/gGraphView.h b/Graphs/gGraphView.h index 9a7cf48e..0b42bef8 100644 --- a/Graphs/gGraphView.h +++ b/Graphs/gGraphView.h @@ -37,6 +37,10 @@ public: void add(GLshort s); void add(GLshort x, GLshort y); void add(GLshort x1, GLshort y1, GLshort x2, GLshort y2); + + void add(GLshort x, GLshort y,QColor & col); // add with vertex color + void add(GLshort x1, GLshort y1, GLshort x2, GLshort y2,QColor & col); // add with vertex colors + void scissor(GLshort x1, GLshort y1, GLshort x2, GLshort y2) { s1=x1; s2=y1; s3=x2; s4=y2; m_scissor=true; } void draw(); inline GLshort & operator [](int i) { return buffer[i]; } @@ -47,17 +51,21 @@ public: void setSize(float f) { m_size=f; } void setAntiAlias(bool b) { m_antialias=b; } void forceAntiAlias(bool b) { m_forceantialias=b; } + void setColor(QColor color) { m_color=color; } protected: QColor m_color; GLshort * buffer; + GLubyte * colors; int m_max; int m_type; // type (GL_LINES, GL_QUADS, etc) int m_cnt; // cnt + int m_colcnt; float m_size; int s1,s2,s3,s4; bool m_scissor; bool m_antialias; bool m_forceantialias; + QMutex mutex; }; struct TextQue @@ -237,6 +245,8 @@ public: void threadDone(); bool threadRunning() { return m_thread->isRunning(); } void threadStart() { if (!m_thread->isRunning()) m_thread->start(); } + GLBuffer * lines(); + GLBuffer * backlines(); protected: //void invalidate(); @@ -317,6 +327,7 @@ public: void setDay(Day * day); QSemaphore * masterlock; bool useThreads() { return m_idealthreads>1; } + GLBuffer * lines, * backlines; protected: int m_idealthreads; Day * m_day; diff --git a/Graphs/gLineChart.cpp b/Graphs/gLineChart.cpp index 20c7be75..eb74031b 100644 --- a/Graphs/gLineChart.cpp +++ b/Graphs/gLineChart.cpp @@ -18,14 +18,12 @@ gLineChart::gLineChart(ChannelID code,QColor col,bool square_plot, bool disable_ m_report_empty=false; addGLBuf(lines=new GLBuffer(col,100000,GL_LINES)); - addGLBuf(outlines=new GLBuffer(QColor(0,0,0,255),20,GL_LINE_LOOP)); lines->setAntiAlias(true); - outlines->setAntiAlias(false); - } gLineChart::~gLineChart() { delete lines; + //delete outlines; } @@ -41,6 +39,7 @@ void gLineChart::paint(gGraph & w,int left, int top, int width, int height) if (width<0) return; + // lines=w.lines(); EventDataType miny,maxy; double minx,maxx; miny=w.min_y, maxy=w.max_y; @@ -114,8 +113,12 @@ void gLineChart::paint(gGraph & w,int left, int top, int width, int height) int minz,maxz; // Draw bounding box - outlines->add(left, top, left, top+height); - outlines->add(left+width,top+height, left+width, top); + GLBuffer *outlines=w.lines(); + QColor blk=Qt::black; + outlines->add(left, top, left, top+height, blk); + outlines->add(left, top+height, left+width,top+height, blk); + outlines->add(left+width,top+height, left+width, top, blk); + outlines->add(left+width, top, left,top, blk); width--; height-=2; @@ -313,7 +316,7 @@ void gLineChart::paint(gGraph & w,int left, int top, int width, int height) // ay1=(m_drawlist[i-1].y()+m_drawlist[i].y()+m_drawlist[i+1].y())/3.0; ax1=m_drawlist[i].x(); ay1=m_drawlist[i].y(); - lines->add(xst+i,yst-ax1,xst+i,yst-ay1); + lines->add(xst+i,yst-ax1,xst+i,yst-ay1,m_line_color); if (lines->full()) break; } @@ -342,7 +345,7 @@ void gLineChart::paint(gGraph & w,int left, int top, int width, int height) firstpx=false; continue; } - lines->add(lastpx,lastpy,px,py); + lines->add(lastpx,lastpy,px,py,m_line_color); if (lines->full()) { done=true; @@ -385,13 +388,13 @@ void gLineChart::paint(gGraph & w,int left, int top, int width, int height) firstpx=false; } else { if (square_plot) { - lines->add(lastpx,lastpy,px,lastpy); - lines->add(px,lastpy); + lines->add(lastpx,lastpy,px,lastpy,m_line_color); + lines->add(px,lastpy,px,py,m_line_color); } else { - lines->add(lastpx,lastpy); + lines->add(lastpx,lastpy,px,py,m_line_color); } - lines->add(px,py); + //lines->add(px,py,m_line_color); if (lines->full()) { done=true; @@ -422,7 +425,7 @@ void gLineChart::paint(gGraph & w,int left, int top, int width, int height) //DrawText(w,msg,left+(width/2.0)-(x/2.0),scry-w.GetBottomMargin()-height/2.0+y/2.0,0,Qt::gray,bigfont); } } else { - lines->scissor(left,w.flipY(top+height+2),width+1,height+1); + //lines->scissor(left,w.flipY(top+height+2),width+1,height+1); //lines->draw(); } } diff --git a/Graphs/gLineOverlay.cpp b/Graphs/gLineOverlay.cpp index 415b4ba5..a6cd36c0 100644 --- a/Graphs/gLineOverlay.cpp +++ b/Graphs/gLineOverlay.cpp @@ -14,14 +14,14 @@ gLineOverlayBar::gLineOverlayBar(ChannelID code,QColor color,QString label,FlagT addGLBuf(points=new GLBuffer(color,1024,GL_POINTS)); points->setSize(4); addGLBuf(quads=new GLBuffer(color,2048,GL_QUADS)); - addGLBuf(lines=new GLBuffer(color,1024,GL_LINES)); + //addGLBuf(lines=new GLBuffer(color,1024,GL_LINES)); points->setAntiAlias(true); quads->setAntiAlias(true); - lines->setAntiAlias(true); + //lines->setAntiAlias(true); } gLineOverlayBar::~gLineOverlayBar() { - delete lines; + //delete lines; delete quads; delete points; } @@ -31,6 +31,7 @@ void gLineOverlayBar::paint(gGraph & w, int left, int topp, int width, int heigh if (!m_visible) return; if (!m_day) return; + lines=w.lines(); int start_py=topp; double xx=w.max_x-w.min_x; @@ -86,8 +87,8 @@ void gLineOverlayBar::paint(gGraph & w, int left, int topp, int width, int heigh if (points->full()) { verts_exceeded=true; break; } } else { // thin lines down the bottom - lines->add(x1,start_py+1); - lines->add(x1,start_py+1+12); + lines->add(x1,start_py+1,m_flag_color); + lines->add(x1,start_py+1+12,m_flag_color); if (lines->full()) { verts_exceeded=true; break; } } @@ -97,12 +98,12 @@ void gLineOverlayBar::paint(gGraph & w, int left, int topp, int width, int heigh z=top; points->add(x1,top); - lines->add(x1,top); - lines->add(x1,bottom); + lines->add(x1,top,m_flag_color); + lines->add(x1,bottom,m_flag_color); if (points->full()) { verts_exceeded=true; break; } } else { - lines->add(x1,z); - lines->add(x1,z-12); + lines->add(x1,z,m_flag_color); + lines->add(x1,z-12,m_flag_color); } if (lines->full()) { verts_exceeded=true; break; } if (xx<(1800000)) { diff --git a/Graphs/gXAxis.cpp b/Graphs/gXAxis.cpp index 472b37fb..b34e1752 100644 --- a/Graphs/gXAxis.cpp +++ b/Graphs/gXAxis.cpp @@ -29,11 +29,9 @@ gXAxis::gXAxis(QColor col,bool fadeout) tz_offset=t2.secsTo(t1)/60L; tz_offset*=60000L; - addGLBuf(vertarray=new GLBuffer(m_line_color)); } gXAxis::~gXAxis() { - delete vertarray; } void gXAxis::paint(gGraph & w,int left,int top, int width, int height) { @@ -121,32 +119,26 @@ void gXAxis::paint(gGraph & w,int left,int top, int width, int height) qint64 aligned_start=minx/step; aligned_start*=step; - //qint32 vertcnt=0; - /*GLshort * vertarray=vertex_array[0]; - if (vertarray==NULL) { - qWarning() << "VertArray==NULL"; - return; - } */ - while (aligned_startadd(py,top); - vertarray->add(py,top+4); + lines->add(py,top,py,top+4,linecol); } - w.qglColor(Qt::black); + for (qint64 i=aligned_start;iadd(px,top); - vertarray->add(px,top+6); + lines->add(px,top,px,top+6,linecol); qint64 j=i+tz_offset; int ms=j % 1000; int m=(j/60000L) % 60L; @@ -165,57 +157,18 @@ void gXAxis::paint(gGraph & w,int left,int top, int width, int height) tmpstr=QString("%1:%2:%3:%4").arg(h,2,10,QChar('0')).arg(m,2,10,QChar('0')).arg(s,2,10,QChar('0')).arg(ms,3,10,QChar('0')); } - //w.renderText(px-(x/2),scry-(w.GetBottomMargin()-18),tmpstr); - //DrawText(w,tmpstr,,0); w.renderText(tmpstr,px-(x/2),top+18); py=px; for (int j=1;j<10;j++) { py+=step_pixels; if (py>=left+width) break; - vertarray->add(py,top); - vertarray->add(py,top+4); + lines->add(py,top,py,top+4,linecol); } - if (vertarray->full()) { + if (lines->full()) { qWarning() << "maxverts exceeded in gXAxis::Plot()"; break; } } - - //glLineWidth(1); - //vertarray->draw(); -/* glEnableClientState(GL_VERTEX_ARRAY); - w.qglColor(Qt::black); - glVertexPointer(2, GL_SHORT, 0, vertarray); - glDrawArrays(GL_LINES, 0, vertcnt>>1); - glDisableClientState(GL_VERTEX_ARRAY); // deactivate vertex arrays after drawing*/ - - - /* if (m_fadeout) { - - glFlush(); - w.DrawTextQue(); - - glBlendFunc(GL_SRC_ALPHA,GL_ONE_MINUS_SRC_ALPHA); - glEnable(GL_BLEND); - glBegin(GL_QUADS); - glColor4ub(255,255,255,255); - glVertex2f(left-20,top+5); - glVertex2f(left-20,top+height); - //glColor4ub(255,255,255,0); - glVertex2f(left,top+height); - glVertex2f(left,top+5); - - //glColor4ub(255,255,255,0); - glVertex2f(left+width,top+5); - glVertex2f(left+width,top+height); - //glColor4ub(255,255,255,255); - glVertex2f(left+width+20,top+height); - glVertex2f(left+width+20,top+5); - glEnd(); - glDisable(GL_BLEND); - }*/ - // glDisable(GL_SCISSOR_TEST); - } diff --git a/Graphs/gXAxis.h b/Graphs/gXAxis.h index 04b08830..c9983b06 100644 --- a/Graphs/gXAxis.h +++ b/Graphs/gXAxis.h @@ -38,6 +38,5 @@ class gXAxis:public Layer QColor m_minor_color; bool m_fadeout; qint64 tz_offset; - GLBuffer * vertarray; }; #endif // GXAXIS_H diff --git a/Graphs/gYAxis.cpp b/Graphs/gYAxis.cpp index 138c740b..8e823e64 100644 --- a/Graphs/gYAxis.cpp +++ b/Graphs/gYAxis.cpp @@ -19,14 +19,9 @@ gXGrid::gXGrid(QColor col) m_minor_color=QColor(220,220,220,64); m_show_major_lines=true; m_show_minor_lines=true; - - addGLBuf(majorvert=new GLBuffer(m_major_color)); - addGLBuf(minorvert=new GLBuffer(m_minor_color)); } gXGrid::~gXGrid() { - delete minorvert; - delete majorvert; } void gXGrid::paint(gGraph & w,int left,int top, int width, int height) { @@ -95,18 +90,6 @@ void gXGrid::paint(gGraph & w,int left,int top, int width, int height) float ty,h; - /*qint32 vertcnt=0; - GLshort * vertarray=(GLshort *)vertex_array[0]; - qint32 minorvertcnt=0; - GLshort * minorvertarray=(GLshort *)vertex_array[1]; - qint32 majorvertcnt=0; - GLshort * majorvertarray=(GLshort *)vertex_array[2]; - - if ((vertarray==NULL) || (minorvertarray==NULL) || (majorvertarray==NULL)) { - qWarning() << "gXGrid::Paint() VertArray==NULL"; - return; - } */ - if (min_ytick<=0) { qDebug() << "min_ytick error in gXGrid::paint()"; return; @@ -115,17 +98,13 @@ void gXGrid::paint(gGraph & w,int left,int top, int width, int height) min_ytick=100; } - //double q=((maxy-(miny+(min_ytick/2.0)))/min_ytick)*4; - //if (q>=maxverts) { - // qDebug() << "Would exeed maxverts. Should be another two bounds exceeded messages after this. (I can do a minor optimisation by disabling the other checks if this turns out to be consistent)" << q << maxverts; - //} + lines=w.backlines(); for (double i=miny; i<=maxy+min_ytick-0.00001; i+=min_ytick) { ty=(i - miny) * ymult; h=top+height-ty; if (m_show_major_lines && (i > miny)) { - majorvert->add(left,h); - majorvert->add(left+width,h); + lines->add(left,h,left+width,h,m_major_color); } double z=(min_ytick/4)*ymult; double g=h; @@ -137,35 +116,17 @@ void gXGrid::paint(gGraph & w,int left,int top, int width, int height) // break; // } if (m_show_minor_lines) {// && (i > miny)) { - minorvert->add(left,g); - minorvert->add(left+width,g); + lines->add(left,g,left+width,g,m_minor_color); } - if (minorvert->full()) { + if (lines->full()) { break; } } - if (majorvert->full() || minorvert->full()) { + if (lines->full()) { qWarning() << "vertarray bounds exceeded in gYAxis for " << w.title() << "graph" << "MinY =" <=1000000) { min_ytick=100; } + lines=w.backlines(); //double q=((maxy-(miny+(min_ytick/2.0)))/min_ytick)*4; /*if (q>=maxverts) { qDebug() << "Would exeed maxverts. Should be another two bounds exceeded messages after this. (I can do a minor optimisation by disabling the other checks if this turns out to be consistent)" << q << maxverts; }*/ - w.qglColor(m_text_color); for (double i=miny; i<=maxy+min_ytick-0.00001; i+=min_ytick) { ty=(i - miny) * ymult; fd=Format(i*m_yaxis_scale); // Override this as a function. @@ -304,22 +251,20 @@ void gYAxis::paint(gGraph & w,int left,int top, int width, int height) //DrawText(w,fd,left+width-8-x,(h+(y/2.0)),0,m_text_color); w.renderText(fd,left+width-8-x,(h+(y/2.0)),0,m_text_color); - vertarray->add(left+width-4,h); - vertarray->add(left+width,h); + lines->add(left+width-4,h,left+width,h,m_line_color); double z=(min_ytick/4)*ymult; double g=h; for (int i=0;i<3;i++) { g+=z; if (g>top+height) break; - vertarray->add(left+width-3,g); - vertarray->add(left+width,g); - if (vertarray->full()) { + lines->add(left+width-3,g,left+width,g,m_line_color); + if (lines->full()) { qWarning() << "vertarray bounds exceeded in gYAxis for " << w.title() << "graph" << "MinY =" < +#endif + MainWindow *mainwin=NULL; @@ -40,6 +46,7 @@ void MyOutputHandler(QtMsgType type, const char *msg) { int main(int argc, char *argv[]) { + XInitThreads(); QApplication a(argc, argv); a.setApplicationName("SleepyHead");