OpencvSharp图像融合

最近学习OpencvSharp使用Opencv仿照C++opencv翻译过来。举个例子,图像融合C++版

    clock_t start1, end1;
    clock_t start2, end2;

    Mat src = imread("D:/dd.jpg");
    Mat dst = imread("D:/ss.jpg ");

    Mat src_mask = 255 * Mat::ones(src.rows, src.cols, src.depth());
    Point center(dst.cols / 2, dst.rows / 2);

    Mat normal_clone;
    Mat mixed_clone;

    start1 = clock();
    seamlessClone(src, dst, src_mask, center, normal_clone, NORMAL_CLONE);
    end1 = clock();

    start2 = clock();
    seamlessClone(src, dst, src_mask, center, mixed_clone, MIXED_CLONE);
    end2 = clock();

    printf("NORMAL_CLONE use time: %d\n", end1 - start1);
    printf("MIXED_CLONE use time: %d\n", end2 - start2);

    imshow("ROI_img", src);
    imshow("bg_img", dst);
    imshow("normal_clone", normal_clone);
    imshow("mixed_clone", mixed_clone);
    waitKey(0);
上面MFC上面跑起来没问题,翻译成C#版

    Mat src =Cv2.ImRead("D:/dd.jpg");
    Mat dst = Cv2.ImRead("D:/ss.jpg ");

扫描二维码关注公众号,回复: 3265691 查看本文章

    Mat src_mask = 255 * Mat.Ones(src.Size(),MatType.CV_8U);
    OpenCvSharp.Point center=new OpenCvSharp.Point(dst.Cols / 2, dst.Rows / 2);

    Mat normal_clone=new Mat();
    Mat mixed_clone=new Mat();
        Cv2.SeamlessClone(src, dst, src_mask, center, normal_clone, SeamlessCloneMethods.NormalClone);
        Cv2.SeamlessClone(src, dst, src_mask, center, mixed_clone, SeamlessCloneMethods.MixedClone);

 Cv2.ImShow("ROI_img", src);
 Cv2.ImShow("bg_img", dst);
 Cv2.ImShow("normal_clone", normal_clone);
 Cv2.ImShow("mixed_clone", mixed_clone);
 Cv2.WaitKey(0);

猜你喜欢

转载自blog.csdn.net/FL1623863129/article/details/81561937