0
回答
使用 android 的摄像头拍照
利用AWS快速构建适用于生产的无服务器应用程序,免费试用12个月>>>   

android提供了操作摄像头的API,可以通过两种做法来使用:

  1. 通过Intent直接调用系统提供的照相机功能,复用它的拍照Activity,这是最简单和最方便的办法,因为你不需要考虑手机的兼容性问题,比如预览拍照图片大小等;
  2. 直接调用摄像头的API,自己编写类似取景框的Activity,这样灵活度更大,缺点是你需要考虑比较底层的东西。要知道android有多个版本,摄像头的分辨率也不一样,需要先获取当前相机的分辨率组合,然后再编写各种屏幕分辨率组合的布局,总之很灵活很麻烦。

在这里,写了个简单的示例,代码见:

http://easymorse.googlecode.com/svn/tags/cam.demo-0.1/

这是上面做法2的思路,只是没有调用拍照,这是取景框的样子。

image

用做法1的方式,拍照变的很简单,很快就可以做出一个粗糙的照相机功能,并可以在它之上实现自己的功能。

代码见:

http://easymorse.googlecode.com/svn/tags/cam.demo-0.2/

程序上来的界面:

image

点击拍照后,调用了系统的拍照Activity:

image

拍照完成后,可以重新拍照,或者确定,将返回到程序的Activity。

image

返回后的样子,可以看到拍照的图片替代了原来占位的图片。

image

这时可以做的事情就很多了,可以把图片发送到服务器端,比如图片博客等等应用。

这个示例反映了android强大的reuse能力,从编程模型上提供的能力。

默认情况下,如果在intent中不做设置,也就是不写这部分:

intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri
        .fromFile(new File(Environment
                .getExternalStorageDirectory(), "camera.jpg")));

那么当从照相机Activity返回的时候,会带一个名为data的Bitmap对象。是照片的缩略图。

如果写上面的代码,则不会返回名为data的对象。但是会按照指定的路径保存原始图片。

原文转自:http://marshal.easymorse.com/archives/2769

举报
华宰
发帖于6年前 0回/4K+阅
顶部