Camera
camera对象提供对设备默认摄像头应用程序的访问。
方法:
camera.getPicture 
选择使用摄像头拍照,或从设备相册中获取一张照片。图片以base64编码的字符串或图片URI形式返回。
简单的范例:
复制
navigator.camera.getPicture( cameraSuccess, cameraError, [ cameraOptions ] );
说明:
camera.getPicture函数打开设备的默认摄像头应用程序,使用户可以拍照(如果 Camera.sourceType 设置为 Camera.PictureSourceType.CAMERA,这也是默认值)。一旦拍照结束,摄像头应用程序会关闭并恢复用户应用程序。
如果Camera.sourceType = Camera.PictureSourceType.PHOTOLIBRARY或Camera.PictureSourceType.SAVEDPHOTOALBUM,系统弹出照片选择对话框,用户可以从相集中选择照片。
返回值会按照用户通过cameraOptions参数所设定的下列格式之一发送给cameraSuccess回调函数:
你可以对编码的图片或URI做任何处理,例如:
备注:较新的设备上使用摄像头拍摄的照片的质量是相当不错的,使用Base64对这些照片进行编码已导致其中的一些设备出现内存问题(如IPHONE4、BlackBerry Torch 9800)。因此,强烈建议将“Camera.destinationType”设为FILE_URI。
支持的平台:
简单的范例:
拍照并获取Base64编码的图像:
复制
navigator.camera.getPicture(onSuccess, onFail, { quality: 50 });

function onSuccess(imageData) {
   var image = document.getElementById('myImage');
   image.src = "data:image/jpeg;base64," + imageData;
}

function onFail(message) {
   alert('Failed because: ' + message);
}
拍照并获取图像文件路径:
复制
navigator.camera.getPicture(onSuccess, onFail, { quality: 50,
				destinationType: Camera.DestinationType.FILE_URI });
				
function onSuccess(imageURI) {
	var image = document.getElementById('myImage');
	image.src = imageURI;
}
	
function onFail(message) {
	alert('Failed because: ' + message);
}
完整的范例:
复制

Capture Photo


提供图像数据的onSuccess回调函数。
复制
function(imageData) {
   // 对图像进行处理
}
参数:
范例:
复制
// 显示图片
function cameraCallback(imageData) {
	var image = document.getElementById('myImage');
	image.src = "data:image/jpeg;base64," + imageData;
}
提供错误信息的onError回调函数。
复制
function(message) {
   // 显示有用信息
}
参数:
定制摄像头设置的可选参数。
复制
{	quality : 75,
	destinationType : Camera.DestinationType.DATA_URL,
	sourceType : Camera.PictureSourceType.CAMERA,
	allowEdit : true,
	encodingType : Camera.EncodingType.JPEG,
	targetWidth : 100,
	targetHeight : 100};
选项:
Android的特异情况:
BlackBerry的特异情况:
Palm的特异情况:
iPhone的特异情况:
Windows Phone 7的特异情况: