l-image-overlay with assets images
See original GitHub issueDescription
Can’t use image from assets folder.
Steps to Reproduce
<l-map
style="height: 400px; width: 400px"
:zoom="zoom"
:center="center"
:options="{zoomControl: false}"
:crs="crs"
>
<l-image-overlay url="@/assets/logo.png" :bounds="bounds"></l-image-overlay>
<l-marker v-for="star in stars" :lat-lng="star" :key="star.name">
<l-popup :content="star.name" />
</l-marker>
</l-map>
Expected Results
Image works
Actual Results
Image won’t show. I get following errors:
data:image/png;base…:1 GET ") net::ERR_INVALID_URL
It works if i use leaflet directly and not Vue2Leaflet.
Browsers Affected
- Chrome
- Firefox
- Edge
- Safari 9
- Safari 8
- IE 11
Versions
- Leaflet: v1.6.0
- Vue: v2.6.10
- Vue2Leaflet: v2.4.2
Issue Analytics
- State:
- Created 4 years ago
- Comments:6 (3 by maintainers)
Top Results From Across the Web
L.ImageOverlay
Instantiates an image overlay object given the URL of the image and the geographical bounds it is tied to. Options. Option, Type, Default,...
Read more >Leaflet put image overlay below the map - Stack Overflow
I have a mapbox map and an Image Overlay on my leaflet project. I need to put the image below the map (which...
Read more >How can i an add image overlay depending on the options in ...
Because you need to create separate image overlays for each feature, ... var imageLayer = L.imageOverlay(imageUrl, imageBounds).addTo(map).
Read more >Adding an image or raster data to a leaflet map - YouTube
This video shows you how to add an image or raster data to a leaflet map. There are many reasons why you might...
Read more >How to add overlay image to map in Leaflet - B4X
assets /sponget.png", 42, 42, 0, 42) ... Follow the steps given below to use an image overlay. ... <title>Image Overlay Example</title>
Read more >
Top Related Medium Post
No results found
Top Related StackOverflow Question
No results found
Troubleshoot Live Code
Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free
Top Related Reddit Thread
No results found
Top Related Hackernoon Post
No results found
Top Related Tweet
No results found
Top Related Dev.to Post
No results found
Top Related Hashnode Post
No results found
@NicolasR So, this is what the component is doing inside
imageOverlay(this.url, this.bounds, options);
As you can see is exactly what you are doing 😃 the difference lays here:private mapPath: any = require('@/assets/map-france-blank.svg');
The require here, compared to adding the
@/assets/map-france-blank.svg
inside a vue template change how the webpack loaders handle it. To test this theory just use require to load the image, assign it to a data or computed value and then pass it to the componentThank you that’s precisely the way to let it work properly:)