• 实验7.1


    #include <bits/stdc++.h>
    #include "opencv2/core.hpp"
    #include "opencv2/imgproc.hpp"
    #include "opencv2/video.hpp"
    #include "opencv2/objdetect.hpp"
    #include "opencv2/imgcodecs.hpp"
    #include "opencv2/highgui.hpp"
    #include "opencv2/ml.hpp"
    #define inf 2333333333333333
    #define N 100010
    #define p(a) putchar(a)
    #define For(i,a,b) for(int i=a;i<=b;++i)
    //by war
    //2020.10.27
    using namespace std;
    using namespace cv;
    int n,k;
    Mat image,img0,out,labels,stats,centroids;
    void in(int &x){
        int y=1;char c=getchar();x=0;
        while(c<'0'||c>'9'){if(c=='-')y=-1;c=getchar();}
        while(c<='9'&&c>='0'){ x=(x<<1)+(x<<3)+c-'0';c=getchar();}
        x*=y;
    }
    void o(int x){
        if(x<0){p('-');x=-x;}
        if(x>9)o(x/10);
        p(x%10+'0');
    }
    
    signed main(){
        srand(time(0));
        img0 = imread("/Users/war/Downloads/1.png",0);
        threshold(img0, image, 128, 255, THRESH_BINARY);
        n=connectedComponentsWithStats(image, labels, stats, centroids);
        vector<Vec3b> v(n+1);
        v[0]=Vec3b(rand()%256,rand()%256,rand()%256);
        For(i,1,n){
            v[i]=Vec3b(rand()%256,rand()%256,rand()%256);
            if(stats.at<int>(i,CC_STAT_AREA)<10000) v[i]=v[0];
        }
        out=Mat::zeros(image.size(),CV_8UC3);
        For(i,0,out.rows-1)
            For(j,0,out.cols-1){
                k=labels.at<int>(i,j);
                out.at<Vec3b>(i,j)=v[k];
            }
        imshow("out",out);
        waitKey();
        return 0;
    }
  • 相关阅读:
    java中next()、nextInt()、nextLine()区别
    原码、反码、补码及移位运算
    微信小程序开发流程(适用于新手学习)
    Dubbo 常用的容错机制
    分布式系统性能注意点
    陌上人如玉,公子世无双!
    五步工作法
    四个凡是
    Javacpu 和内存问题排查步骤
    开启JMC功能
  • 原文地址:https://www.cnblogs.com/war1111/p/13885512.html
Copyright © 2020-2023  润新知