3

嘿,我正在开发一个应用程序,可以使用 Phonegap 使用地理位置和时间戳标记图像。我已经能够通过将图像编辑为画布来标记图像。现在我需要将该编辑后的图像作为新图像保存到设备照片库/库中,或者替换选择要标记的图像。使用 phonegap 的目的是应用程序必须跨平台运行。有什么办法可以实现吗?

以下代码将图像编辑为画布并将图像转换回数据 URI。

var canvas = document.getElementById("canvasPnl");
        var context = canvas.getContext("2d");
        var imageObj = new Image();
        imageObj.onload = function(){

        context.drawImage(imageObj,0,0,300,300 );
        context.fillStyle="#FFFFFF";
        context.fillText('Latitude: '+ lat.toString()+' Longitude: '+ lon.toString(), 0, 10);
        context.fillText(new Date(), 0, 20);
        };
        imageObj.src=imageURI;
        dataURI= canvas.toDataURL();

这可以转换为图像对象并保存到手机图库吗???

4

3 回答 3

2

https://github.com/devgeeks/Canvas2ImagePlugin显然可以满足您的要求,尽管我没有尝试过。

于 2014-07-12T07:50:09.677 回答
1

我认为您不能仅使用 JavaScript 将图像保存在图库中,但您可以将用户发送到图像或显示图像,用户可以手动保存它。

于 2014-04-29T05:01:32.307 回答
0

也许你可以试试我为 IOS 编写的插件(如果你想将画布元素保存到相册,你可以使用下面的 downloadWithUrl 方法获取画布的 dataURI)。希望对你有效。

这是 git 链接:https ://github.com/Nomia/ImgDownloader

简短的例子:

document.addEventListener("deviceready",onDeviceReady);

//google logo url
url = 'https://www.google.com/images/srpr/logo11w.png';

onDeviceReady = function(){
    cordova.plugins.imgDownloader.downloadWithUrl(url,function(){
        alert("success");
    },function(){
        alert("error");
    });        
}

//also you can try dataUri like: 1px gif
//url = 'data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7'

您也可以使用下载方法将本地文件保存到图库

于 2014-09-07T07:57:36.597 回答