當前位置: 首頁>>代碼示例>>Java>>正文


Java CameraBridgeViewBase.CvCameraViewFrame方法代碼示例

本文整理匯總了Java中org.opencv.android.CameraBridgeViewBase.CvCameraViewFrame方法的典型用法代碼示例。如果您正苦於以下問題:Java CameraBridgeViewBase.CvCameraViewFrame方法的具體用法?Java CameraBridgeViewBase.CvCameraViewFrame怎麽用?Java CameraBridgeViewBase.CvCameraViewFrame使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.opencv.android.CameraBridgeViewBase的用法示例。


在下文中一共展示了CameraBridgeViewBase.CvCameraViewFrame方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    //Rotating the input frame
    Mat mGray = inputFrame.gray();
    mRgba = inputFrame.rgba();
    if (mIsFrontCamera)
    {
        Core.flip(mRgba, mRgba, 1);
        Core.flip(mGray, mGray, 1);
    }

    //Detecting face in the frame
    MatOfRect faces = new MatOfRect();
    if(haarCascade != null)
    {
        haarCascade.detectMultiScale(mGray, faces, 1.1, 2, 2, new Size(200,200), new Size());
    }

    Rect[] facesArray = faces.toArray();
    for (int i = 0; i < facesArray.length; i++)
        Imgproc.rectangle(mRgba, facesArray[i].tl(), facesArray[i].br(), new Scalar(100), 3);
    return mRgba;
}
 
開發者ID:johnhany,項目名稱:MOAAP,代碼行數:24,代碼來源:MainActivity.java

示例2: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    mRgba = inputFrame.rgba();
    mGray = inputFrame.gray();

    if (absoluteFaceSize == 0) {
        int height = mGray.rows();
        float relativeFaceSize = 0.2f;

        if (Math.round(height * relativeFaceSize) > 0) {
            absoluteFaceSize = Math.round(height * relativeFaceSize);
        }
        nativeDetector.setMinFaceSize(absoluteFaceSize);
    }

    MatOfRect faces = new MatOfRect();
    MatOfRect facesFliped = new MatOfRect();

    return getMat(mRgba, mGray, faces, facesFliped);
}
 
開發者ID:rafaelaaraujo,項目名稱:Face-detect-framework,代碼行數:20,代碼來源:FaceDetect.java

示例3: render

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat render(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    Mat undistortedFrame = new Mat(inputFrame.rgba().size(), inputFrame.rgba().type());
    Imgproc.undistort(inputFrame.rgba(), undistortedFrame,
            mCalibrator.getCameraMatrix(), mCalibrator.getDistortionCoefficients());

    Mat comparisonFrame = inputFrame.rgba();
    undistortedFrame.colRange(new Range(0, mWidth / 2)).copyTo(comparisonFrame.colRange(new Range(mWidth / 2, mWidth)));
    List<MatOfPoint> border = new ArrayList<MatOfPoint>();
    final int shift = (int)(mWidth * 0.005);
    border.add(new MatOfPoint(new Point(mWidth / 2 - shift, 0), new Point(mWidth / 2 + shift, 0),
            new Point(mWidth / 2 + shift, mHeight), new Point(mWidth / 2 - shift, mHeight)));
    Imgproc.fillPoly(comparisonFrame, border, new Scalar(255, 255, 255));

    Imgproc.putText(comparisonFrame, mResources.getString(R.string.original), new Point(mWidth * 0.1, mHeight * 0.1),
            Core.FONT_HERSHEY_SIMPLEX, 1.0, new Scalar(255, 255, 0));
    Imgproc.putText(comparisonFrame, mResources.getString(R.string.undistorted), new Point(mWidth * 0.6, mHeight * 0.1),
            Core.FONT_HERSHEY_SIMPLEX, 1.0, new Scalar(255, 255, 0));

    return comparisonFrame;
}
 
開發者ID:xunqun,項目名稱:OpenCV-AndroidSamples-master,代碼行數:22,代碼來源:ComparisonFrameRender.java

示例4: render

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat render(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    Mat undistortedFrame = new Mat(inputFrame.rgba().size(), inputFrame.rgba().type());
    Imgproc.undistort(inputFrame.rgba(), undistortedFrame,
            mCalibrator.getCameraMatrix(), mCalibrator.getDistortionCoefficients());

    Mat comparisonFrame = inputFrame.rgba();
    undistortedFrame.colRange(new Range(0, mWidth / 2)).copyTo(comparisonFrame.colRange(new Range(mWidth / 2, mWidth)));
    List<MatOfPoint> border = new ArrayList<MatOfPoint>();
    final int shift = (int)(mWidth * 0.005);
    border.add(new MatOfPoint(new Point(mWidth / 2 - shift, 0), new Point(mWidth / 2 + shift, 0),
            new Point(mWidth / 2 + shift, mHeight), new Point(mWidth / 2 - shift, mHeight)));
    Core.fillPoly(comparisonFrame, border, new Scalar(255, 255, 255));

    Core.putText(comparisonFrame, mResources.getString(R.string.original), new Point(mWidth * 0.1, mHeight * 0.1),
            Core.FONT_HERSHEY_SIMPLEX, 1.0, new Scalar(255, 255, 0));
    Core.putText(comparisonFrame, mResources.getString(R.string.undistorted), new Point(mWidth * 0.6, mHeight * 0.1),
            Core.FONT_HERSHEY_SIMPLEX, 1.0, new Scalar(255, 255, 0));

    return comparisonFrame;
}
 
開發者ID:jsmith613,項目名稱:Aruco-Marker-Tracking-Android,代碼行數:22,代碼來源:ComparisonFrameRender.java

示例5: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    Mat imgRgba = inputFrame.rgba();
    Mat img = new Mat();
    imgRgba.copyTo(img);
    List<Mat> images = ppF.getCroppedImage(img);
    Rect[] faces = ppF.getFacesForRecognition();

    // Selfie / Mirror mode
    if(front_camera){
        Core.flip(imgRgba,imgRgba,1);
    }
    if(images == null || images.size() == 0 || faces == null || faces.length == 0 || ! (images.size() == faces.length)){
        // skip
        return imgRgba;
    } else {
        faces = MatOperation.rotateFaces(imgRgba, faces, ppF.getAngleForRecognition());
        for(int i = 0; i<faces.length; i++){
            MatOperation.drawRectangleAndLabelOnPreview(imgRgba, faces[i], "", front_camera);
        }
        return imgRgba;
    }
}
 
開發者ID:Qualeams,項目名稱:Android-Face-Recognition-with-Deep-Learning-Test-Framework,代碼行數:24,代碼來源:DetectionActivity.java

示例6: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    // input frame has RGBA format
    mRgba = inputFrame.rgba();
    mGray = inputFrame.gray();
    doWithMat(mGray.getNativeObjAddr(), mRgba.getNativeObjAddr());
    return mRgba;
}
 
開發者ID:vulovicv23,項目名稱:opencv-documentscanner-android,代碼行數:9,代碼來源:OpenCvCamera.java

示例7: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    if (!initialized) {
        return inputFrame.rgba();
    }

    // telemetry.addData("Vision Status", "Ready!");

    fps.update();
    return frame(inputFrame.rgba(), inputFrame.gray());
}
 
開發者ID:ykarim,項目名稱:FTC2016,代碼行數:12,代碼來源:VisionOpModeCore.java

示例8: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    Mat rgba = inputFrame.rgba();
    Mat gray = inputFrame.gray();
    setMatrices(rgba, gray);
    if (isMachineLearningInitialised && !isStopped) {
        fdInteractor.execute(matrixGray, this);
    }
    return matrixRgba;
}
 
開發者ID:raulh82vlc,項目名稱:Image-Detection-Samples,代碼行數:11,代碼來源:FDOpenCVPresenter.java

示例9: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
// 這裏執行人臉檢測的邏輯, 根據OpenCV提供的例子實現(face-detection)
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    mRgba = inputFrame.rgba();
    mGray = inputFrame.gray();
    // 翻轉矩陣以適配前後置攝像頭
    if (isFrontCamera) {
        Core.flip(mRgba, mRgba, 1);
        Core.flip(mGray, mGray, 1);
    } else {
        Core.flip(mRgba, mRgba, -1);
        Core.flip(mGray, mGray, -1);
    }
    float mRelativeFaceSize = 0.2f;
    if (mAbsoluteFaceSize == 0) {
        int height = mGray.rows();
        if (Math.round(height * mRelativeFaceSize) > 0) {
            mAbsoluteFaceSize = Math.round(height * mRelativeFaceSize);
        }
    }
    MatOfRect faces = new MatOfRect();
    if (classifier != null)
        classifier.detectMultiScale(mGray, faces, 1.1, 2, 2,
                new Size(mAbsoluteFaceSize, mAbsoluteFaceSize), new Size());
    Rect[] facesArray = faces.toArray();
    Scalar faceRectColor = new Scalar(0, 255, 0, 255);
    for (Rect faceRect : facesArray)
        Imgproc.rectangle(mRgba, faceRect.tl(), faceRect.br(), faceRectColor, 3);
    return mRgba;
}
 
開發者ID:typer9527,項目名稱:FaceDetectDemo,代碼行數:31,代碼來源:DetectActivity.java

示例10: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    Mat input = inputFrame.gray();
    Mat circles = new Mat();
    Imgproc.blur(input, input, new Size(7, 7), new Point(2, 2));
    Imgproc.HoughCircles(input, circles, Imgproc.CV_HOUGH_GRADIENT, 2, 100, 100, 90, 0, 1000);

    Log.i(TAG, String.valueOf("size: " + circles.cols()) + ", " + String.valueOf(circles.rows()));

    if (circles.cols() > 0) {
        for (int x=0; x < Math.min(circles.cols(), 5); x++ ) {
            double circleVec[] = circles.get(0, x);

            if (circleVec == null) {
                break;
            }

            Point center = new Point((int) circleVec[0], (int) circleVec[1]);
            int radius = (int) circleVec[2];

            Imgproc.circle(input, center, 3, new Scalar(255, 255, 255), 5);
            Imgproc.circle(input, center, radius, new Scalar(255, 255, 255), 2);
        }
    }

    circles.release();
    input.release();
    return inputFrame.rgba();
}
 
開發者ID:ahmetozlu,項目名稱:real_time_circle_detection_android,代碼行數:30,代碼來源:MainActivity.java

示例11: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    mRgba = inputFrame.rgba();
    mGray = inputFrame.gray();
    JniManager.process(mRgba.getNativeObjAddr(), mGray.getNativeObjAddr());
    return mRgba;
}
 
開發者ID:uelordi01,項目名稱:Android-opencv-native-samples,代碼行數:8,代碼來源:MainActivity.java

示例12: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    mRgba = inputFrame.rgba();
    mGray = inputFrame.gray();
    rotateFlipImage(ImageControllers.getInstance().getFlipType(),
                        ImageControllers.getInstance().getMakeTranspose(),
                                                mRgba.getNativeObjAddr());
    if (mAbsoluteFaceSize == 0) {
        int height = mGray.rows();
        if (Math.round(height * mRelativeFaceSize) > 0) {
            mAbsoluteFaceSize = Math.round(height * mRelativeFaceSize);
        }
        mNativeDetector.setMinFaceSize(mAbsoluteFaceSize);
    }

    MatOfRect faces = new MatOfRect();

    if (mDetectorType == JAVA_DETECTOR) {
        if (mJavaDetector != null)
            mJavaDetector.detectMultiScale(mGray, faces, 1.1, 2, 2, // TODO: objdetect.CV_HAAR_SCALE_IMAGE
                    new Size(mAbsoluteFaceSize, mAbsoluteFaceSize), new Size());
    }
    else if (mDetectorType == NATIVE_DETECTOR) {
        if (mNativeDetector != null)
            mNativeDetector.detect(mGray, faces);
        Log.v(LOG_TAG, "native detect");
    }
    else {
        Log.e(TAG, "Detection method is not selected!");
    }

    Rect[] facesArray = faces.toArray();
    for (int i = 0; i < facesArray.length; i++)
        Imgproc.rectangle(mRgba, facesArray[i].tl(), facesArray[i].br(), FACE_RECT_COLOR, 3);

    return mRgba;
}
 
開發者ID:uelordi01,項目名稱:Android-opencv-native-samples,代碼行數:38,代碼來源:FdActivity.java

示例13: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    Mat raw = inputFrame.rgba();

    Size imageSize = new Size(1280,720); //Resize Images to this

    Boolean debug_show_preprocessed = false; //Show the preproccessed image
    Boolean debug_show_filtered = false; //Show the filtered image
    Boolean debug_draw_stats = false; //Show stats for each rectangle (very spammy)
    Boolean debug_draw_center = false; //Draw center line on the screen
    Boolean debug_draw_rects = false; //Draw all found rectangles

    //Weights for scoring
    double score_ratio_weight = 0.9;
    double score_distance_x_weight = 1;
    double score_distance_y_weight = 1.2;
    double score_area_weight = 3;

    try {

    }
    catch (Exception e) {
        telemetry.addData("error",e.getMessage());
    }
    // This is where the magic will happen. inputFrame has all the data for each camera frame.
    telemetry.update();
    return raw;
}
 
開發者ID:SCHS-Robotics,項目名稱:Team9261-2017-2018,代碼行數:29,代碼來源:GlyphDetector.java

示例14: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    Mat matRgba = inputFrame.rgba();

    // just draw a text string to test modifying onCameraFrame real time by listener
    // Core.putText(matRgba, "~20% screen size", new Point(100,300), 3, 1, new Scalar (255, 0, 0, 255), 2);

    onCameraFrame(matRgba);
    return matRgba;

}
 
開發者ID:rustielin,項目名稱:MemeVision,代碼行數:12,代碼來源:MainActivity.java

示例15: onCameraFrame

import org.opencv.android.CameraBridgeViewBase; //導入方法依賴的package包/類
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame)
{
    threshold = thresholdBar.getProgress();
    edge = inputFrame.rgba();
    if(((Switch) findViewById(R.id.edgeSwitch)).isChecked())
        Canny(edge, edge,threshold , threshold*3);
    return edge;
}
 
開發者ID:gcoulby,項目名稱:OpenCVDistanceCamera,代碼行數:10,代碼來源:MainActivity.java


注:本文中的org.opencv.android.CameraBridgeViewBase.CvCameraViewFrame方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。