Причина такого мозаїчного вигляду полягає в тому, що кожне окреме зображення намальовано сірою шкалою, розтягнутою від зображення хв до зображення макс., А НЕ по всьому світу хв / макс. Коли ви об’єднуєте всі зображення в одне, ну, є лише один хв / макс. Те саме стосується VRT, оскільки VRT розглядає всі зображення як одне ціле (коли ви подивитесь на файл VRT, ви побачите загальну статистику).
Коли обидва, merge та VRT, не є варіантом, наступний сценарій може допомогти.
У першому циклі я перебираю всі шари, підбираючи растри і отримую оцінку їхнього інтервалу min / max. Це так, як працює сама QGIS. З цих значень min / max я обчислюю глобальний min / max
У другому циклі візуалізація для всіх растрових шарів налаштована таким чином, що сіра шкала розтягується через інтервал глобальної хв / макс.
gmin = 9999
gmax = -9999
layers = []
# loop over all layers, take rasters and estimate min, max values
for layer in iface.mapCanvas().layers():
if isinstance(layer, QgsRasterLayer):
# change percentages and sample size to increase or decrease accuracy
min_max = layer.dataProvider().cumulativeCut(1, 0.02, 0.98, theSampleSize=250000)
gmin = min(gmin, min_max[0])
gmax = max(gmax, min_max[1])
layers.append(layer)
# for all rasters create a single band gray scale renderer with
# gray scale stretched across the interval [gmin..gmax]
for rasterlayer in layers:
renderer = QgsSingleBandGrayRenderer(rasterlayer.dataProvider(), 1)
# take the first band (0)
ce = QgsContrastEnhancement(rasterlayer.dataProvider().dataType(0))
ce.setContrastEnhancementAlgorithm(QgsContrastEnhancement.StretchToMinimumMaximum)
ce.setMinimumValue(gmin)
ce.setMaximumValue(gmax)
renderer.setContrastEnhancement(ce)
rasterlayer.setRenderer(renderer)
# refresh canvas to show changes
iface.mapCanvas().refresh()