opencv 3/C+이미지 테두리 추출 방식

canny 연산 자 실현
track bar 를 사용 하여 canny 연산 자 파 라 메 터 를 조정 하여 적당 한 그림 가장자리 로 추출 합 니 다.

#include<iostream>
#include<opencv2/opencv.hpp>
using namespace cv;

void trackBar(int, void*);
int s1=0,s2=0;
Mat src, dst;
int main()
{
 src = imread("E:/image/image/daibola.jpg");
 if(src.empty())
 {
  printf("can not load image 
"); return -1; } cvNamedWindow("input", CV_WINDOW_AUTOSIZE); imshow("input", src); dst = src.clone(); cvNamedWindow("output", CV_WINDOW_AUTOSIZE); createTrackbar("canny1", "output", &s1, 255, trackBar); createTrackbar("canny2", "output", &s2, 255, trackBar); GaussianBlur(src,src,Size(3,3),0); waitKey(); return 0; } void trackBar(int, void*) { Canny(src,dst,s1,s2,3); imshow("output", dst); }

Sobel 연산 자 실현

#include<iostream>
#include<opencv2/opencv.hpp>
using namespace cv;

int main()
{
 Mat src, dst;
 src = imread("E:/image/image/daibola.jpg");

 if(src.empty())
 {
  printf("can not load image 
"); return -1; } dst = Mat::zeros(src.size(), src.type()); cvNamedWindow("input", CV_WINDOW_AUTOSIZE); imshow("input", src); Mat kernel = (Mat_<int>(2,2)<<0,1,-1,0); filter2D(src,dst,-1,kernel,Point(-1,-1),0.0); Mat xgrad, ygrad; Sobel(src,xgrad,CV_16S,1,0,3); Sobel(src,ygrad,CV_16S,0,1,3); convertScaleAbs(xgrad,xgrad); convertScaleAbs(ygrad,ygrad); addWeighted(xgrad,0.5,ygrad,0.5,0,dst); //addWeighted(dst,0.5,src,1,0,dst); cvNamedWindow("output", CV_WINDOW_AUTOSIZE); imshow("output", dst); waitKey(); return 0; }

이상 의 opencv 3/C+이미지 변두리 추출 방식 은 바로 작은 편집 이 여러분 에 게 공유 하 는 모든 내용 입 니 다.여러분 께 참고 가 되 고 저 희 를 많이 사랑 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기