SVG and canvas are two completely different techniques for drawing graphical applications on HTML5, both have advantages and disadvantages, but they are not incompatible with each other, especially SVG content can be directly drawn on the canvas function, so that the two can be perfectly fused together, Let canvas enjoy the existing rich SVG footage without sacrificing the SVG vector stepless scaling feature.
"HTML5-based drag and drop generation picture Base64 information" Although the display is drag and drop ordinary raster image effect, but you can also directly drag and drop the SVG format image to display, but the normal picture format data for the Data:image/png type, In the SVG format, the data type is data:image/svg+xml and dragged into the SVG format picture for the HT for Web topology graph:
Here's a small example of how to load an SVG image and divide it into seven basic scale-drawing effects, and you can see that canvas drawing svg retains its vector-not-distorted properties
functionDraw () {varIMG =NewImage (); IMG.SRC= ' Chart.svg '; Document.body.appendChild (IMG); Img.onload=function(){ varCanvas = document.getElementById (' Canvas '); varg = Canvas.getcontext (' 2d '); varwidth = img.clientwidth * 1.5; varHeight = img.clientheight * 1.5; varx = 2; vary = 2; for(vari=0; i<7; i++{g.drawimage (img, x, y, width, height); X+ = width + 2; Width/= 2; Height/= 2; } };}
Referring to the fusion of canvas and SVG, we will use the HT for web vector function to show a mobile phone battery charging Progress instance, the entire cell phone battery static part of the implementation by loading a simple SVG footage, and the charge dynamic change part, we use a progressive color of the HT rectangle element to describe , the length of the rectangle is converted into length information according to the percentage of the charging progress by the dynamic binding function of the HT vector data, and finally the dynamic charging effect is achieved by the timer simulation data change:
Ht. Default.setimage (' Battery ', {width:64, Height:64, comps: [{type:' Rect ', rect: {func:function(data) {return[5, 50*DATA.A (' percent '), 16]}}, background:' Red ', gradient:' Spread.vertical '}, {type:' Image ', Name:' Battery.svg ', relative:true, rect: [0, 0, 1, 1] } ]}); varnode =Newht. Node (); Node.setposition (80, 150); Node.setimage (' Battery '); NODE.S (' Image.stretch ', ' uniform '); Node.a (' percent ', 0);d atamodel.add (node); Graphview.seteditable (true); SetInterval (function() {percent= Node.a (' percent ') + 0.02; if(Percent > 1) {percent= 0; } node.a (' percent ', percent);},16);
There is also a special application scenario for SVG drawing to canvas, which is to describe HTML elements in SVG through the Foreignobject feature of SVG, and then canvas to draw svg. You can draw the HTML content of the Foreignobject description to the Canvas, see Https://developer.mozilla.org/en-US/docs/Web/API/Canvas_API/Drawing_DOM The _objects_into_a_canvas instance, where the blob is used to set the IMG src as the URL is a more bizarre technical point, but from the above mentioned we can actually convert the entire SVG content into data:image/svg+xml; The base64 content can be passed as src URL, so I modified the example, using Btoa (data) to convert the SVG content into Base64 way to set IMG.SRC, this way easier to understand, example code and the effect is as follows:/HTTP V.youku.com/v_show/id_xodg0mtu4njey.html
function draw () { var canvas = document.getElementById (' canvas ' ); var ctx = Canvas.getcontext (' 2d ' ); var data = ...; var img = new Image (); Img.onload = function () {Ctx.drawimage ( IMG, 0, 0); }; Img.src = ' data:image/svg+xml;base64, ' +
Drawing SVG content to Canvas's HTML5 application