zoukankan      html  css  js  c++  java
  • 实验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
    MVC4重复提交数据
    cache
    Nosql
    MVC4重复提交
    PHP Java
    .net performance
    How the Runtime Locates Assemblies
    android
    window.onscroll
  • 原文地址:https://www.cnblogs.com/war1111/p/13885512.html
Copyright © 2011-2022 走看看