diff options
author | John Firebaugh <john.firebaugh@gmail.com> | 2017-07-18 11:19:35 -0700 |
---|---|---|
committer | John Firebaugh <john.firebaugh@gmail.com> | 2017-07-19 09:31:07 -0700 |
commit | ac58130d3626efec8021c7408f5bc69a9e36d133 (patch) | |
tree | f8b1560966e74a58cb9433c1fe8066eae2d36370 /src/mbgl/renderer/sources/render_image_source.cpp | |
parent | 2c0fe49650548069dea382313f7cbdb04f41b227 (diff) | |
download | qtlocation-mapboxgl-ac58130d3626efec8021c7408f5bc69a9e36d133.tar.gz |
[core] Extract renderTileDebug; inline renderClippingMask
Diffstat (limited to 'src/mbgl/renderer/sources/render_image_source.cpp')
-rw-r--r-- | src/mbgl/renderer/sources/render_image_source.cpp | 26 |
1 files changed, 24 insertions, 2 deletions
diff --git a/src/mbgl/renderer/sources/render_image_source.cpp b/src/mbgl/renderer/sources/render_image_source.cpp index 1cb3d9d1ba..738b8e8034 100644 --- a/src/mbgl/renderer/sources/render_image_source.cpp +++ b/src/mbgl/renderer/sources/render_image_source.cpp @@ -5,6 +5,7 @@ #include <mbgl/renderer/render_tile.hpp> #include <mbgl/renderer/sources/render_image_source.hpp> #include <mbgl/renderer/tile_parameters.hpp> +#include <mbgl/programs/programs.hpp> #include <mbgl/util/tile_coordinate.hpp> #include <mbgl/util/tile_cover.hpp> #include <mbgl/util/logging.hpp> @@ -48,11 +49,32 @@ void RenderImageSource::startRender(Painter& painter) { } void RenderImageSource::finishRender(Painter& painter) { - if (!isLoaded()) { + if (!isLoaded() || !(painter.frame.debugOptions & MapDebugOptions::TileBorders)) { return; } + + static const style::Properties<>::PossiblyEvaluated properties {}; + static const DebugProgram::PaintPropertyBinders paintAttibuteData(properties, 0); + for (auto matrix : matrices) { - painter.renderTileDebug(matrix); + painter.programs->debug.draw( + painter.context, + gl::LineStrip { 4.0f * painter.frame.pixelRatio }, + gl::DepthMode::disabled(), + gl::StencilMode::disabled(), + gl::ColorMode::unblended(), + DebugProgram::UniformValues { + uniforms::u_matrix::Value{ matrix }, + uniforms::u_color::Value{ Color::red() } + }, + painter.tileVertexBuffer, + painter.tileBorderIndexBuffer, + painter.tileBorderSegments, + paintAttibuteData, + properties, + painter.state.getZoom(), + "debug" + ); } } |