首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >opencv android中的光流计算

opencv android中的光流计算
EN

Stack Overflow用户
提问于 2013-11-08 11:59:21
回答 2查看 2.8K关注 0票数 1

我是OpenCV的初学者,正在尝试使用OpenCV的calcOpticalFlowFarneback方法计算光流。

请看我的实现:

代码语言:javascript
复制
package org.opencv.samples.tutorial1;

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.MatOfPoint2f;
import org.opencv.video.Video;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.SurfaceView;
import android.view.WindowManager;
import android.widget.Toast;

public class Tutorial1Activity extends Activity implements CvCameraViewListener2 {
    private static final String TAG = "OCVSample::Activity";

    private CameraBridgeViewBase mOpenCvCameraView;
    private boolean              mIsJavaCamera = true;
    private MenuItem             mItemSwitchCamera = null;

    private BaseLoaderCallback mLoaderCallback = new BaseLoaderCallback(this) {
        @Override
        public void onManagerConnected(int status) {
            switch (status) {
                case LoaderCallbackInterface.SUCCESS:
                {
                    Log.i(TAG, "OpenCV loaded successfully");
                    mOpenCvCameraView.enableView();
                } break;
                default:
                {
                    super.onManagerConnected(status);
                } break;
            }
        }
    };

    public Tutorial1Activity() {
        Log.i(TAG, "Instantiated new " + this.getClass());
    }

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        Log.i(TAG, "called onCreate");
        super.onCreate(savedInstanceState);
        getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);

        setContentView(R.layout.tutorial1_surface_view);

        if (mIsJavaCamera)
            mOpenCvCameraView = (CameraBridgeViewBase) findViewById(R.id.tutorial1_activity_java_surface_view);
        else
            mOpenCvCameraView = (CameraBridgeViewBase) findViewById(R.id.tutorial1_activity_native_surface_view);

        mOpenCvCameraView.setVisibility(SurfaceView.VISIBLE);

        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 boolean onCreateOptionsMenu(Menu menu) {
        Log.i(TAG, "called onCreateOptionsMenu");
        mItemSwitchCamera = menu.add("Toggle Native/Java camera");
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        String toastMesage = new String();
        Log.i(TAG, "called onOptionsItemSelected; selected item: " + item);

        if (item == mItemSwitchCamera) {
            mOpenCvCameraView.setVisibility(SurfaceView.GONE);
            mIsJavaCamera = !mIsJavaCamera;

            if (mIsJavaCamera) {
                mOpenCvCameraView = (CameraBridgeViewBase) findViewById(R.id.tutorial1_activity_java_surface_view);
                toastMesage = "Java Camera";
            } else {
                mOpenCvCameraView = (CameraBridgeViewBase) findViewById(R.id.tutorial1_activity_native_surface_view);
                toastMesage = "Native Camera";
            }

            mOpenCvCameraView.setVisibility(SurfaceView.VISIBLE);
            mOpenCvCameraView.setCvCameraViewListener(this);
            mOpenCvCameraView.enableView();
            Toast toast = Toast.makeText(this, toastMesage, Toast.LENGTH_LONG);
            toast.show();
        }

        return true;
    }



    public void onCameraViewStarted(int width, int height) {
    }

    public void onCameraViewStopped() {

    }

    Mat first_frame = null;
    Mat second_frame = null;
    boolean dumped = false;
    //this function is called on each frame.
    public Mat onCameraFrame(CvCameraViewFrame inputFrame) {



        // I wanted to calculate the optical flow like this.
        first_frame = second_frame;
        if(first_frame == null || second_frame == null){
            second_frame = inputFrame.rgba();
            return inputFrame.rgba();
        }

        //now we have two consecutive frame.
        Mat flow = new Mat(inputFrame.rgba().size(), CvType.CV_8UC1);

        Video.calcOpticalFlowFarneback(first_frame, second_frame, flow,0.5,1, 1, 1, 7,
                1.5,1);
        System.out.println("flow = "+flow.dump());

        return inputFrame.rgba();
    }
}

它给出了错误,因为我可能在参数中输入了错误的值。有人能帮帮忙吗?

EN

回答 2

Stack Overflow用户

发布于 2013-12-17 15:50:11

首先,声场的流动非常缓慢。我只能重新保存约10fps,而不会在使用cvCameraViewListener2时对图像进行任何更改。所以你(可能)得不到好的帧率。

第二,现在是一年多以前,我上一次做光流的事情。当第二次调用onCameraFrame时,设置first_frame=second_frame。但是您并没有将实际的帧放入您的second_frame。您的first_frame仍然等于您的second_frame。

代码语言:javascript
复制
first_frame = second_frame;
    if(first_frame == null || second_frame == null){
        second_frame = inputFrame.rgba();
        return inputFrame.rgba();
    }
//ADD THIS:
second_frame = inputFrame.rgba();


    //now we have two consecutive frame.
票数 0
EN

Stack Overflow用户

发布于 2014-05-07 01:54:21

为了使calcOpticalFlowFarneback工作,第一帧和第二帧应该具有。

代码语言:javascript
复制
channels() == 1

我不确定是否有办法转换它。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19851347

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档