测试 Emgu CV

Mat image = CvInvoke.Imread(@"C:\Users\Hello\Pictures\123.jpg", Emgu.CV.CvEnum.ImreadModes.Unchanged);
CvInvoke.Imshow("image", image);

Mat gray = new Mat();
CvInvoke.CvtColor(image, gray, Emgu.CV.CvEnum.ColorConversion.Rgb2Gray);
CvInvoke.Threshold(gray, gray, 200, 255, Emgu.CV.CvEnum.ThresholdType.Otsu | Emgu.CV.CvEnum.ThresholdType.Binary);
CvInvoke.Imshow("gray", gray);

Mat element = CvInvoke.GetStructuringElement(Emgu.CV.CvEnum.ElementShape.Rectangle, new Size(3, 3), new Point(2, 2));
CvInvoke.Dilate(gray, gray, element, new Point(2, 2), 1, Emgu.CV.CvEnum.BorderType.Default, new Emgu.CV.Structure.MCvScalar(0));

Random rnd = new Random();
VectorOfVectorOfPoint contours = new VectorOfVectorOfPoint();
CvInvoke.FindContours(gray, contours, null, Emgu.CV.CvEnum.RetrType.Tree, Emgu.CV.CvEnum.ChainApproxMethod.ChainApproxSimple);
for (int i = 0; i < contours.Size; i++) {
    if (CvInvoke.ContourArea(contours[i]) > 100.0) {
        // Rectangle rc = CvInvoke.BoundingRectangle(contours[i]);
        // CvInvoke.Rectangle(image, rc, new MCvScalar(0, 0, 255));
        CvInvoke.DrawContours(image, contours, i,
            new MCvScalar(rnd.Next(0, 255), rnd.Next(0, 255), rnd.Next(0, 255)));
    }
}

CvInvoke.Imshow("result", image);
CvInvoke.WaitKey();

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值