使用 OpenLayers WebGL 渲染托管 GeoTIFF 文件未正确可视化

发布于 2025-01-09 23:59:19 字数 3104 浏览 1 评论 0原文

在 Web 地图应用程序中,我尝试使用 OpenLayers 6 将 GeoTIFF 文件渲染为 OSM 图层上的覆盖图层。该图层渲染在确切的位置,看起来很好。这是我的结果的屏幕截图:

在此处输入图像描述

但如果我放大,在某些区域我可以看到平滑(简化)的边缘,这不是我想要的:

在此处输入图像描述

这是我的代码:

import React, { useState, useEffect, useRef } from "react";
import "ol/ol.css";

import GeoTIFF from "ol/source/GeoTIFF";
import Map from "ol/Map";
import View from "ol/View";
import TileLayer from "ol/layer/WebGLTile";

import OSMLayer from "./OSMLayer";
import { fromLonLat } from "ol/proj";

function App() {
  var mapObjectRef = useRef();
  var tifLayer = useRef();

  const pixelValue = [
    "case",
    ["<=", ["band", 1], 0.0],
    -1,
    ["between", ["band", 1], 0.0, 5.0],
    0,
    ["between", ["band", 1], 5.0, 6.0],
    1,
    ["between", ["band", 1], 6.0, 7.0],
    2,
    ["between", ["band", 1], 7.0, 8.0],
    3,
    ["between", ["band", 1], 8.0, 9.0],
    4,
    ["between", ["band", 1], 9.0, 10.0],
    5,
    6,
  ];

  useEffect(() => {
    const source = new GeoTIFF({
      sources: [
        {
          url: "http://../my_image.tif";
          interpolate: false,
        },
      ],
      normalize: false,
    });

    source.on("change", (e) => {
      mapObjectRef.current.addLayer(tifLayer.current);
    });

    tifLayer.current = new TileLayer({
      style: {
        color: [
          "case",
          ["==", pixelValue, -1],
          [0, 0, 0, 0],
          ["==", pixelValue, 0],
          "#FFFFFF",
          ["==", pixelValue, 1],
          [247, 37, 133, 1],
          ["==", pixelValue, 2],
          [181, 23, 158, 1],
          ["==", pixelValue, 3],
          [114, 9, 183, 1],
          ["==", pixelValue, 4],
          [86, 11, 173, 1],
          ["==", pixelValue, 5],
          [63, 55, 201, 1],
          ["==", pixelValue, 6],
          "#ff0000",
          "#0000ff",
        ],
      },
      source: source,
    });

    mapObjectRef.current = new Map({
      target: "map",
      layers: [OSMLayer()],
      view: new View({
        center: fromLonLat([lat, lng]),
        zoom: 15.5,
      }),
    });
  }, []);

  return (
    <div
      id="map"
      style={{ height: "100vh", width: "100%" }}/>
  );
}

export default App;

我的问题是实现如下目标:

在此处输入图像描述

更多信息

我尝试渲染的图像是 < code>.tif 文件并具有以下元数据(使用 gdal.Info()):

Band 1 Block=161x12 Type=Float32, ColorInterp=Gray
  Min=5.000 Max=10.000 
  Minimum=5.000, Maximum=10.000, Mean=6.864, StdDev=1.788
  NoData Value=-3.39999995214436425e+38
  Metadata:
    STATISTICS_MAXIMUM=10
    STATISTICS_MEAN=6.8642607683353
    STATISTICS_MINIMUM=5
    STATISTICS_STDDEV=1.7880035940136

In a web map application, I am trying to render a GeoTIFF file as an overlay layer on a OSM layer using OpenLayers 6. The layer is rendered on the exact location and it seems fine. Here is the screenshot of my results:

enter image description here

But if I zoom in, in some areas I could see smooth (simplified) edges which is not what I want:

enter image description here

Here is my code:

import React, { useState, useEffect, useRef } from "react";
import "ol/ol.css";

import GeoTIFF from "ol/source/GeoTIFF";
import Map from "ol/Map";
import View from "ol/View";
import TileLayer from "ol/layer/WebGLTile";

import OSMLayer from "./OSMLayer";
import { fromLonLat } from "ol/proj";

function App() {
  var mapObjectRef = useRef();
  var tifLayer = useRef();

  const pixelValue = [
    "case",
    ["<=", ["band", 1], 0.0],
    -1,
    ["between", ["band", 1], 0.0, 5.0],
    0,
    ["between", ["band", 1], 5.0, 6.0],
    1,
    ["between", ["band", 1], 6.0, 7.0],
    2,
    ["between", ["band", 1], 7.0, 8.0],
    3,
    ["between", ["band", 1], 8.0, 9.0],
    4,
    ["between", ["band", 1], 9.0, 10.0],
    5,
    6,
  ];

  useEffect(() => {
    const source = new GeoTIFF({
      sources: [
        {
          url: "http://../my_image.tif";
          interpolate: false,
        },
      ],
      normalize: false,
    });

    source.on("change", (e) => {
      mapObjectRef.current.addLayer(tifLayer.current);
    });

    tifLayer.current = new TileLayer({
      style: {
        color: [
          "case",
          ["==", pixelValue, -1],
          [0, 0, 0, 0],
          ["==", pixelValue, 0],
          "#FFFFFF",
          ["==", pixelValue, 1],
          [247, 37, 133, 1],
          ["==", pixelValue, 2],
          [181, 23, 158, 1],
          ["==", pixelValue, 3],
          [114, 9, 183, 1],
          ["==", pixelValue, 4],
          [86, 11, 173, 1],
          ["==", pixelValue, 5],
          [63, 55, 201, 1],
          ["==", pixelValue, 6],
          "#ff0000",
          "#0000ff",
        ],
      },
      source: source,
    });

    mapObjectRef.current = new Map({
      target: "map",
      layers: [OSMLayer()],
      view: new View({
        center: fromLonLat([lat, lng]),
        zoom: 15.5,
      }),
    });
  }, []);

  return (
    <div
      id="map"
      style={{ height: "100vh", width: "100%" }}/>
  );
}

export default App;

My issue is achieving something as follow:

enter image description here

More inforamion

The image that I am trying to render is a .tif file and has following metadata (using gdal.Info()):

Band 1 Block=161x12 Type=Float32, ColorInterp=Gray
  Min=5.000 Max=10.000 
  Minimum=5.000, Maximum=10.000, Mean=6.864, StdDev=1.788
  NoData Value=-3.39999995214436425e+38
  Metadata:
    STATISTICS_MAXIMUM=10
    STATISTICS_MEAN=6.8642607683353
    STATISTICS_MINIMUM=5
    STATISTICS_STDDEV=1.7880035940136

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

孤独岁月 2025-01-16 23:59:19

interpolate 是 GeoTIFF 构造函数的一个选项,不适用于单个源

const source = new GeoTIFF({
  sources: [
    {
      url: "http://../my_image.tif";
    },
  ],
  interpolate: false,
  normalize: false,
});

interpolate is an option for the GeoTIFF constructor, not for individual sources

const source = new GeoTIFF({
  sources: [
    {
      url: "http://../my_image.tif";
    },
  ],
  interpolate: false,
  normalize: false,
});
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文