将相机预览与图像合并?

Posted

技术标签:

【中文标题】将相机预览与图像合并?【英文标题】:Merge Camera preview with a image? 【发布时间】:2012-05-06 03:35:55 【问题描述】:

我正在尝试从相机预览和其上方的ImageView 制作合成图像。我有一张透明 png 的图片,它设置在这样的 imageview 上

ImageView iv = new ImageView(this);
iv.setImageResource(R.drawable.one);

然后我将它添加到已经显示我的相机预览(继承 SurfaceView)的框架布局中,如下所示:

preview = (FrameLayout) findViewById(R.id.camera_preview);
preview.addView(cp); //cp is a reference to a camera preview object
preview.addView(iv);

我的imageview的图片是这样的:

屏幕是这样的(我不得不从另一台相机拍摄照片,因为 DDMS 屏幕截图没有显示预览,只显示图像和黑屏,但不知道这是否相关):

现在我的任务是用 imageview 拍摄那张照片。想出了两个办法,都不知道能不能实现

    单独保存图片,跟踪图片上的封面,然后以某种方式合并。这可以做到吗?如何做到? 获得两个视图所在的框架布局的外观并保存为图像 截取特定区域的屏幕截图,我会在万不得已的情况下进行此操作,即如果可以这样做

我想知道的是这些方法中哪一种是可能的,如何实现?还是有更好的方法来完成这项工作?

【问题讨论】:

您可以添加一个带有相机预览的视图,例如在单个活动上合并两个视图 【参考方案1】:

假设您已经有来自 jpeg 回调的byte[] data 形式的图像。

    将图像解码为可变位图:

    Bitmap photo = BitmapFactory.decodeByteArray(data, 0, data.length);
    photo = photo.copy(photo.getConfig(), true);
    

    阅读叠加层:

    Bitmap overlay = BitmapFactory.decodeResource(getResources(), R.drawable.one);
    

    在照片上绘制叠加层:

    Canvas canvas = new Canvas(photo);
    canvas.drawBitmap(overlay, new Matrix(), null);
    

现在,photo 应该包含您的图片。

【讨论】:

我正在以 2.1 作为目标进行构建,因为 BitmapFactory.Options.inMutable 在该 API 级别不可用,因此在那里获取可变位图的方法是什么。 没错,它是在 Honeycomb 中添加的。我更新了我的答案 是的,应该是。见docs photo.copy() 方法占用了大量内存,OutOfMemoryException 被抛出。然后我使用createScaledBitmap 方法并将高度和重量设置为叠加层。但我先保存了原始照片。

以上是关于将相机预览与图像合并?的主要内容,如果未能解决你的问题,请参考以下文章

相机预览处于纵向模式,但拍摄的图像已旋转

Android 相机预览在预览中拉伸,而不是在拍照后

用于相机预览的Android单元测试?

AVFoundation 图像方向在预览中偏离了 90 度,但在相机胶卷中很好

设置缩小的相机预览以相对于宽度具有正确的图像纵横比

检测实时android相机预览的颜色代码