我有这个片段从相机中捕获照片并以base64字符串输出。
function onPhotoDataSuccess(imageData) {
console.log("Image Data: "+imageData);
var smallImage = document.getElementById('smallImage');
smallImage.style.display = 'block';
smallImage.src = "data:image/jpeg;base64," + imageData;
console.log("Src:" + smallImage.src);
}
当我查看控制台日志时,第一个日志Image Data
未完成,但第二个Src
日志更长。
以下是Image Data
的日志:
09-18 17:00:24.591: D/CordovaLog(12097):
file:///android_asset/www/upload.html: Line 57 :
Image Data: /9j/4AAQSkZJRgABAQAAAQABAAD/2wBDABALDA4MChAODQ4SERATGCgaGBYWGDEjJR0oOjM9PDkz
对于Src
我得到的(你也可以解码它,没什么有趣的):
09-18 17:00:24.630: D/CordovaLog(12097):
file:///android_asset/www/upload.html: Line 71 :
Src:
您可以在两个日志中使用相同的变量imageData
看到,我无法得到相同的结果。
并且,如果您在Src
中解码base64字符串,则图像不完整。
任何人都知道如何解决这个问题?
编辑:jsfiddle显示base64的解码
HTML正文中的 编辑:<img>
标记:
<img style="display:none;width:300px" id="smallImage" src="" />
答案 0 :(得分:0)
我建议您将目的地类型用作FILE_URI
并从下面描述的方法中获取base64
将目标类型设置为FILe-URI是您可以在其文档中看到的推荐方法
http://docs.phonegap.com/en/2.5.0/cordova_camera_camera.md.html
将目标类型指定为FILE_URI
本身,在imagedata中,您将获取图像文件,将其放置在图像标记中,然后将其放在HTML5画布中,画布有一个名为toDataURL的方法,您可以在其中获取相应图像的base64。
检查以下代码
function onPhotoDataSuccess(imageData)
{
var $img = $('<img/>');
$img.attr('src', imageData);
$img.css({position: 'absolute', left: '0px', top: '-999999em', maxWidth: 'none', width: 'auto', height: 'auto'});
$img.bind('load', function()
{
var canvas = document.createElement("canvas");
canvas.width = $img.width();
canvas.height = $img.height();
var ctx = canvas.getContext('2d');
ctx.drawImage($img[0], 0, 0);
var dataUri = canvas.toDataURL('image/png');
});
$img.bind('error', function()
{
console.log('Couldnt convert photo to data URI');
});
}