vue3项目中调用手机摄像头

vue3项目中调用手机摄像头,第1张

近期有个需求,通过vue的网页调用手机摄像头,拍摄完成后,传回照片给vue。

作为刚开始接触安卓的小白,看了非常多的案例,都是新建camera类,处理拍照、拍视频、查看照片等 *** 作。而我的需求非常简单,就是点击按钮,拍照,给网页返回照片而已,不需要如此复杂的 *** 作,于是尝试着用简单的方式完成调用摄像头的功能。

(1)vue端,增加一个a标签,设置跳转关键字camera,这个是安卓识别要调用摄像头的关键点。

vue网页调用手机摄像头,webview如何实现

(2)手机端,接受a标签的跳转,注:a标签调用一般会去调用WebViewClient的onPageFinished方法,但是此时的跳转属于非常规跳转,故采用`camera:`标识此次的跳转,然后就会调用WebViewClient的shouldOverrideUrlLoading方法拦截此次跳转,具体写法如下:

vue网页调用手机摄像头,webview如何实现vue网页调用手机摄像头,webview如何实现

vue网页调用手机摄像头,webview如何实现

基本上就是判断跳转连接中是否包含camera字段了,包含即调用监听事件,利用监听事件调用手机的摄像头,Intent it = new Intent(MediaStore.ACTION_IMAGE_CAPTURE)即可。不过问题在于WebViewClient的shouldOverrideUrlLoading方法返回对象是boolean类型,那么,我们需要返回的是图片路径或者图片本身,也可以是base64处理过的流,这个类型的返回值对我们没有太多意义,所以设置一个全局变量imageUri,在拍照之前给其赋值,在回调时就利用这个路径可以得到想要的所有格式的图片数据了。

(3)上图,最后一步,完成了就可以直接去vue端接收图片了。

vue网页调用手机摄像头,webview如何实现

一枚程序媛,安卓开发新手,做的东西可能比较low,欢迎批评指正。

女程序员共同的特点是喜欢解决问题,懂得去思考、去总结经验,并且她们对自己很有信心,工作的时候很有激情,这是大多优秀的程序员具备的特质。

女程序员喜欢解决难题,因为她们觉得一个问题一定能找得到答案。构建应用程序不是一个简单的过程。代码不编译的原因到底是什么,为什么为出现bug,在开发的过程中会出现很多问题吗,应该如何去解决,这些都是有技巧的。在压力的作用下解决问题更能提升自己的能力,不过这对心理素质是一种考验。如果系统崩溃了,你可以向管理人员寻求帮助,在你解决问题的时候,让你稍微歇息一下。

程序员对自己很有信心,她们相信自己一定能够解决问题。 建立一个系统的方法有很多种,不管你的想法有多完美,如果你不把想法变现,它们就不会有价值。最好的女程序员对她们的想法有信心,并在设计讨论中发言,以帮助构建应用程序架构。如果你想当一个优秀的女程序员,那你可以选择增强你的自信,从一个小建议开始,而不是提出整个应用程序重新设计。

女程序员非常喜欢自己的工作,如果她们不喜欢这份工作,就无法成为这个行业中的顶尖高手。女程序员的激情并不是只体现在编程一个方面 —— 在工作、所使用的技术、老板、项目等方面都有激情,这才是优秀的女程序员。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8100068.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-13
下一篇 2023-04-13

发表评论

登录后才能评论

评论列表(0条)

保存