Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RasterLayer: Properly handle GUI updates when multiple canvas are displayed #59444

Merged
merged 6 commits into from
Nov 28, 2024

Conversation

ptitjano
Copy link
Contributor

Description

This fixes an issue mentioned by @nyalldawson in qgis/QGIS-Enhancement-Proposals#273

This occurs when the Min/Max settings is set in the renderer and multiple canvas are displayed. Indeed, in that case QgsRasterLayer updates the GUI (the renderer widget and the legend) multiple times when the rendered values are updated because each canvas causes a renderer update.

This issue is fixed by removing the GUI update from the raster layer code. With this change, when the rendered values are updated, these statistics (min-max) are propagated to the canvas by the use of a QgsRenderedItemDetails: QgsRenderedCalculatedResults. Then, only the main canvas is notified of this change and updates the GUI accordingly.

@ptitjano ptitjano self-assigned this Nov 14, 2024
@ptitjano ptitjano added the Bug Either a bug report, or a bug fix. Let's hope for the latter! label Nov 14, 2024
@github-actions github-actions bot added this to the 3.42.0 milestone Nov 14, 2024
@ptitjano ptitjano added the Rasters Related to general raster layer handling (not specific data formats) label Nov 14, 2024
@ptitjano ptitjano force-pushed the canvas-min-max branch 3 times, most recently from 26595b2 to 7b17df6 Compare November 14, 2024 12:11
Copy link

github-actions bot commented Nov 14, 2024

🪟 Windows builds

Download Windows builds of this PR for testing.
Debug symbols for this build are available here.
(Built from commit d569eaf)

🪟 Windows Qt6 builds

Download Windows Qt6 builds of this PR for testing.
(Built from commit d569eaf)

@ptitjano ptitjano force-pushed the canvas-min-max branch 2 times, most recently from 61f86be to 33998d8 Compare November 15, 2024 16:34
src/core/qgsrenderedcalculatedresults.h Outdated Show resolved Hide resolved
src/core/qgsrenderedcalculatedresults.h Outdated Show resolved Hide resolved
src/core/raster/qgsrasterlayer.h Outdated Show resolved Hide resolved
src/core/raster/qgsrasterlayerrenderer.cpp Outdated Show resolved Hide resolved
src/core/qgsrenderedcalculatedresults.h Outdated Show resolved Hide resolved
src/core/qgsrenderedcalculatedresults.h Outdated Show resolved Hide resolved
src/gui/qgsmapcanvas.cpp Outdated Show resolved Hide resolved
@nyalldawson
Copy link
Collaborator

Good approach, I like where this is going! 👍

@ptitjano ptitjano force-pushed the canvas-min-max branch 2 times, most recently from db19524 to abf6011 Compare November 21, 2024 17:10
@ptitjano
Copy link
Contributor Author

@nyalldawson This should be ready now.

@ptitjano ptitjano force-pushed the canvas-min-max branch 4 times, most recently from 3060e67 to a6a76a1 Compare November 22, 2024 08:34
src/core/qgsrenderedlayerstatistics.h Outdated Show resolved Hide resolved
src/core/qgsrenderedlayerstatistics.h Outdated Show resolved Hide resolved
src/app/qgisapp.cpp Outdated Show resolved Hide resolved
src/app/qgisapp.cpp Outdated Show resolved Hide resolved
src/core/raster/qgssinglebandgrayrenderer.h Outdated Show resolved Hide resolved
src/core/raster/qgssinglebandpseudocolorrenderer.h Outdated Show resolved Hide resolved
@nyalldawson
Copy link
Collaborator

Much cleaner, this is great! 💯

@JanCaha
Copy link
Contributor

JanCaha commented Nov 25, 2024

Looks good 👍 This approach will be useful for MeshLayer as well.

This will be used in the next commits to store the min-max values of a
raster layer and report them to the main canvas.
This is similar to what is achieved in
`QgsRasterLayer::refreshRendererIfNeeded()` to check if the renderer
needs to be refresh according to an extent. It does not perform any
refresh.

It is not used at the moment. This will replace the logic to refresh a
renderer in the following commits.
This is similar to what is achieved in
`QgsRasterLayer::refreshRenderer()` to refresh the renderer according
to an extent. Contrary to the first one, this method does not perform
any GUI update or emit any signal.

It is not used at the moment. This will replace the logic to refresh a
renderer in the following commits.
This will be used in the next commit to refresh a renderer.
This replaces the existing logic in `QgsRasterLayerRenderer` which
calls `QgsRasterLayer::refreshRendererIfNeeded()` to refresh the
renderer associated `QgsRasterLayerRenderer` and the raster associated
with `QgsRasterLayer`. It also makes GUI updates.

With this approach, the following new logic is done:
 1. `QgsRasterRenderer::needsRefresh()` is called to check if
 `rasterRenderer` needs to be updated.
 2. If a refresh is needed, the new min/max values are computed by
 calling `QgsRasterLayer::computeMinMax()`
 3. The min/max values are used to refresh `rasterRenderer`
 4. The min/max values are stored in a `QgsRenderedLayerStatistics`
 and propagated to `QgisApp`
 5. In QgisApp, `QgsRenderedLayerStatistics` is used to refresh the
 renderer of `QgsRasterLayer` and force a refresh of the style and the
 legend if the change comes from the main canvas.
This is not used anymore.
@nyalldawson nyalldawson merged commit 9d372b6 into qgis:master Nov 28, 2024
31 checks passed
@ptitjano ptitjano deleted the canvas-min-max branch November 28, 2024 10:54
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug Either a bug report, or a bug fix. Let's hope for the latter! Rasters Related to general raster layer handling (not specific data formats)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants