-->
Sep 24, 2022
maplibre-rs is an upcoming and cross-platform vector map renderer written in Rust. If you want to get in touch with the developers, visit the #maplibre:matrix.org chat or join the MapLibre (#maplibre and #maplibre-rs) community within the OpenStreetMap Slack. You can get an invitation here.
It has been an exciting summer - FOSS4G happened and a paper about maplibre-rs was published. The whole MapLibre team was able to meet! We met our sponsors and other awesome people from the open-source community.
And because a picture is worth a thousand words:
Behind the scenes, I was working on providing an alternative multi-threading implementation for the web platform. Because atomics are only supported by enabling specific HTTP headers, we really need a more portable implementation which does not rely on these atomics. Instead of doing real multithreading in the browser, we want to do multiprocessing through WebWorkers. I designed an interface which should work well for most data-processing needs. The interface is called AsyncProcedureCall
.
#[derive(Clone)]
pub enum Message<T: Transferables> {
TileTessellated(T::TileTessellated),
UnavailableLayer(T::UnavailableLayer),
TessellatedLayer(T::TessellatedLayer),
}
#[derive(Clone, Serialize, Deserialize)]
pub enum Input {
TileRequest(TileRequest),
}
pub type AsyncProcedure<C> = fn(input: Input, context: C) -> AsyncProcedureFuture;
pub trait AsyncProcedureCall<T: Transferables, HC: HttpClient>: 'static {
type Context: Context<T, HC> + Send;
fn receive(&mut self) -> Option<Message<T>>;
fn schedule(&self, input: Input, procedure: AsyncProcedure<Self::Context>);
}
Instead of relying on mutexes and MPSC channels, the implementation of this APC
for the web relies on WebWorkers and sending ArrayBuffers.
Iโm working on this in a rather large PR. As not much else is going on in the project, merging probably wonโt cause issues.
The following will summarizes what happened last week on GitHub.
#169 Add watch functionality for web by @maxammann
We have now build tools for the web which automatically reloads the demo in the browser for changes in Rust.
#167 Add citation instructions by @maxammann
The maplibre-rs is now officially citable in others scientific work!
#160 Add CLI to demo by @maxammann
A CLI allows users now to configure the demo on Linux, Windows and macOS.
#154 Run scheduled builds by @maxammann
We regularly build our main branch now, to detect breaking dependencies.
#80 Refactor WebWorker pool by @maxammann
This is the start of a major refactor for async tasks on the web.
#166 ReferenceError: Canโt find variable: Worker by @maxammann
This bug blocks us currently on Safari (iOS/macOS). Iโm actively working right now to provide a build which does not use atomics.
#164 INVALID_ENUM: framebuffertexture2d invalid attachment by @maxammann
This is a bug in older versions in Safari. With the release of iOS 16 and Safari 16 this is fixed now.
#161 Limit the maximum and minimum zoom level by @hanchao
We got a great bug report! It seems like people are experimenting with maplibre-rs in the wild!
None.