question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

l-image-overlay with assets images

See original GitHub issue

Description

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:closed
  • Created 4 years ago
  • Comments:6 (3 by maintainers)

github_iconTop GitHub Comments

1reaction
DonNicoJscommented, Jan 24, 2020

@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 component

0reactions
Dinuzcommented, Mar 17, 2020

@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 component

Thank you that’s precisely the way to let it work properly:)

Read more comments on GitHub >

github_iconTop 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 >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found