เหตุผลสำหรับลักษณะที่ปรากฏของกระเบื้องโมเสคนี้คือภาพแต่ละภาพถูกวาดด้วยสเกลสีเทาซึ่งขยายจากนาทีของภาพเป็นสูงสุดของภาพและไม่ครอบคลุมทั่วโลกต่อนาที เมื่อคุณรวมภาพทั้งหมดเป็นภาพเดียวก็มีเพียงหนึ่งนาที / สูงสุด เช่นเดียวกันกับ VRT เนื่องจาก VRT ปฏิบัติต่อภาพทั้งหมดเป็นภาพเดียว (เมื่อคุณดูในไฟล์ VRT คุณจะเห็นสถิติทั่วไป)
เมื่อทั้งสองผสานและ VRT ไม่ใช่ตัวเลือกสคริปต์ต่อไปนี้อาจช่วยได้
ในลูปแรกฉันวนซ้ำทุกเลเยอร์เลือกแรสเตอร์และรับช่วงเวลาต่ำสุด / สูงสุด นี่คือวิธีที่ QGIS ทำงาน จากค่าต่ำสุด / สูงสุดฉันจะคำนวณค่าต่ำสุด / สูงสุดทั่วโลก
ในลูปที่สองตัวเรนเดอร์สำหรับเลเยอร์แรสเตอร์ทั้งหมดจะได้รับการกำหนดค่าเพื่อให้สเกลสีเทายืดข้ามช่วงเวลาทั่วโลกต่ำสุด / สูงสุด
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()