Visual Studio 2013 Express Visual C++( アンマネージドコード ) OpenCV 3.1 |
■248.OpenCV ラプラシアンフィルタ | Prev Top Next | |
|
今回はラプラシアンフィルタです。輪郭抽出です。
#include <iostream> #include <opencv2/highgui/highgui.hpp> #include <opencv2/imgproc/imgproc.hpp> #pragma comment( lib, "opencv_world300d.lib" ) int main(int argc, const char* argv[]) { int hr = -1; try { cv::Mat src, dest; // 輪郭線を白色にするためグレースケールにする src = cv::imread("D:/TEMP/MaverickProj/Image/OpenCV/10/Texture.png", cv::IMREAD_GRAYSCALE); cv::Laplacian( src, dest, -1, // 出力画像に求めるビット深度. 3, // 2次微分フィルタを求めるために利用されるアパーチャのサイズ.正の奇数でないとならない 0.5, // 求められたラプラシアンに対するスケールファクタ 0, // dst に格納する前に,結果に足されるオプション値. cv::BORDER_DEFAULT ); std::cout << "Successed" << std::endl; // 元画像のウィンドウ表示 cv::namedWindow("Source", 1); imshow("Source", src); // フィルタ適用後の画像のウィンドウ表示 cv::namedWindow("Laplacian", 1); imshow("Laplacian", dest); cv::waitKey(0); hr = 0; } catch (cv::Exception ex) { std::cout << ex.err << std::endl; } // ウィンドウの破棄 cv::destroyAllWindows(); return hr; }
ksize = 3.0 scale = 0.5