HTML5 tuvalinde bir SVG dosyası çizme


131

Bir SVG dosyasını HTML5 tuvaline çizmenin varsayılan bir yolu var mı? Google Chrome, SVG'yi bir resim olarak yüklemeyi (ve yalnızca kullanmayı drawImage) destekler, ancak geliştirici konsolu bunu uyarır resource interpreted as image but transferred with MIME type image/svg+xml.

SVG'yi tuval komutlarına dönüştürmek için bir olasılık olduğunu biliyorum ( bu soruda olduğu gibi ), ancak buna gerek olmadığını umuyorum. Eski tarayıcıları umursamıyorum (yani FireFox 4 ve IE 9 bir şeyi destekleyecekse, bu yeterince iyi).


4
Bu sorunun cevabı canlı bir demo stackoverflow.com/questions/5495952/… ile var
Drew LeSueur

Yanıtlar:


122

DÜZENLE Aralık 16th, 2019

Path2D artık tüm büyük tarayıcılar tarafından desteklenmektedir

EDIT Kasım 5, 2014

Artık tüm tarayıcılarda olmasa da bazılarındactx.drawImage .svg kaynağı olan HTMLImageElements öğesini çizmek için kullanabilirsiniz . Chrome, IE11 ve Safari çalışır, Firefox bazı hatalarla çalışır (ancak her gece bunları düzeltir).

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";

Burada canlı örnek . Tuvalde yeşil bir kare görmelisiniz. Sayfadaki ikinci yeşil kare, <svg>referans için DOM'a eklenen aynı öğedir.

SVG (dize) yollarını çizmek için yeni Path2D nesnelerini de kullanabilirsiniz. Başka bir deyişle, yazabilirsiniz:

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

Bunun canlı bir örneği burada.


Eski gelecek cevabı:

SVG yollarını tuvalde yerel olarak kullanmanıza izin veren yerel hiçbir şey yoktur. Bunu sizin için yapmak için kendinizi dönüştürmeli veya bir kitaplık kullanmalısınız.

Canvg'ye bakmanızı öneririm:

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

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


4
Bu neden gerekli? SVG, sadece bir tuval üzerine mükemmel bir şekilde çiziyor gibi görünüyor drawImage. Ama yine de bu uyarıyı alıyorum. Nereden geliyor?
shoosh

1
Simon, söylediğin doğru değil. İkincisi, Chrome'da onaylanmış bir hata.
Mathias Lykkegaard Lorenzen

4
Wikimedia, SVG'yi kullanmanızı sevmiyor gibi görünüyor. Bulduğum ilk kullanılabilir SVG olarak snapsvg.io/assets/images/logo.svg'yi değiştirdim . FF'de çalıştı. jsfiddle.net/Na6X5/331
Thomas

1
Bunu yapmak için Veri URI'larını da kullanabilirsiniz : jsfiddle.net/020k543w
Döndürme

9
Not: Uzun süredir devam eden bir FireFox Bug nedeniyle, ne yazık ki, genişlik ve yükseklik etiketlerine sahip olmayan svg'ler tuvalde hiç görüntülenmez. Ayrıca genişlik ve yükseklik yüzde olarak olmamalıdır.
Hatoru Hansou

26

Üzgünüm, @Matyas cevabına yorum yapmak için yeterli itibarım yok, ancak svg'nin görüntüsü de base64'teyse, çıktıya çekilecek.

Demo:

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="" height="20px" width="20px" x="10" y="10"></image>
</svg>
<hr/><br/>

IMAGE
<img/>
<hr/><br/>
   
CANVAS
<canvas></canvas>
<hr/><br/>


1
Yazı tipleriyle aynı şey, SVG'ye gömülmeleri
Sphinxxx

1
içindeki imgetiketleri yineleyebilir svgve daha sonra resimleri tuval üzerine ayrı ayrı çizebilirsiniz.
luckydonald

24

Aşağıdakileri svgyaparak bir tuvale kolayca basit s çizebilirsiniz :

  1. Svg'nin kaynağını base64 formatındaki bir resme atama
  2. Görüntüyü bir tuval üzerine çizme

Not: Yöntemin tek dezavantajı svg,. (demoya bakın)

gösteri:

(Gömülü görüntünün yalnızca içinde görülebileceğini unutmayın 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/>


2
Bahsettiğiniz sorunu çözmenin herhangi bir yolu var mı? Svg'ye gömülü resim.
Vijay Baskaran

Maalesef gömülü görüntü sorununa bir çözüm bulamadım.
Matyas

Tamam. Teşekkürler Matyas :)
Vijay Baskaran


6

Simon'ın yukarıda dediği gibi, drawImage kullanmak işe yaramaz. Ancak canvg kitaplığını kullanarak ve:

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

Bu, Simon'ın yukarıda sağladığı bağlantıdan gelir, burada başka öneriler de vardır ve canvg.js ve rgbcolor.js'ye bağlanmak veya bunları indirmek istediğinizi belirtir. Bunlar, JavaScript işlevleri içinde, URL aracılığıyla veya svg etiketleri arasında satır içi SVG kodu kullanarak bir SVG'yi işlemenize ve yüklemenize olanak tanır.

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.