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

Cannot render svg with image on 2.4.1 #257

Closed
Jackie1210 opened this issue Sep 17, 2023 · 16 comments · Fixed by #268
Closed

Cannot render svg with image on 2.4.1 #257

Jackie1210 opened this issue Sep 17, 2023 · 16 comments · Fixed by #268
Assignees

Comments

@Jackie1210
Copy link

Follow up the background with #256

This is second issue:

<svg width="100" height="100" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg"><mask id="satori_om-id"><rect x="0" y="0" width="100" height="100" fill="#fff"/></mask><rect x="0" y="0" width="100" height="100" fill="#fff"/><clipPath id="satori_cp-id-0"><rect x="0" y="0" width="100" height="100"/></clipPath><mask id="satori_om-id-0"><rect x="0" y="0" width="100" height="100" fill="#fff"/></mask><image x="0" y="0" width="100" height="100" href="data:image/svg+xml;utf8,%3Csvg  fill=%22none%22 xmlns=%22http://www.w3.org/2000/svg%22 width=%22100%22 height=%22100%22 viewBox=%220 0 100 100%22%3E%3Cimage id=%22image0_1_2%22 width=%22100%22 height=%22100%22 href=%22%22%3E%3C/image%3E%3C/svg%3E" preserveAspectRatio="none" clip-path="url(#satori_cp-id-0)" mask="url(#satori_om-id-0)"/><mask id="satori_om-id-0-0"><rect x="0" y="0" width="0" height="100" fill="#fff"/></mask></svg>
@yisibl
Copy link
Member

yisibl commented Sep 18, 2023

This is an <image> nested within an <image>, which we don't currently support and which requires further research.

image

For your test case, you can just remove the nesting and resvg-js will render it.

@yisibl
Copy link
Member

yisibl commented Sep 18, 2023

This looks like the same issue as #254.

@Jackie1210
Copy link
Author

@yisibl Actually, it rendered correctly before i upgrade to 2.4.1

@dkyeremeh
Copy link

dkyeremeh commented Sep 21, 2023

I have a similar issue. This is the svg code

<?xml version="1.0" encoding="utf-8"?>
<svg version="1.1" id="Layer_2" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px"
>
 <image x="0" y="0" width="140" height="48" xlink:href="https://touchplan.io/wp-content/uploads/2021/07/Demo-Company-Logo.jpeg" />
</svg>

This is the logging info

[2023-09-21T14:40:23Z WARN  resvg::image] Failed to load an embedded raw image.

@zimond
Copy link
Collaborator

zimond commented Sep 22, 2023

@dkyeremeh can you try if #258 fixes your problem?

@yisibl
Copy link
Member

yisibl commented Sep 22, 2023

@dkyeremeh I confirm that your case can be rendered.

Load the http image you need to refer to example/image-url.js

@Jackie1210
Copy link
Author

This is an <image> nested within an <image>, which we don't currently support and which requires further research.

image

For your test case, you can just remove the nesting and resvg-js will render it.

The reason why we cannot simply remove one of href, please check this case

@zimond
Copy link
Collaborator

zimond commented Sep 22, 2023

@Jackie1210 <image> tag inside an embedded base64 href is against the spec. And I think resvg does not support it on purpose. https://github.com/RazrFalcon/resvg/blob/master/crates/usvg-parser/src/image.rs#L225

@zimond
Copy link
Collaborator

zimond commented Sep 22, 2023

I believe you can use <svg> tag inside <svg> to get what you want. No need to base64 wrap every layer.

@Jackie1210
Copy link
Author

<image> tag inside an embedded base64 href is against the spec

Can you show me the spec's link cuz i haven't found any proof.

@zimond
Copy link
Collaborator

zimond commented Sep 22, 2023

@Jackie1210 https://www.w3.org/TR/SVG/embedded.html#ImageElementHrefAttribute

Since image references always refer to a complete document, a target-only URL is treated as a link to the same file, which is rendered again as an independent embedded image. Since the embedded image is processed in a secure mode, its own embedded references are not processed, preventing infinite recursion.

@dkyeremeh
Copy link

@dkyeremeh I confirm that your case can be rendered.

Load the http image you need to refer to example/image-url.js

I will try it out. On the other hand I would like to find out if there's a reason why images are not auto-loaded?

@dkyeremeh
Copy link

<?xml version="1.0" encoding="utf-8"?>
<svg version="1.1" id="Layer_2" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px"
>
 <image x="0" y="0" width="140" height="48" xlink:href="https://touchplan.io/wp-content/uploads/2021/07/Demo-Company-Logo.jpeg" />
</svg>

It works. Thanks

@Jackie1210
Copy link
Author

@Jackie1210 https://www.w3.org/TR/SVG/embedded.html#ImageElementHrefAttribute

Since image references always refer to a complete document, a target-only URL is treated as a link to the same file, which is rendered again as an independent embedded image. Since the embedded image is processed in a secure mode, its own embedded references are not processed, preventing infinite recursion.

Thanks for your feedback, but use case I gave does work in most browser, so it just confuse me. 😢

@zimond
Copy link
Collaborator

zimond commented Sep 23, 2023

@dkyeremeh because fetching network resource is always not safe, so we leave it as a user-motivated action instead of hiding this inside the library

@zimond
Copy link
Collaborator

zimond commented Sep 23, 2023

@Jackie1210 again, I think you can use <svg> inside <svg> to get what you need.

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

Successfully merging a pull request may close this issue.

4 participants