"canvas.toDataURL("image/png")"在Firefox中无法正常工作 [英] "canvas.toDataURL("image/png")" not working properly in firefox

查看:90
本文介绍了"canvas.toDataURL("image/png")"在Firefox中无法正常工作的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个带有文件输入字段的网页.我想,

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

  1. 上传图像文件.
  2. 使用上传的图片创建图片元素.
  3. 在画布上绘制
  4. 获取画布的"DataURL".

此过程适用于Google Chrome,但不适用于Mozilla Firefox.当我进行console.log时,canvas.toDataURL输出显示

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



这不是正确的输出.如何从画布生成跨浏览器DataURL.

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

这是我的代码.

$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);
                };

推荐答案

等待图像加载.

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

请注意,这是@kaiido的评论的n复制粘贴,因为他拒绝重新发布它作为答复.归功于他.

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.

这篇关于"canvas.toDataURL("image/png")"在Firefox中无法正常工作的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆