3

I have a web page with file input field.I wanted to ,

  1. Upload a image file.
  2. create image element using uploaded image.
  3. draw it on canvas
  4. get "DataURL" of canvas.

This process works on Google Chrome,but not working on Mozilla Firefox.When i console.log the canvas.toDataURL output it shows



This is not the correct output.How can i generate cross browser DataURL from the canvas.

Here is my code.

$scope.importImageForBackground = function (event)
                {
                    $scope.file = event.target.files[0];
                    var img = document.createElement("img");

                    var reader = new FileReader();

                    reader.onloadend = function (e) {
                        $scope.$apply(function () {

                            img.src = e.target.result;

                            var canvas = document.createElement("canvas");
                            var ctx = canvas.getContext("2d");
                            canvas.width = 1050;
                            canvas.height = 600;
                            ctx.drawImage(img, 0, 0, 1050, 600);

                            $scope.data = canvas.toDataURL("image/png");

                            console.log($scope.data);
                        });
                    };

                    reader.readAsDataURL($scope.file);
                };
Randika
  • 683
  • 3
  • 11
  • 32
  • 3
    wait for the image has loaded (`img.onload = function(){ var canvas = ...}; img.src = e.target.result;`) – Kaiido Sep 01 '15 at 08:31
  • @Kalido Thank you so much,It Worked.Can you post it as a answer.Then i can mark this as solved. – Randika Sep 01 '15 at 09:09
  • There is already a bunch of those questions, and it's not likely to help anyone else in future, I think it would be better to simply delete it – Kaiido Sep 01 '15 at 09:19
  • @Kaiido: But I think someone might stumble here. I copy-n-past'ed your comment below (http://stackoverflow.com/a/32328726/2932998). – Randika Sep 01 '15 at 10:00
  • Well I'm sorry but did you felt on [this](http://stackoverflow.com/questions/32303406/empty-images-when-resizing-images-using-canvas#comment52493578_32303406) when looking for your problem ? Note : it was yesterday and if it's not everyday, then at least fifth a week, we've got such questions. It's not your fault as an asker, but just that the symptoms will be very different for each asker. But the solution is always the same easy found one. So our system of duplicate kinda fails here and I voted to close your question as typographical/not reproducible/ **won't help any further reader**. – Kaiido Sep 01 '15 at 12:57

2 Answers2

6

Wait for the image to load.

img.onload = function(){
    var canvas = ...
};
img.src = e.target.result;

Please note that this is a copy-n-paste of @kaiido's comment, as he refused to repost it as an answer. Credit goes to him.

Randika
  • 683
  • 3
  • 11
  • 32
0

I faced the same issue, You can fix this using Javascript shown as below

        var canvas=document.getElementById(canvasId);
        var href=canvas.toDataURL("image/png");
        var windowtab=window.open('about:blank','image from canvas');
        windowtab.document.write("<img src='"+href+"' alt='from canvas'/>");
Shivakrishna
  • 1,333
  • 1
  • 12
  • 18