Important: The RGraph website has recently experienced some downtime. It's now back up and available once more but keep this in mind as you may experience errors or oddities when browsing the site.

An example of the toDataURL function

Introduction

[No canvas support]

One way you can transfer your canvas around is by using the toDataUrl function. This function takes a snapshot of the appearance of the canvas and returns it as a base64 encoded data: URL. You can then transfer it around as you would any other text - though you may want to avoid sending it as a GET parameter (ie in the URL) as the base64 encoded string can be quite long and it may exceed the allowed length for URLs. can be long For example:

var canvas = document.getElementById('cvs');
var context = canvas.getContext('2d');
context.font = '26pt Arial';
context.fillText('Some example text!', 10, 40);

url = canvas.toDataURL();

document.getElementById("out").value = url;

The output

Here is an example of the output of the function. Here it's shown in a textarea - though you can just as easily use it in a link as the URL.

This is an example of the resulting URL. As you can see it is quite large - and this is just a simple canvas URL.

And here is the resulting image:

Here is an example of fetching the URL with JavaScript:

window.open(document.getElementById('cvs').toDataURL(), 'new_window', 'width=310,height=30')

Or you could get the URL and then use it as the src of an image tag:

<img src=" ... ">

Notes about usage