Рисование файла SVG на холсте HTML5 - PullRequest
102 голосов
/ 22 сентября 2010

Существует ли способ рисования файла SVG на холсте HTML5 по умолчанию? Google Chrome поддерживает загрузку SVG как изображения (и просто с использованием drawImage), но консоль разработчика предупреждает, что resource interpreted as image but transferred with MIME type image/svg+xml.

Я знаю, что есть возможность конвертировать SVG в команды canvas (как в этот вопрос ), но я надеюсь, что это не нужно. Меня не волнуют старые браузеры (поэтому, если FireFox 4 и IE 9 будут поддерживать что-то, этого достаточно).

Ответы [ 5 ]

89 голосов
/ 22 сентября 2010

РЕДАКТИРОВАТЬ 5 ноября 2014

Теперь вы можете использовать ctx.drawImage для рисования элементов HTMLImageElements с исходным кодом .svg в некоторых, но не во всех браузерах . Chrome, IE11 и Safari работают, Firefox работает с некоторыми ошибками (но по ночам их исправляет).

var img = new Image();
img.onload = function() {
    ctx.drawImage(img, 0, 0);
}
img.src = "http://upload.wikimedia.org/wikipedia/commons/d/d2/Svg_example_square.svg";

Живой пример здесь . Вы должны увидеть зеленый квадрат на холсте. Второй зеленый квадрат на странице - это тот же элемент <svg>, вставленный в DOM для справки.

Вы также можете использовать новые объекты Path2D для рисования SVG (строковых) путей ( работает только в Chrome ). Другими словами, вы можете написать:

var path = new Path2D('M 100,100 h 50 v 50 h 50');
ctx.stroke(path);

Живой пример этого здесь.


Старый ответ потомков:

Нет ничего нативного, что позволяет вам использовать SVG-пути на холсте. Вы должны преобразовать себя или использовать библиотеку, чтобы сделать это для вас.

Я бы посоветовал заглянуть в canvg:

http://code.google.com/p/canvg/

http://canvg.googlecode.com/svn/trunk/examples/index.htm

19 голосов
/ 09 мая 2015

Вы можете легко нарисовать простые svg s на холсте:

  1. Назначение источника изображения для изображения в формате base64
  2. Рисование изображения на холсте

Примечание: Единственный недостаток метода заключается в том, что он не может рисовать изображения, встроенные в svg. (см. демонстрацию)

Демонстрация:

(обратите внимание, что встроенное изображение видно только в svg)

var svg = document.querySelector('svg');
var img = document.querySelector('img');
var canvas = document.querySelector('canvas');

// get svg data
var xml = new XMLSerializer().serializeToString(svg);

// make it base64
var svg64 = btoa(xml);
var b64Start = 'data:image/svg+xml;base64,';

// prepend a "header"
var image64 = b64Start + svg64;

// set it as the source of the img element
img.src = image64;

// draw the image onto the canvas
canvas.getContext('2d').drawImage(img, 0, 0);
svg, img, canvas {
  display: block;
}
SVG

<svg height="40">
  <rect width="40" height="40" style="fill:rgb(255,0,255);" />
  <image xlink:href="https://en.gravatar.com/userimage/16084558/1a38852cf33713b48da096c8dc72c338.png?size=20" height="20px" width="20px" x="10" y="10"></image>
</svg>
<hr/><br/>

IMAGE
<img/>
<hr/><br/>
   
CANVAS
<canvas></canvas>
<hr/><br/>
13 голосов
/ 26 июля 2017

Извините, у меня недостаточно репутации, чтобы комментировать ответ @Matyas, но если изображение svg также в base64, оно будет отображено на выходе.

Демо-версия:

var svg = document.querySelector('svg');
var img = document.querySelector('img');
var canvas = document.querySelector('canvas');

// get svg data
var xml = new XMLSerializer().serializeToString(svg);

// make it base64
var svg64 = btoa(xml);
var b64Start = 'data:image/svg+xml;base64,';

// prepend a "header"
var image64 = b64Start + svg64;

// set it as the source of the img element
img.onload = function() {
    // draw the image onto the canvas
    canvas.getContext('2d').drawImage(img, 0, 0);
}
img.src = image64;
svg, img, canvas {
  display: block;
}
SVG

<svg height="40">
  <rect width="40" height="40" style="fill:rgb(255,0,255);" />
  <image xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAEX0lEQVQ4jUWUyW6cVRCFv7r3/kO3u912nNgZgESAAgGBCJgFgxhW7FkgxAbxMLwBEmIRITbsQAgxCEUiSIBAYIY4g1EmYjuDp457+Lv7n+4tFjbwAHVOnVPnlLz75ht67OhhZg/M0p6d5tD9C8SNBBs5XBJhI4uNLC4SREA0UI9yJr2c4e6QO+v3WF27w+rmNrv9Pm7hxDyHFg5yYGEOYxytuRY2SYiSCIwgRgBQIxgjEAKuZWg6R9S0SCS4qKLZElY3HC5tp7QPtmlMN7HOETUTXBJjrEGsAfgPFECsQbBIbDGJZUYgGE8ugQyPm+o0STtTuGZMnKZEjRjjLIgAirEOEQEBDQFBEFFEBWLFtVJmpENRl6hUuFanTRAlbTeZarcx0R6YNZagAdD/t5N9+QgCYAw2jrAhpjM3zaSY4OJGTDrVwEYOYw2qioigoviq5MqF31m9fg1V5fCx+zn11CLNVnufRhBrsVFE1Ihpthu4KDYYwz5YQIxFBG7duMZnH31IqHL6wwnGCLFd4pez3/DaG2/x4GNPgBhEZG/GGlxkMVFkiNMYay3Inqxed4eP33uf7Y0uu90xWkGolFAru7sZn5w5w921m3u+su8vinEO02hEWLN/ANnL2rkvv2an2yd4SCKLM0JVBsCgAYZZzrnPP0eDRzXgfaCuPHXwuEYjRgmIBlQVVLl8/hKI4fRzz3L6uWe5+PMvnHz6aa4uX+D4yYe5vXaLH86eoyoLjLF476l9oKo9pi5HWONRX8E+YznOef7Vl1h86QWurlwjbc+QpikPPfoIcZLS39pmMikp8pzae6q6oqgriqrGqS+xeLScoMYSVJlfOMTl5RXW1+5w5fJVnFGWf1/mxEMnWPppiclkTLM5RdJoUBYFZVlQ5DnZMMMV167gixKLoXXsKGqnOHnqOJ/+/CfZ+XUiZ0jTmFv5mAvf/YjEliQ2vPD8Ir6qqEcZkzt38cMRo5WruFvfL9FqpyRxQhj0qLOax5I2S08+Tu/lFiGUGOPormxwuyfMnjrGrJa88uIixeYWl776lmrzNjmw8vcG8sU7ixpHMXFsCUVg9tABjEvRgzP82j7AhbyiX5Qcv2+Bvy7dYGZ1k7efeQB/Y4PBqGBtdYvb3SFzLcfqToZc/OB1zYeBSpUwLBlvjZidmWaSB1yaYOfn6LqI/r0hyU6P+cRSlhXjbEI2zvnt7y79oqQ3qeg4g6vKjCIXehtDmi6m0UnxVnCRkPUHVNt9qkLJxgXOCYNOg34v48raPaamU2o89/KKsQ9sTSpc0JK7NwdcX8s43Ek5cnSOLC/Z2R6Rj0ra0w2W1/t0xyWn51uk2Ri1QtSO6OU5d7OSi72cQeWxKG7p/Dp//JXTy6C1Pcbc6DMpPRtjTxChEznWhwVZUCKrjCrPoPDczHLmnLBdBgZlRRWUEBR3ZKrme5TlrTGlV440Y1IrXM9qQGi6mkG5V6uza7tUIeCDElTZ1L26elX+fcH/ACJBPYTJ4X8tAAAAAElFTkSuQmCC" height="20px" width="20px" x="10" y="10"></image>
</svg>
<hr/><br/>

IMAGE
<img/>
<hr/><br/>
   
CANVAS
<canvas></canvas>
<hr/><br/>
7 голосов
/ 31 октября 2013

Mozilla имеет простой способ рисования SVG на холсте, который называется " Рисование объектов DOM на холсте "

4 голосов
/ 02 апреля 2013

Как говорит Саймон выше, использование drawImage не должно работать. Но, используя библиотеку canvg и:

var c = document.getElementById('canvas');
var ctx = c.getContext('2d');
ctx.drawSvg(SVG_XML_OR_PATH_TO_SVG, dx, dy, dw, dh);

Это происходит по ссылке, которую Саймон предоставляет выше, в которой есть ряд других предложений и указывается, что вы хотите либо дать ссылку, либо загрузить canvg.js и rgbcolor.js. Это позволяет вам манипулировать и загружать SVG, либо через URL, либо используя встроенный код SVG между тегами svg, в функциях JavaScript.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...