这篇文章主要为大家详细介绍了Android自定义相机、预览区域裁剪,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了Android自定义相机,预览区域裁剪的具体代码,供大家参考,具体内容如下
写法一:

预览区域裁剪,方法调用:
//按照比例进行裁剪头像区域
Bitmap resultBitmap = getScaleImage(resultBitmap,
(int) cuttingAreaView.getX(),
(int) cuttingAreaView.getY(),
cuttingAreaView.getWidth(),
cuttingAreaView.getHeight(),
mSurfaceView.getWidth(),
mSurfaceView.getHeight());/**
* 按照比例裁剪图片
*
* @param source
* @param cuttingAreaX 预览view的X坐标
* @param cuttingAreaY
* @param cuttingAreaWidth
* @param cuttingAreaHeight
* @param displayWidth
* @param displayHeight
* @return
*/
private Bitmap getScaleImage(Bitmap source, int cuttingAreaX, int cuttingAreaY, int cuttingAreaWidth, int cuttingAreaHeight, int displayWidth, int displayHeight) {
int sourceWidth = source.getWidth();
int sourceHeight = source.getHeight();
LegoLog.d("sourceWidth:" + sourceWidth + ",sourceHeight:" + sourceHeight + ",cuttingAreaX:" + cuttingAreaX + ",cuttingAreaY:" + cuttingAreaY + ",cuttingAreaWidth:" + cuttingAreaWidth + ",cuttingAreaHeight:" + cuttingAreaHeight + ",displayWidth:" + displayWidth + ",displayHeight:" + displayHeight);
int sourceCuttingAreaX = cuttingAreaX * sourceWidth / displayWidth;
int sourceCuttingAreaY = cuttingAreaY * sourceHeight / displayHeight;
int sourceCuttingAreaWidth = cuttingAreaWidth * sourceWidth / displayWidth;
int sourceCuttingAreaHeight = cuttingAreaHeight * sourceHeight / displayHeight;
LegoLog.d("sourceWidth:" + sourceWidth + ",sourceHeight:" + sourceHeight + ",sourceCuttingAreaX:" + sourceCuttingAreaX + ",sourceCuttingAreaY:" + sourceCuttingAreaY + ",sourceCuttingAreaWidth:" + sourceCuttingAreaWidth + ",sourceCuttingAreaHeight:" + sourceCuttingAreaHeight);
return Bitmap.createBitmap(source, sourceCuttingAreaX, sourceCuttingAreaY, sourceCuttingAreaWidth, sourceCuttingAreaHeight, null, false);
}其他方法:
private void initParameters(Camera camera) {
try {
mParameters = camera.getParameters();
mParameters.setPreviewFormat(ImageFormat.NV21);
//获取与指定宽高相等或最接近的尺寸
//设置预览尺寸
Camera.Size bestPreviewSize = getBestSize(mSurfaceView.getWidth(), mSurfaceView.getHeight(), mParameters.getSupportedPreviewSizes());
if (bestPreviewSize != null) {
mParameters.setPreviewSize(bestPreviewSize.width, bestPreviewSize.height);
}
//设置保存图片尺寸
Camera.Size bestPicSize = getBestSize(PIC_WIDTH, PIC_HEIGHT, mParameters.getSupportedPictureSizes());
if (bestPicSize != null) {
mParameters.setPictureSize(bestPicSize.width, bestPicSize.height);
}
//对焦模式
if (isSupportFocus(Camera.Parameters.FOCUS_MODE_CONTINUOUS_PICTURE)) {
mParameters.setFocusMode(Camera.Parameters.FOCUS_MODE_CONTINUOUS_PICTURE);
}
camera.setParameters(mParameters);
} catch (Exception e) {
e.printStackTrace();
}
}
private Camera.Size getBestSize(int targetWidth, int targetHeight, List<Camera.Size> sizeList) {
Camera.Size bestSize = null;
float targetRatio = ((float) targetHeight / targetWidth); //目标大小的宽高比
float minDiff = targetRatio;
for (Camera.Size size : sizeList) {
if (size.width == targetHeight && size.height == targetWidth) {
bestSize = size;
break;
}
float supportedRatio = (float) size.width / size.height;
if (Math.abs(supportedRatio - targetRatio) < minDiff) {
minDiff = Math.abs(supportedRatio - targetRatio);
bestSize = size;
}
}
return bestSize;
}参考【人车核验】CaptureManager.java
写法二:
Bitmap bitmap = BitmapFactory.decodeFile(originalFile.getPath());//原图
//计算裁剪位置
float left, top, right, bottom;
left = (float) scanView.getLeft() / (float) cameraPreview.getWidth();
top = ((float) containerView.getTop() - (float) cameraPreview.getTop()) / (float) cameraPreview.getHeight();
right = (float) scanView.getRight() / (float) cameraPreview.getWidth();
bottom = (float) containerView.getBottom() / (float) cameraPreview.getHeight();
//裁剪及保存到文件
Bitmap cropBitmap = Bitmap.createBitmap(bitmap,
(int) (left * (float) bitmap.getWidth()),
(int) (top * (float) bitmap.getHeight()),
(int) ((right - left) * (float) bitmap.getWidth()),
(int) ((bottom - top) * (float) bitmap.getHeight()));参考:MobileCheck
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程学习网。
编程基础网
本文标题为:Android自定义相机、预览区域裁剪
基础教程推荐
猜你喜欢
- 以代码实例总结iOS应用开发中数据的存储方式 2022-11-20
- Android自定义悬浮按钮效果 2023-04-22
- iOS微信分享后关闭发送成功提示并返回应用 2023-01-03
- iOS对数组进行排序的实例代码 2023-03-16
- Kotlin的枚举与异常示例详解 2022-12-07
- iOS的音频文件的格式转换示例 2023-06-11
- iOS统计项目的代码总行数 2022-11-01
- Android自定义view实现圆形进度条效果 2023-05-26
- 使用Android Studio创建OpenCV4.1.0 项目的步骤 2023-02-26
- Android zxing如何识别反转二维码详解 2022-11-08
