La razón de esta apariencia en mosaico es que cada imagen individual se dibuja con una escala de grises que se extiende desde la imagen min hasta la imagen max, y NO a través del min / max global. Cuando fusiona todas las imágenes en una, bueno, solo hay un mínimo / máximo. Lo mismo es cierto para VRT, ya que VRT trata todas las imágenes como una sola (cuando eche un vistazo al archivo VRT verá las estadísticas comunes).
Cuando ambos, fusionar y VRT, no son una opción, el siguiente script podría ayudar.
En el primer bucle itero sobre todas las capas, seleccionando los rásteres y obtengo una estimación de su intervalo mínimo / máximo. Así es como funciona QGIS en sí mismo. A partir de estos valores min / max calculo el min / max global
En el segundo bucle, los renderizadores para todas las capas ráster se configuran de modo que la escala de grises se extienda a través del intervalo global 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()