opencv_ex19-圖像放大pyrUp、彩色轉灰階cvtColor、灰階圖像可調式邊緣檢測Canny、二值化圖像反向輸出

opencv_ex19-圖像放大pyrUp、彩色轉灰階cvtColor、灰階圖像可調式邊緣檢測Canny、二值化圖像反向輸出

opencv_ex19-圖像放大pyrUp、彩色轉灰階cvtColor、灰階圖像可調式邊緣檢測Canny、二值化圖像反向輸出


GITHUB: https://github.com/jash-git/CPP_opencv249_ex


    OpenCV canny
    void Canny(InputArray image, OutputArray edges, double threshold1, double threshold2, int apertureSize=3, bool L2gradient=false)

        src:輸入圖,單通道8位元圖。
        dst:輸出圖,尺寸、型態和輸入圖相同。
        threshold1:第一個閾值。
        threshold2:第二個閾值。
        apertureSize :Sobel算子的核心大小。
        L2gradient :梯度大小的算法,預設為false。

#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/ml/ml.hpp>

#include <iostream>
#include <cstdio>

#include <sys/timeb.h>
#if defined(WIN32)
    #define  TIMEB    _timeb
    #define  ftime    _ftime
    typedef __int64 TIME_T;
#else
    #define TIMEB timeb
    typedef long long TIME_T;
#endif

using namespace cv;
using namespace std;
Mat src;//input image
void Pause()
{
    printf("Press Enter key to continue...");
    fgetc(stdin);
}

int t1_value = 50;
int max_value = 255;
Mat gray_src;
const char* OUTPUT_TITLE = "Canny Result";
void Canny_Demo(int, void*);

int main()
{
    Mat input;
	input = imread("Lena_original.jpg");
	if (!input.data)
    {
		printf("could not load image...\n");
	}
    else
    {
        //放大
        pyrUp(input, src, Size(input.cols*2, input.rows*2));

        Mat tmp;
        GaussianBlur(src, tmp, Size(3, 3), 0, 0);//高斯模糊GaussianBlur目的為了給圖像預處理時候減低噪聲(雜訊)
        cvtColor(tmp, gray_src, CV_BGR2GRAY);//彩色轉灰階
        imshow("Lena_gray", gray_src);

        namedWindow(OUTPUT_TITLE, CV_WINDOW_AUTOSIZE);
        createTrackbar("Threshold Value:", OUTPUT_TITLE, &t1_value, max_value, Canny_Demo);
        Canny_Demo(0, 0);
    }
    waitKey(0);
    Pause();
    return 0;
}
void Canny_Demo(int, void*) {
	Mat edge_output;
	Canny(gray_src, edge_output, t1_value, t1_value * 2, 3, false);

	imshow(OUTPUT_TITLE, ~edge_output);
}

發表迴響

你的電子郵件位址並不會被公開。 必要欄位標記為 *