200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > 微信小程序摄像头监控_微信小程序摄像头调用怎么操作?

微信小程序摄像头监控_微信小程序摄像头调用怎么操作?

时间:2024-05-22 17:50:30

相关推荐

微信小程序摄像头监控_微信小程序摄像头调用怎么操作?

为了满足更多人对小程序的期待,小程序也可以调用摄像头了,实现方法就是在微信里面通过js调起原生摄像头,这样还可以上传和下载图片。微信小程序摄像头调用怎么操作?一起来看看具体的流程。

1.微信小程序摄像头调用具体配置

页面引入通过jssdk授权后,传入wx对象,首先配置需要的接口

wx.config({ /* debug: true, */ appId: appid, timestamp: timestamp,nonceStr: nonceStr, signature: signature, jsApiList: ['chooseImage',//拍照或从手机相册中选图接口 'previewImage',//预览图片接口 'uploadImage',//上传图片接口'downloadImage'//下载图片接口 ] });

2.怎样进行微信小程序摄像头调用

将下面的方法放在需要点击事件的微信小程序回调函数里面

wx.chooseImage({ count: 1, //张数, 默认9 sizeType: ['compressed'], //建议压缩图sourceType: ['album', 'camera'], // 来源是相册、相机 success: function (res) {//varlocalIds = res.localIds; // 返回选定照片的本地ID列表,localId可以作为img标签的src属性显示图片 $('.driver-card img').prop('src',res.localIds[0]); uploadPhoto.uploadToWeixinServer(res.localIds[0],'car') }});

这时我们可以看到这样的效果,代表调起成功了!chooseImage方法的成功回调里,我将选中的照片赋值给需要显示的img的src(因为我这里只有一张照片,如果有多张用小程序循环调用赋值即可),这样一来,就可以直接显示刚刚拍照/相册里选中的照片了

3.上传照片

在上面chooseImage的success回调里面,可以看到我调用了uploadToWeixinServer方法,参数为本地照片的Id

uploadToWeixinServer: function(localId,type){ wx.uploadImage({ localId:localId, isShowProgressTips: 1, // 默认为1,显示进度提示 success: function (res){ //res.serverId 返回图片的微信服务器端IDuploadPhoto.uploadToOwnerServer(res.serverId,type);//异步上传到我们自己的服务器 } }); },

调用uploadImage接口后,将图片上传到了微信服务器,返回图片的小程序ID,这个时候需要用ajax异步上传到自己的服务器里,调用微信提供的“获取临时素材”接口。当然也不一定是选择完照片就立即上传,还得根据实际业务需求出发,也有是静默上传(没有进度提示),也有是在最终提交表单时一起上传

js:

uploadToOwnerServer: function(serverId,type){ $.ajax({ data:{serverId:serverId,type:type}, type : "POST", url : WX_ROOT +"wechat/uploadPhoto", success : function(json) { if (json) { var data =JSON.parse(json.data); if ('car' == type) uploadPhoto.options.carImage =data.path + data.name else uploadPhoto.options.idCardImage = data.path +data.name

} } }); },

Controller

@RequestMapping(value = "/uploadPhoto", method = RequestMethod.POST) public@ResponseBody HttpResult uploadPhoto(@RequestParam String serverId,@RequestParamString type) throws Exception{ LOGGER.info("RestFul of uploadPhoto parametersserverId:{},type:{}",serverId,type);

try { /** 将图片保存到本地服务器 **/ String photoName = type + new Date().getTime() +UUID.randomUUID().toString();

//文件路径不存在则创建 File saveFile = new File(PIC_PATH + type); if(!saveFile.mkdir()) saveFile.mkdir();

wechatService.saveImageToDisk(serverId, photoName, PIC_PATH + type + "/");LOGGER.info("Download the picture from weixin server pathL:{}",PIC_PATH + type +"/"); JSONObject data = new JSONObject(); data.put("name", type + "/" +photoName+".jpg"); data.put("path", PIC_SERVER + "/");

HttpResult rs = new HttpResult(); rs.setCode(200);rs.setData(data.toJSONString()); LOGGER.info("Download the picture from weixinserver is successful!serverId:{},photoName:{}",serverId,photoName);LOGGER.info("HttpResult data:{}",rs.getData()); return rs; } catch (Exception e){ LOGGER.error("Download the picture from weixin server is error",serverId);return null; }

这里我使用了一个UUID生成主键规则,通过类型+时间戳+唯一字符串定义图片名称。如果上传成功,同时又将自己服务器的图片地址返回给前端。

getInputStream

调用微信提供的获取临时素材接口下载还在微信服务器上的图片,参数为前端提交上来的媒体文件ID,最终将文件转化为输入流对象

/** * 根据文件id下载文件 * @param accessToken * @param mediaId * @return 文件流对象 */public InputStream getInputStream(String accessToken, String mediaId) {InputStream is = null; String url ="http://file.api./cgi-bin/media/get?access_token="+ accessToken +"&media_id=" + mediaId; try { URL urlGet = new URL(url); HttpURLConnectionhttp = (HttpURLConnection) urlGet.openConnection();http.setRequestMethod("GET"); // 必须是get方式请求http.setRequestProperty("Content-Type","application/x-www-form-urlencoded");http.setDoOutput(true); http.setDoInput(true);System.setProperty(".client.defaultConnectTimeout", "30000");// 连接超时30秒System.setProperty(".client.defaultReadTimeout", "30000"); // 读取超时30秒http.connect(); // 获取文件转化为byte流 is = http.getInputStream(); } catch (Exceptione) { LOGGER.error("Failed to convert inputStream from weixinserver,accessToken:{},mediaId:{}",accessToken,mediaId); } return is;

}

service

通过循环解析流对象,将文件写入自己的服务器

public void saveImageToDisk(String mediaId, String picName, String picPath)throws Exception { String accessToken = getBaseAccessToken(); InputStreaminputStream = getInputStream(accessToken, mediaId);

// 循环取出流中的数据 byte[] data = new byte[1024]; int len = 0; FileOutputStreamfileOutputStream = null; try { fileOutputStream = newFileOutputStream(picPath+picName+".jpg"); while ((len = inputStream.read(data))!= -1) { fileOutputStream.write(data, 0, len); } LOGGER.info("Write thefileInputStream is successful"); } catch (IOException e) { LOGGER.error("Writethe fileInputStream is error"); } finally { if (inputStream != null) { try {inputStream.close(); } catch (IOException e) { LOGGER.error("Close thefileInputStream is error"); } } if (fileOutputStream != null) { try {fileOutputStream.close(); } catch (IOException e) { LOGGER.error("Close thefileOutputStream is error"); } } } }

那么到这里,微信小程序摄像头调用、简单的拍照、上传下载图片的功能都已经开发完成了,参照货源代理网小程序频道提供的以上代码就好了,希望大家都能开发成功,微信小程序后续还会有什么新功能的开发,大家可以拭目以待了。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。