实现地图颜色滤镜
这是cesium提供的更改地图颜色的效果
data:image/s3,"s3://crabby-images/e0b8e/e0b8e54e3dffb4aa910618d3180aaf0f29fb391c" alt=""
ImageryLayer提供了修改 brightness图层亮度 contrast对比度 hue色相 saturation饱和度 gamma伽玛校正 这些属性
data:image/s3,"s3://crabby-images/d876a/d876a82c0ce35ab41e14bc70a3f022fcd0a8bd9a" alt=""
但是用完你会发现,调不出来我想要的颜色,产品想要的一个颜色效果,用这些配置根本达不到要求,所以需要增加一个颜色属性,然后再配合这些属性进行微调
修改源码实现
仿照ImageryLayer源码的原有属性的代码,在其相关地方加入filterRGB属性用于设置颜色
data:image/s3,"s3://crabby-images/e3b89/e3b89a640ce82b72585776c315b85ca0e11f2323" alt=""
data:image/s3,"s3://crabby-images/a198d/a198d15df6bd76346d224b48e91a1bca3309b72a" alt=""
data:image/s3,"s3://crabby-images/58b65/58b65d07112462d1b422725b97c195fd77e91e44" alt=""
data:image/s3,"s3://crabby-images/85bd8/85bd87984a425d87bcd1dd9945b42b8eb5b45f56" alt=""
这里为了使用方便,对颜色值进行一个调整
data:image/s3,"s3://crabby-images/caffd/caffd1bfa089b18ca5e732bc3f0b5c461c5ef028" alt=""
data:image/s3,"s3://crabby-images/78307/783075eea129ae68352f8a1a62f7d9a1b95c4984" alt=""
data:image/s3,"s3://crabby-images/1f693/1f6930a69ad92a33df5d6c3c99199e3b8107c568" alt=""
上面实现了一种滤镜颜色效果,进一步优化,再增加一种灰度反色滤镜效果。
业务端调用
ts
// 部分代码,业务端调用时修改这些属性就可以了
let layersLength = this.viewerCesium.imageryLayers.length;
if (layersLength === 0) return false;
for (let j = 0; j < layersLength; j++) {
let imageryLayer = this.viewerCesium.imageryLayers.get(j);
imageryLayer.alpha = mapBottomParam.alpha;
imageryLayer.brightness = mapBottomParam.brightness;
imageryLayer.contrast = mapBottomParam.contrast;
imageryLayer.saturation = mapBottomParam.saturation;
if (mapBottomParam.filterColor) {
const color = Color.fromCssColorString(mapBottomParam.filterColor);
if (mapMode === 1) {
// @ts-ignore
imageryLayer.color = new Cartesian3(color.red, color.green, color.blue);
// @ts-ignore
imageryLayer.colorEnable = true;
// @ts-ignore
imageryLayer.filterColorEnable = false;
imageryLayer.gamma = 0.3;
} else if (mapMode === 3) {
// @ts-ignore
imageryLayer.filterColor = new Cartesian3(color.red, color.green, color.blue);
// @ts-ignore
imageryLayer.filterColorEnable = true;
// @ts-ignore
imageryLayer.colorEnable = false;
}
}
}
效果
data:image/s3,"s3://crabby-images/588dd/588dd36ccaab05beb17d410004fdd90d6420caca" alt=""