How to make offline maps(using leaflet OSM) , by caching?

不问归期 提交于 2019-12-31 08:46:10

问题


I am trying to make offline maps through caching (IndexedDB) in browser. I understand the concept is that I download and store the tiles of map first when connected to internet.

Then I have to load the tiles logically offline.

However, I'm not able to figure it out.

How do I store them and how to load them again logically? I'm stuck here. I am using the leaflet API for maps. How can this be implemented?


回答1:


See my extensive research on this at:

Storing Image Data for offline web application (client-side storage database)

and at:

https://gis.stackexchange.com/questions/44813/database-for-offline-slippy-map-tiles

Key for what you want to do is a Functional Tile layer to get stuff from the DB:

https://github.com/ismyrnow/Leaflet.functionaltilelayer

BTW, I am just now testing out PouchDB for this, which is much cleaner that the raw IndexeDB.

Follow my results at:

https://groups.google.com/forum/?fromgroups#!topic/pouchdb/RG6wUsAi2R0




回答2:


I have cache example implementation http://tbicr.github.com/OfflineMap/leaflet/index.html and code https://github.com/tbicr/OfflineMap/tree/master/leaflet_idb_sql_site.

For storage used IndexedDB and WebSQL. Storage had low performance and not tested.




回答3:


I am working on a solution for the same problem. Storing tiles from a tileserver, and loading them from the db in leafletjs.

I have implemented a custom layer which loads tiles from a db (indexeddb/webdatabase) if available, and fallbacks to an tileserver (which has Access-Control-Allow-Origin header, see https://developer.mozilla.org/en-US/docs/Web/HTTP/Access_control_CORS#Access-Control-Allow-Credentials)

I implemented a control which saves the tiles currently in view in indexeddb or webdatabase.

Code is on https://github.com/allartk/leaflet.offline This is still work in progress at this time!



来源:https://stackoverflow.com/questions/16036880/how-to-make-offline-mapsusing-leaflet-osm-by-caching

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!