Android 解决MTK相机前摄镜像问题

ops/2024/11/8 21:44:34/

很莫名其妙的,前摄默认镜像,原来是为了前摄拍字体正确显示,比如自拍,前摄拍摄的人像虽左右镜像了,但如果后面有字牌显示,字体会显示正常而不是翻转。但现在需求是满足普遍的前摄原生代码不带镜像修改,需要把预览和保存的图片进行左右翻转,那么就需要找到相应的修改位置才行。

以下就是相关修改点:直接修复前摄镜像显示 即可正常显示

充分利用此方法:

PhotoModeHelper.rotateAndMirror(bitmap, orientation, true);

matrix.postScale(-1, 1);

1./vendor/mediatek/proprietary/packages/apps/Camera2/common/src/com/mediatek/camera/common/utils/CameraUtil.java

 //*/add package
import android.graphics.BitmapFactory;
import com.mediatek.camera.common.mode.photo.PhotoModeHelper;
import java.io.ByteArrayOutputStream;
import android.graphics.Bitmap;
//*/

添加在最后的方法

//*/add sub camera mirror method mirrorJpegData
   public static byte[] mirrorJpegData(byte[] jpegData, int orientation) {
       byte[] dest = jpegData;
       BitmapFactory.Options opts = new BitmapFactory.Options();
       opts.inMutable = true;
       Bitmap b = BitmapFactory.decodeByteArray(jpegData, 0, jpegData.length, opts);
       b = PhotoModeHelper.rotateAndMirror(b, orientation, true);
       ByteArrayOutputStream baos = new ByteArrayOutputStream();
       b.compress(Bitmap.CompressFormat.JPEG, 100, baos);
       dest = baos.toByteArray();
       b.recycle();

       return dest;
   }
   //*/

2./vendor/mediatek/proprietary/packages/apps/Camera2/common/src/com/mediatek/camera/common/mode/photo/PhotoMode.java

 @Override
    public void onPostViewCallback(byte[] data) {
        LogHelper.d(TAG, "[onPostViewCallback] data = " + data + ",mIsResumed = " + mIsResumed);
        CameraSysTrace.onEventSystrace(POST_VIEW_CALLBACK, true, true);
        if (data != null && mIsResumed) {
            //will update the thumbnail
            int rotation = CameraUtil.getJpegRotationFromDeviceSpec(Integer.parseInt(mCameraId),
                    mIApp.getGSensorOrientation(), mIApp.getActivity());
            Bitmap bitmap = BitmapCreator.createBitmapFromYuv(data,
                    ThumbnailHelper.POST_VIEW_FORMAT,
                    ThumbnailHelper.getThumbnailWidth(),
                    ThumbnailHelper.getThumbnailHeight(),
                    mIApp.getAppUi().getThumbnailViewWidth(),
                    rotation);
              //*/ add sub camera mirror
            if (mCameraId.equals(FRONT_CAMERA_ID)) {//BACK_CAMERA_ID
                Matrix m = new Matrix();
                m.postScale(-1, 1);
                bitmap = Bitmap.createBitmap(bitmap, 0, 0, bitmap.getWidth(), bitmap.getHeight(), m, true);
            }
            //*/

            mIApp.getAppUi().updateThumbnail(bitmap);
        }
        CameraSysTrace.onEventSystrace(POST_VIEW_CALLBACK, false, true);
    }

===============

保存数据是通过PhotoMode.java文件中的saveData方法实现,具体修改参照如下:引用方法

   private void saveData(byte[] data) {
        if (data != null) {
            //*/ add. sub camera mirror
            if (mCameraId.equals(FRONT_CAMERA_ID)) {//BACK_CAMERA_ID
                data = CameraUtil.mirrorJpegData(data, 0);
            }
            //*/

            //check memory to decide whether it can take next picture.
            //if not, show saving
            ISettingManager.SettingController controller = mISettingManager.getSettingController();
            String dngState = controller.queryValue(KEY_DNG);
            long saveDataSize = data.length;
            if (dngState != null && "on".equalsIgnoreCase(dngState)) {
                saveDataSize = saveDataSize + DNG_IMAGE_SIZE;
            }
            synchronized (mCaptureNumberSync) {
                mCapturingNumber ++;
                mMemoryManager.checkOneShotMemoryAction(saveDataSize);
            }
            String fileDirectory = mICameraContext.getStorageService().getFileDirectory();
            Size exifSize = CameraUtil.getSizeFromSdkExif(data);
            ContentValues contentValues = mPhotoModeHelper.createContentValues(data,
                    fileDirectory, exifSize.getWidth(), exifSize.getHeight());
            mICameraContext.getMediaSaver().addSaveRequest(data, contentValues, null,
                    mMediaSaverListener);
        }
    }

到此完结撒花! 


http://www.ppmy.cn/ops/132039.html

相关文章

对称二叉树(力扣101)

题目如下: 思路 对于这道题, 我会采用递归的解法. 看着对称的二叉树, 写下判断对称的条件, 再进入递归即可. 值得注意的是, 代码中会有两个函数, 第一个是isSymmetric,第二个是judge. 因为这里会考虑到一种特殊情况, 那就是 二叉树的根结点(最上面的那个),它会单独用…

内容创作太难?分享五个偷懒工具!

在数字内容创作日益繁荣的今天,选择高效、优质的创作资源平台是每位创作者提升作品质量的关键。以下是几个内容创作必备的网站推荐,涵盖了设计、文案、灵感、图片等多个领域,助您在创作的道路上事半功倍。 一、UI中国UI中国官网https://www.u…

LeetCode100之旋转图像(48)--Java

1.问题描述 给定一个 n n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。 示例1 输入:matrix [[1,2,3],[4,5,6],[7,8,9]] 输出&…

第七篇: BigQuery中的复杂SQL查询

BigQuery中的复杂SQL查询 背景与目标 在数据分析中,我们通常需要从多个数据源中获取信息,以便进行深入的分析。这时,BigQuery提供的JOIN、UNION和子查询等复杂SQL语句非常实用。本文将以Google BigQuery的公共数据集为例,介绍如何…

提示工程(Prompt Engineering):大模型微调Prompt/Instruct Mode;稀疏向量与稠密向量进行词语编码

目录 提示工程(Prompt Engineering):大模型微调Prompt/Instruct Mode 稀疏向量与稠密向量 稀疏向量 稠密向量 稀疏向量与稠密向量的区别 提示工程(Prompt Engineering):大模型微调Prompt/Instruct Mode 如今已不再是一个陌生的概念,它作为一种“有效地与人工智能沟…

Python 继承、多态、封装、抽象

面向对象编程(OOP)是 Python 中的一种重要编程范式,它通过类和对象来组织代码。OOP 的四个核心概念是继承(Inheritance)、多态(Polymorphism)、封装(Encapsulation)和数据…

Maven(25)如何使用Maven进行性能测试?

使用Maven进行性能测试通常涉及使用JMeter或JMH(Java Microbenchmark Harness)等工具。这里我将详细介绍如何使用JMH进行性能测试,因为它是专门为Java微基准测试设计的。以下是如何在Maven项目中集成JMH进行性能测试的步骤: 步骤…

智能电网能源优化管理系统(Smart Grid Energy Optimization Management System, SGEOMS)

1.产品介绍 产品介绍方案 产品名称 智能电网能源优化管理系统(Smart Grid Energy Optimization Management System, SGEOMS) 主要功能 能源生产优化能源输送优化能源分配优化能源使用优化功能介绍 能源生产优化 具体作用:通过对现有能源生产过程的优化和建立新的能源生产…