Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

addProtocol for custom Protocols like PMTiles #28

Open
punov opened this issue Feb 2, 2023 · 10 comments
Open

addProtocol for custom Protocols like PMTiles #28

punov opened this issue Feb 2, 2023 · 10 comments

Comments

@punov
Copy link

punov commented Feb 2, 2023

Motivation

At the moment, we have a frontend integration with Protomaps vector tiles, that have a full support of Maplibre GL:
https://protomaps.com/docs/frontends/maplibre

Inside our Mobile application, we use Maplibre as tool for rendering maps, but we don't have a chance to render same vector tiles since this custom protocol is not supported out of the box, and there's no way to add it.

Implementation

Expectations is to have the same addProtocol method to provide a loadFn for custom tile servers like pmtiles.

import * as pmtiles from "pmtiles";

let protocol = new pmtiles.Protocol();
maplibregl.addProtocol("pmtiles",protocol.tile);

If there's any known workaround to provide support for custom protocol using the existing Maplibre API,
I'd appreciate any directions / advices.

@jthiard
Copy link
Contributor

jthiard commented Feb 2, 2023

Hi @punov
I didn't got deep into it, but if I understand it right the addProtocol method in maplibre-gl-js is used to override with javascript code the tiles fetching when using a specific protocol in source url.

As this maplibre-react-native lib is a wrapper on top of maplibre-gl-native - and not maplibre-gl-js, fetching the tiles is made at the native level, and you won't be able to customize it with javascript code.

I'm unsure if it may be customized at the android / iOS level (with java/objectiveC or kotlin/swift hooks) or if it requires to go deeper at the C++ level.

@punov
Copy link
Author

punov commented Feb 2, 2023

@jthiard thanks for your answer, after going through the source code, I have the same understanding.
I'm ok to customize the native code to support it, but at the moment I struggle finding the proper hook for tileserver fetch operations.

addProtocol method is as simple as calling the function to fetch the data according to current coordinates and zoom level,
so getting closer to the function that executes it in native code is a step #1 for me.

@lseelenbinder
Copy link
Member

lseelenbinder commented Feb 6, 2023

@punov You'll be looking for functionality around here:

src/mbgl/storage

Most likely an adaptation of src/mbgl/storage/http_file_source.hpp and platform/default/src/mbgl/storage/http_file_source.cpp with some of platform/default/src/mbgl/storage/file_source_manager.cpp.

It's a bit of a mess, but generally you can register handlers for types of files, and there's a default FileSourceManager normally invoked. You'll need to create your own and pass it through via ResourceOptions: src/mbgl/map/map.cpp.

Does this help point you in the right direction?

@lpatrun
Copy link

lpatrun commented Nov 28, 2024

Is there any progress on this? Or some instructions on how to do it?

@KiwiKilian
Copy link
Collaborator

KiwiKilian commented Nov 28, 2024

PMTiles is currently beeing worked on at the MapLibre Native side maplibre/maplibre-native#2882.

@lpatrun
Copy link

lpatrun commented Dec 19, 2024

Is there any plan for the near/distant future to have an addProtocol functionality like it is implemented for the "maplibre-gl"?

@KiwiKilian
Copy link
Collaborator

AFAIK there is nobody working on addProtocol, you can try implementing something like this as described by #28 (comment) – but I can't yet imagine a clean way where this would be supported by MapLibre RN.

PMTiles support is much more likely, once it's available in MapLibre Native.

@KiwiKilian KiwiKilian changed the title Missing addProtocol method fot custom protocols, Protomaps / pmtiles support Missing addProtocol method for custom Protocols like PMTiles Dec 22, 2024
@KiwiKilian KiwiKilian changed the title Missing addProtocol method for custom Protocols like PMTiles addProtocol for custom Protocols like PMTiles Dec 22, 2024
@KiwiKilian
Copy link
Collaborator

Would anyone need an addProtocol method for anything else then PMTiles? Would love to hear other use cases, if there are any.

@tyrauber
Copy link
Collaborator

Wouldn't addProtocol be required to support an api_key on styleJSON?

What about the maplibre-contour plugin which uses addProtocol under the covers to accomplish the terrain layers from a raster-dem?

@onizukanaim
Copy link

My solution meanwhile :
Thank you use dom

"use dom";

import maplibregl from "maplibre-gl";
import { Protocol } from "pmtiles";
import layers from "protomaps-themes-base";
import { useEffect } from "react";
import { Map } from "react-map-gl";
import { View } from "react-native";
import { useColorScheme } from "~/utils/useColorScheme";

export default function MapViewWeb() {
  const { colorScheme } = useColorScheme();
  useEffect(() => {
    let protocol = new Protocol();
    maplibregl.addProtocol("pmtiles", protocol.tile);
    return () => {
      maplibregl.removeProtocol("pmtiles");
    };
  }, []);

  return (
    <Map
      attributionControl={false}
      style={{ width: "100vw", height: "100vh" }}
      mapStyle={{
        glyphs:
          "https://protomaps.github.io/basemaps-assets/fonts/{fontstack}/{range}.pbf",
        sprite:
          "https://api.protomaps.com/styles/v4/light/en.json?key=NON_COMMERCIAL_USE_KEY",
        version: 8,
        sources: {
          sample: {
            type: "vector",
            url: "pmtiles://https://world.pmtiles",
          },
        },
        layers: layers(
          "sample",
          colorScheme,
          "en"
        ) as mapboxgl.LayerSpecification[],
      }}
      mapLib={maplibregl as any}
    />
  );
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

7 participants