我有一个创建的Phonegap项目,它按照教程http://mobile.tutsplus.com/tutorials/phonegap/phonegap-from-scratch-camera-exporting/.Now使用Camera捕获图片我想将图像保存为blob到sqlite数据库中。一旦保存检索并显示图像。请建议。
答案 0 :(得分:3)
请按照以下步骤
1。使用手机间隙相机API将您的照片作为基础64
2. 现在将Base 64转换为Blob对象
function convertDataURIToBlob(dataURI, mimetype) {
var BASE64_MARKER= ';base64,';
var base64Index = dataURI.indexOf(BASE64_MARKER) + BASE64_MARKER.length;
var base64 = dataURI.substring(base64Index);
var raw = window.atob(base64);
var rawLength = raw.length;
var uInt8Array = new Uint8Array(rawLength);
for (var i = 0; i < rawLength; ++i) {
uInt8Array[i] = raw.charCodeAt(i);
}
var bb = new BlobBuilder();
bb.append(uInt8Array.buffer);
return bb.getBlob(mimetype);
}
然而,不应该传入mimetype,而应该从中提取它
数据网址与getBlob()一起使用。
或
使用此plugin
3. 现在您可以使用phonegap Storage API将图像保存到Sqlite,您希望的列数据类型为字符串。
4. 使用Phone gap Storage API从Sqlite中获取blob对象
5. 现在使用Java脚本将此对象表示为HTMl标记。这里
将blob对象示例为HTML 5
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Blob</title>
<script type="text/javascript">
(function () {
window.URL = window.URL || window.webkitURL;
function contentLoaded() {
var blob = new Blob(['alert("hello")'], { type: 'text/javascript' });
var script = document.createElement('script');
script.setAttribute('src', window.URL.createObjectURL(blob));
document.body.appendChild(script);
}
window.addEventListener('DOMContentLoaded', contentLoaded, false);
} ());
</script>
</head>
<body>
<div id="container">
</div>
</body>
</html>