Android应用开发之使用PhoneGap实现拍照上传功能

看这里:Android应用开发之使用PhoneGap实现拍照上传功能

在之前的使用Intellij Idea 搭建PhoneGap Android开发环境以及Android应用开发之使用PhoneGap实现位置上报功能两篇文章中,我们学习了phonegap Android环境的搭建以及phonegap获取位置信息自动上报等,本篇在之前的基础上,我们继续进行PhoneGap Android应用的开发,通过PhoneGap调用摄像头实现拍照自动上传的功能。

整体的学习思路大概是这样:index.html中提供三个按钮,分别是【拍照】、【本地图片】、【拍照上传】,主要是以下三个步骤:

  1. 点击【拍照】按钮,调用摄像头拍照,成功后在按钮右侧显示相应的图片;
  2. 点击【本地图片】按钮,调用本地图片库,选择图片后在按钮右侧显示选择的图片;
  3. 点击【拍照上传】按钮,调用摄像头拍照,成功后首先上传图片到服务器端后,上传成功后提醒,并在按钮右侧显示上传的图片。

初始的html文件,大致是这样,简单的进行了布局和javascript代码的编写,如下:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no"/>
    <script type="text/javascript" charset="utf-8" src="../js/cordova.js"></script>
    <script type="text/javascript" charset="utf-8" src="../js/jquery-1.7.1.min.js"></script>
    <title>Hello PhoneGap</title>
    <script type="text/javascript">
        function loadImage() {
            //拍照并显示在屏幕
        }
        function loadImageLocal() {
            //获取本地图片并显示在屏幕
        };
        function loadImageUpload() {
            //拍照上传并显示在屏幕
        };
    </script>
</head>
<body>
<h1>Hello PhoneGap</h1>
<p>
    <input type="button" value="拍照" onclick="loadImage();"/>
    <img src="" id="getImage" style="display: none;width: 120px;height: 120px;"/>
</p>
<p>
    <input type="button" value="本地图片" onclick="loadImageLocal();"/>
    <img src="" id="getImageLocal" style="display: none;width: 120px;height: 120px;"/>
</p>
<p>
    <input type="button" value="拍照上传" onclick="loadImageUpload();"/>
    <img src="" id="getImageUpload" style="display: none;width: 120px;height: 120px;"/>
</p>
</body>
</html>

首先,我们来实现【拍照】的功能,调用摄像头拍照,并显示,phonegap提供了一些camera的API,通过调用navigator.camera.getPicture(cameraSuccess,cameraError,[cameraOptions])方法,我们可以简单的实现拍照功能,三个参数分别对应拍照成功、拍照失败和拍照参数选项,我们定义onLoadImageSuccess,onLoadImageFail作为拍照成功或失败的回调函数,cameraOptions 我们定义了最主要的destinationType来区分图片来自于拍照还是图片库,这里定义为{destinationType: Camera.DestinationType.DATA_URL},其他的参数定义请参见API或查阅源码,完整的js如下:

function loadImage() {
    //拍照并显示在屏幕
    navigator.camera.getPicture(onLoadImageSuccess, onLoadImageFail, {destinationType: Camera.DestinationType.DATA_URL});
}
//拍照成功后回调
function onLoadImageSuccess(imageURI) {
    //这里的图片经过了base64编码
    var src = "data:image/jpeg;base64," + imageURI;
    $("#getImage").attr("src", src);
    $("#getImage").show();
}
//所有获取图片失败都回调此函数
function onLoadImageFail(message) {
    navigator.notification.alert("拍照失败,原因:" + message, null, "警告");
}

接下来运行module,在手机上点击【拍照】按钮,我们就可以调用摄像头拍照,并在屏幕上显示拍的照片,第一步的工作已经完成,接下来实现从本地图片库获取图片,与第一步主要是 cameraOptions 的 不同,需要额外的添加sourceType图片资源类型为sourceType: Camera.PictureSourceType.PHOTOLIBRARY,即来自本地图片库,另外,我们修改下destinationType: Camera.DestinationType.FILE_URI,返回完整的图片路径,同时定义相应的 onLoadImageLocalSuccess,失败的回调还是onLoadImageFail,相应的js代码如下:

function loadImageLocal() {
    //获取本地图片并显示在屏幕
    navigator.camera.getPicture(onLoadImageLocalSuccess, onLoadImageFail, {
        destinationType: Camera.DestinationType.FILE_URI,
        sourceType: Camera.PictureSourceType.PHOTOLIBRARY
    });
}
//本地图片选择成功后回调此函数
function onLoadImageLocalSuccess(imageURI) {
    $("#getImageLocal").attr("src", imageURI);
    $("#getImageLocal").show();
}

这样,第二步的功能也已经实现,比较简单,接下来,最重要的一点,我们实现第三步的【拍照上传】功能,与第一步的功能较为类似,主要是在图片拍照成功后,对图片进行上传处理,这里同样指定destinationType: Camera.DestinationType.FILE_URI,相应的js代码如下:

function loadImageUpload() {
    //拍照上传并显示在屏幕
    navigator.camera.getPicture(onLoadImageUploadSuccess, onLoadImageFail, {
        destinationType: Camera.DestinationType.DATA_URL
    });
}
//图片拍照成功后回调此函数
function onLoadImageUploadSuccess(imageURI) {
    //此处执行文件上传的操作,上传成功后执行下面代码
    $("#getImageLocalUpload").attr("src", imageURI);
    $("#getImageLocalUpload").show();
    navigator.notification.alert("文件上传成功!", null, "提醒");
}

本功能的关键是执行上传部分的代码,phonegap提供了FileUploadOptions和FileTransfer,通过FileTransfer.upload方法,同时传递options选项,进行上传的操作,也可以定义相应的成功或回调函数,完整的onLoadImageUploadSuccess代码如下:

//图片拍照成功后回调此函数
function onLoadImageUploadSuccess(imageURI) {
    //此处执行文件上传的操作,上传成功后执行下面代码
    var options = new FileUploadOptions(); //文件参数选项
    options.fileKey = "file";//向服务端传递的file参数的parameter name
    options.fileName = imageURI.substr(imageURI.lastIndexOf(‘/‘) + 1);//文件名
    options.mimeType = "image/jpeg";//文件格式,默认为image/jpeg
    var ft = new FileTransfer();//文件上传类
    ft.onprogress = function (progressEvt) {//显示上传进度条
        if (progressEvt.lengthComputable) {
            navigator.notification.progressValue(Math.round(( progressEvt.loaded / progressEvt.total ) * 100));
        }
    }
    navigator.notification.progressStart("提醒", "当前上传进度");
    ft.upload(imageURI, encodeURI(‘http://192.168.0.32:8888/app/upload.jfinal‘), function () {
        navigator.notification.progressStop();//停止进度条
        $("#getImageLocalUpload").attr("src", imageURI);
        $("#getImageLocalUpload").show();
        navigator.notification.alert("文件上传成功!", null, "提醒");
    }, null, options);
}

至此,使用phonegap实现拍照上传功能已经完成,基本能够简单的通过phonegap进行Android应用的开发,下面是完成后的效果图:

完整代码地址:http://git.oschina.net/realfighter/Hello-PhoneGap/blob/master/assets/www/html/camera.html

时间: 2024-08-28 10:40:55

Android应用开发之使用PhoneGap实现拍照上传功能的相关文章

用c++开发基于tcp协议的文件上传功能

用c++开发基于tcp协议的文件上传功能 2005我正在一家游戏公司做程序员,当时一直在看<Windows网络编程> 这本书,把里面提到的每种IO模型都试了一次,强烈推荐学习网络编程的同学阅读,比 APUE 讲的更深入 这是某个银行广告项目(p2p传输视频)的一部分 IO模型采用的阻塞模式,文件一打开就直接上传 用vc 2003编译,生成win32 dll 麻雀虽小五脏俱全,CSimpleSocket,CReadStream dll 输出一虚类 extern "C" __d

html5调用手机摄像头,实现拍照上传功能

今天做手机网站,想实现手机扫描二维码功能.首先实现在浏览器中调用手机摄像头,实现拍照功能并且把拍下的照片显示在页面并上传到服务器上,然后再在服务器端进行分析. 首先实现在浏览器中调用摄像头,当然用现在火的不行的html5,html5中的<video>标签,并将从摄像头获得视频作为这个标签的输入来源.实现拍照功能的html5代码: <article> <style scoped> video { transform: scaleX(-1); } p { text-alig

(转)Android学习-使用Async-Http实现图片压缩并上传功能

(转)Android学习-使用Async-Http实现图片压缩并上传功能 文章转载自:作者:RyaneLee链接:http://www.jianshu.com/p/940fc7ba39e1 让我头疼一个星期的图片批量上传服务器的问题最后受这篇文章的作者启发而解决,自己之前一直执着于通过uri地址找到图片然后上传图片,却没想过直接上传图片本身.感谢作者的博客和启发. 前言 (转载请注明出处,谢谢!) 最近在做一个小项目,项目中要实现上传图片到服务器,而这个例子是实现图片的尺寸压缩,将获取到的压缩图

WebX.5 拍照上传功能

//拍照 navigator.camera.getPicture(onSuccess, onFail, { quality: 50 ,destinationType:0,sourceType:1});//拍照获取base64的图片 function onSuccess(imageData) { data.newData({//拍照完成新增到存储图片的data中 "defaultValues" : [ { fZID : fZID,//主表ID imgurl : "data:im

Android应用开发之使用PhoneGap实现位置上报功能

看这里:Android应用开发之使用PhoneGap实现位置上报功能 上一篇,使用Intellij Idea 搭建PhoneGap Android开发环境中,简单的介绍了PhoneGap Android开发环境的搭建,并且开发了Hello World的应用,本篇,我们继续学习使用PhoneGap进行开发,获取用户设备的位置信息,通过获取经纬度实现位置上报的功能,接下来,开始本篇的学习. 我们在上篇module的基础上进行开发,主要是修改index.html中的内容,为了操作DOM方便,我们引入j

vuejs开发组件分享之H5图片上传、压缩及拍照旋转的问题处理

一.前言 三年.net开发转前端已经四个月了,前端主要用webpack+vue,由于后端转过来的,前端不够系统,希望分享下开发心得与园友一起学习. 图片的上传之前都是用的插件(ajaxupload),或者传统上传图片的方式,各有利弊:插件的问题是依赖jq并且会使系统比较臃肿,还有传统的web开发模式 前后端偶尔在一起及对用户体验要求低,现在公司采用webpack+vue+restfullApi开发模式 前后端完全分离,遵从高内聚,低偶尔的原则,开发人员各司其职,一则提升开发效率(从长期来看,短期

【Android源码解析】--选择多张图片上传多图预览

最近做了选择多图并且上传服务器,在网上找了一些demo,适当的做了一下调整,用过了不能忘记,记下来以后还能多看看,本人觉得自己的博客有些渣渣,还希望大家不要介意啊,哪里有错误希望大家及时指正. 好了下面具体的分析一下:(想要做出功能,需求分析是必不可少的,需求.逻辑弄懂了再上手写代码,思路会很清晰的) 1.多图上传首先得选择图片(这里项目需求是既可以拍照上传也可以从相册中选择) 2.拍照上传很简单了网上也有很多例子,调用照相机,返回uri,获取图片 3.从相册中选择图片 3.1 获取手机中的所有

【神操作】拍照上传就可以打卡!

相信不少人饱受指纹识别.人脸打卡的虐待!堵在最后一公里.迟到一分钟?堵在最后一公里,没法打卡?甚至是等不到或挤不上电梯结果导致打卡迟到?人脸识别半天识别不出,欲哭无泪?指纹打卡关键时刻掉链子,又算迟到? 这些打卡之痛,想必每个上班族总是要经历那么几回.还好现在的手机考勤设计非常人性化,可以设定签到范围,精确到公司附近300米-1000米,只要步入公司附近,就可以顺手签个到.这对于很多需要打卡的上班族确实方便了很多,但这一波刚平,一波又起.手机签到.GPS定位打卡是很方便,但这都要在网络给力的前提

微信公众平台前端人员对接(微信拍照上传)

前言: 1.本篇主要介绍前端如何对接微信公众平台 2.示例选取微信拍照上传 3.微信JS-SDK说明文档 4.企业号开发者中心 5.请一定要确认自己的帐号类型是否拥有使用微信某项功能的权限,要不然方法回调不起作用 6.企业号对接功能检测图如下: 步骤: 1.确认设置安全域名(设置后,可在该域名下进行测试) 2.获取到AppID和AppSecret 3.通过AppID和AppSecret得到access_token a.请求方式get b.请求链接https://api.weixin.qq.com