Closed Bug 1779963 Opened 3 years ago Closed 3 years ago

toDataUrl() or drawImage() not producing image

Categories

(Core :: Graphics: Canvas2D, defect)

Firefox 102
defect

Tracking

()

RESOLVED DUPLICATE of bug 700533

People

(Reporter: rustem.yuzlibaev, Unassigned)

Details

User Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/103.0.0.0 Safari/537.36
Firefox for Android

Steps to reproduce:

There is a string image/svg+xml (base64) that needs to be transformed to image/png (base64) (to show this icon in browser notifications):



Function that does transformation:

function base64SvgToBase64Png(imgsrc: string): Promise<string> {
return new Promise((resolve, reject) => {
const canvas = document.createElement('canvas');

canvas.setAttribute('width', '80');
canvas.setAttribute('height', '80');

const context = canvas.getContext('2d');

const image = new Image();
image.src = imgsrc;

image.onload = function () {
  try {
    if (context) {
      context.drawImage(image, 0, 0);
      const base64PNG = canvas.toDataURL('image/png');
      resolve(base64PNG);
    }
  } catch (e) {
    reject(e);
  }
};

});
}

Actual results:

Resolved value of the promise:



(image corrupted)

Expected results:

Whereas on Chrome it resolved to this:



(here it is possible to see it in base64 image viewer)

Component: Untriaged → Graphics: Canvas2D
Product: Firefox → Core

what is the SVG input? Does it have width and height attributes on the root node? If it does are either of them percentages? Is the SVG self-contained i.e. no external references?

Flags: needinfo?(rustem.yuzlibaev)

(In reply to Robert Longson [:longsonr] from comment #1)

what is the SVG input? Does it have width and height attributes on the root node? If it does are either of them percentages? Is the SVG self-contained i.e. no external references?

as stated in post it is ('imgsrc' argument that is passed in base64SvgToBase64Png function):



This image is viewable at https://jaredwinick.github.io/base64-image-viewer/, so it's correct

Flags: needinfo?(rustem.yuzlibaev)

Please attach the actual SVG you're trying to convert to this question.

Flags: needinfo?(rustem.yuzlibaev)

(In reply to Robert Longson [:longsonr] from comment #3)

Please attach the actual SVG you're trying to convert to this question.

I don't have image itself but its URI representation:
data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 22' %3E%3Cpath fill='%23E3232C' d='M22,11c0,6.1-4.9,11-11,11S0,17.1,0,11S4.9,0,11,0S22,4.9,22,11z'/%3E%3Cpath fill='%23FFFFFF' d='M5.8,20.7c1.7-2.6,3.5-5.2,5.3-7.8l5.2,7.8c0.3-0.1,0.5-0.3,0.8-0.5s0.5-0.3,0.7-0.5 c-1.9-2.9-3.9-5.8-5.8-8.7h5.8V9.2H12V7.3h5.8V5.5H4.3v1.8h5.8v1.9H4.3V11h5.8l-5.8,8.7C4.5,19.9,4.7,20,5,20.2 C5.3,20.4,5.5,20.6,5.8,20.7z'/%3E%3C/svg%3E

Then, by running these lines below I will got base64 encodings:

// 'icon' variable here is the URI code above

// take svg string starting from '<' char up to end
const svgUriEncoded = icon.substring(icon.indexOf('%3C'));
const svgUriDecoded = decodeURIComponent(svgUriEncoded);
const base64SvgEncoded = base64.encode(svgUriDecoded);

base64SvgEncoded variable will be this:
PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9JzAgMCAyMiAyMicgPjxwYXRoIGZpbGw9JyNFMzIzMkMnIGQ9J00yMiwxMWMwLDYuMS00LjksMTEtMTEsMTFTMCwxNy4xLDAsMTFTNC45LDAsMTEsMFMyMiw0LjksMjIsMTF6Jy8+PHBhdGggZmlsbD0nI0ZGRkZGRicgZD0nTTUuOCwyMC43YzEuNy0yLjYsMy41LTUuMiw1LjMtNy44bDUuMiw3LjhjMC4zLTAuMSwwLjUtMC4zLDAuOC0wLjVzMC41LTAuMywwLjctMC41IGMtMS45LTIuOS0zLjktNS44LTUuOC04LjdoNS44VjkuMkgxMlY3LjNoNS44VjUuNUg0LjN2MS44aDUuOHYxLjlINC4zVjExaDUuOGwtNS44LDguN0M0LjUsMTkuOSw0LjcsMjAsNSwyMC4yIEM1LjMsMjAuNCw1LjUsMjAuNiw1LjgsMjAuN3onLz48L3N2Zz4=

Last step adding PREFIX: data:image/svg+xml,base64 to above base64 string at the beginning

I don't think this is useful info as this input is the same for both Firefox and Chrome
Something is happening inside base64SvgToBase64Png() function

Flags: needinfo?(rustem.yuzlibaev)

As I hinted in comment 1, you need width and height attributes on the svg root element and the values on the width and height must not be percentages.

Status: UNCONFIRMED → RESOLVED
Closed: 3 years ago
Resolution: --- → DUPLICATE

Thank you for your support

You need to log in before you can comment on or make changes to this bug.