【问题标题】:Changing the color of an object in an Android application在 Android 应用程序中更改对象的颜色
【发布时间】:2015-09-07 11:53:04
【问题描述】:

基本上我的目标是实时更改对象的颜色以进行油漆应用。为了实现这个目标,我遵循以下概念:

  1. 我已使用canny() 方法来查找对象。
  2. 使用findContours() 进行边缘检测。
  3. 使用drawContours() 为对象着色。

如果有实现目标所需的任何其他概念,请 向我建议。我试过但没有得到精确的轮廓边缘。

原始输入:

预期输出:

当前输出:

我正在获取灰度图像,但我想要 rgb 模式。

这是我的代码:

package com.example.imageprocess;

import java.util.ArrayList;
import java.util.List;

import org.opencv.android.BaseLoaderCallback;
import org.opencv.android.CameraBridgeViewBase;
import org.opencv.android.CameraBridgeViewBase.CvCameraViewFrame;
import org.opencv.android.CameraBridgeViewBase.CvCameraViewListener2;
import org.opencv.android.LoaderCallbackInterface;
import org.opencv.android.OpenCVLoader;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.core.MatOfPoint;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.core.Size;
import org.opencv.imgproc.Imgproc;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.WindowManager;

public class MainActivity extends Activity implements CvCameraViewListener2 {

        private Mat                    mRgba;
        private Mat                    mIntermediateMat;
        private Mat                    mGray;

        private CameraBridgeViewBase   mOpenCvCameraView;

        private BaseLoaderCallback  mLoaderCallback = new BaseLoaderCallback(this) {
            @Override
            public void onManagerConnected(int status) {
                switch (status) {
                    case LoaderCallbackInterface.SUCCESS:
                    {
                        Log.i("OPENCVACTIVITY", "OpenCV loaded successfully");

                        // Load native library after(!) OpenCV initialization
                       // System.loadLibrary("mixed_sample");

                        mOpenCvCameraView.enableView();
                    } break;
                    default:
                    {
                        super.onManagerConnected(status);
                    } break;
                }
            }
        };

       /* public MainActivity() {
            Log.i("OPENCVACTIVITY", "Instantiated new " + this.getClass());
        }
*/
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
          getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);

            setContentView(R.layout.activity_main);

            mOpenCvCameraView = (CameraBridgeViewBase) findViewById(R.id.tutorial2_activity_surface_view);
            mOpenCvCameraView.setCvCameraViewListener(this);
    }



    @Override
    public void onPause()
    {
        super.onPause();
        if (mOpenCvCameraView != null)
            mOpenCvCameraView.disableView();
    }

    @Override
    public void onResume()
    {
        super.onResume();
        OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_3, this, mLoaderCallback);
    }

    public void onDestroy() {
        super.onDestroy();
        if (mOpenCvCameraView != null)
            mOpenCvCameraView.disableView();
    }

    @Override
    public void onCameraViewStarted(int width, int height) {
        // TODO Auto-generated method stub
         mRgba = new Mat(height, width, CvType.CV_8UC4);
            mIntermediateMat = new Mat(height, width, CvType.CV_8UC4);
            mGray = new Mat(height, width, CvType.CV_8UC1);

    }

    @Override
    public void onCameraViewStopped() {
         mRgba.release();
            mGray.release();
            mIntermediateMat.release();

    }

    @Override
    public Mat onCameraFrame(CvCameraViewFrame inputFrame) {
        Mat gaussian_output = new Mat();
         mRgba = inputFrame.rgba();
         Imgproc.Canny(inputFrame.gray(), mIntermediateMat, 80, 100);
         Imgproc.cvtColor(mIntermediateMat, mRgba, Imgproc.COLOR_YUV2RGBA_NV21, 4);
         Imgproc.GaussianBlur(mIntermediateMat, gaussian_output, new Size(5, 5), 5);
         List<MatOfPoint> contours = new ArrayList<MatOfPoint>();
         Imgproc.findContours( gaussian_output, contours, new Mat(),Imgproc.RETR_EXTERNAL, Imgproc.CHAIN_APPROX_SIMPLE, new Point(0,0) );
         Scalar color = new Scalar(165, 30, 215);
        // Imgproc.drawContours(gaussian_output, contours, -1, color, 3);
         Mat hierarchy = new Mat();
      // find contours:
      Imgproc.findContours(gaussian_output, contours, hierarchy, Imgproc.RETR_TREE,Imgproc.CHAIN_APPROX_SIMPLE);
      for (int contourIdx = 0; contourIdx < contours.size(); contourIdx++) {
          Imgproc.drawContours(gaussian_output, contours, contourIdx,color, -1);
      }

        return gaussian_output;
    }


}

【问题讨论】:

  • 你找到解决办法了吗?我也在尝试相同但找不到​​任何东西。你能帮我吗

标签: android opencv image-processing edge-detection


【解决方案1】:

我相信你犯了将灰度图像移动到彩色图像的错误。

尝试: Imgproc.cvtColor(mRgba, mIntermediateMat, Imgproc.COLOR_YUV2RGBA_NV21, 4); 代替: Imgproc.cvtColor(mIntermediateMat, mRgba, Imgproc.COLOR_YUV2RGBA_NV21, 4);

【讨论】:

  • 上面的代码不起作用......现在我正在获取灰度图像,但我希望用彩色图像打开相机,当我触摸特定对象时,对象颜色会改变
  • 我仍然觉得你在 onCameraFrame 方法中犯了一些严重的错误。您将获得 inputFrame 的 rgba 和灰度版本,然后您稍后将灰度用作输入,并将 rgba 作为有效覆盖它的输出。
  • 当我尝试在 oncameraFrame() 中使用以下代码获得相同的输出时,我的意思是图像以灰度显示 Imgproc.Canny(mRgba, mIntermediateMat, 80, 100); Imgproc.cvtColor(mIntermediateMat, mRgba, Imgproc.COLOR_YUV2RGBA_NV21, 4);
  • 我并不是说那是错误,它可能是其他错误,因为您正在将 rgba 重置为灰度。
  • 你能把这个项目放在某个地方,这样我就可以在 Eclipse 中弄乱它,看看我能不能让它工作?
【解决方案2】:

聚会有点晚了。我还没有尝试过代码,但我怀疑:

mIntermediateMat = new Mat(height, width, CvType.CV_8UC4);

虽然这里的 mIntermediateMat 是 8bit 4 通道垫,

Imgproc.Canny(inputFrame.gray(), mIntermediateMat, 80, 100);

这里变成了一个 8bit 1 通道的垫子。参考:canny doc.

输出边缘图;它具有与图像相同的大小和类型。

结果,

Imgproc.GaussianBlur(mIntermediateMat, gaussian_output, new Size(5, 5), 5);

gaussian_output 是一个 8bit 1 通道 mat,并且...

return gaussian_output;

返回 8 位 1 通道(灰度)图像。

【讨论】:

    【解决方案3】:

    http://www.labbookpages.co.uk/software/imgProc/libPNG.html

    您应该使用 LIBPNG 进行图像处理。使用它,您可以通过设置颜色矩阵将其转换为灰度或彩色图像。

    【讨论】:

      猜你喜欢
      • 2011-02-14
      • 1970-01-01
      • 2020-08-10
      • 1970-01-01
      • 1970-01-01
      • 2012-03-30
      • 2016-11-01
      • 2017-09-29
      • 2010-12-15
      相关资源
      最近更新 更多