# HG changeset patch # User Chris Cannam # Date 1467279412 -3600 # Node ID e536dfc6b250b74e93ef40aff42d2aea738f4a79 # Parent 2e1d6c2ed3ee76ed00b9324b7a007fa688861da0 Two functions, rather than one with a boolean arg diff -r 2e1d6c2ed3ee -r e536dfc6b250 layer/Colour3DPlotRenderer.cpp --- a/layer/Colour3DPlotRenderer.cpp Wed Jun 29 15:13:54 2016 +0100 +++ b/layer/Colour3DPlotRenderer.cpp Thu Jun 30 10:36:52 2016 +0100 @@ -23,9 +23,19 @@ #include "view/LayerGeometryProvider.h" Colour3DPlotRenderer::RenderResult -Colour3DPlotRenderer::render(QPainter &paint, - QRect rect, - bool complete) +Colour3DPlotRenderer::render(QPainter &paint, QRect rect) +{ + return render(paint, rect, false); +} + +Colour3DPlotRenderer::RenderResult +Colour3DPlotRenderer::renderTimeConstrained(QPainter &paint, QRect rect) +{ + return render(paint, rect, true); +} + +Colour3DPlotRenderer::RenderResult +Colour3DPlotRenderer::render(QPainter &paint, QRect rect, bool timeConstrained) { LayerGeometryProvider *v = m_sources.geometryProvider; if (!v) { diff -r 2e1d6c2ed3ee -r e536dfc6b250 layer/Colour3DPlotRenderer.h --- a/layer/Colour3DPlotRenderer.h Wed Jun 29 15:13:54 2016 +0100 +++ b/layer/Colour3DPlotRenderer.h Thu Jun 30 10:36:52 2016 +0100 @@ -99,15 +99,11 @@ * geometry (e.g. start frame) from the stored * LayerGeometryProvider. * - * If complete is false, as much of the rect will be rendered as - * can be managed given internal time constraints. The returned - * QRect (the rendered field in the RenderResult struct) will - * contain the area that was rendered. Note that we always render - * the full requested height, it's only width that is - * time-constrained. - * - * If complete is true, the whole rect will be rendered and the - * returned QRect will be equal to the passed QRect. + * The whole rect will be rendered and the returned QRect will be + * equal to the passed QRect. (See renderTimeConstrained for an + * alternative that may render only part of the rect in cases + * where obtaining source data is slow and retaining + * responsiveness is important.) * * If the model to render from is not ready, this will throw a * std::logic_error exception. The model must be ready and the @@ -115,9 +111,27 @@ * that the LayerGeometryProvider returns valid results; it is the * caller's responsibility to ensure these. */ - RenderResult render(QPainter &paint, - QRect rect, - bool complete); + RenderResult render(QPainter &paint, QRect rect); + + /** + * Render the requested area using the given painter, obtaining + * geometry (e.g. start frame) from the stored + * LayerGeometryProvider. + * + * As much of the rect will be rendered as can be managed given + * internal time constraints (using a RenderTimer object + * internally). The returned QRect (the rendered field in the + * RenderResult struct) will contain the area that was + * rendered. Note that we always render the full requested height, + * it's only width that is time-constrained. + * + * If the model to render from is not ready, this will throw a + * std::logic_error exception. The model must be ready and the + * layer requesting the render must not be dormant in its view, so + * that the LayerGeometryProvider returns valid results; it is the + * caller's responsibility to ensure these. + */ + RenderResult renderTimeConstrained(QPainter &paint, QRect rect); private: Sources m_sources; @@ -149,6 +163,7 @@ // then repainting from cache to the requested painter. ScrollableImageCache m_cache; + RenderResult render(QPainter &paint, QRect rect, bool timeConstrained); //!!! fft model scaling?