瀏覽代碼

added main

Animal 4 年之前
當前提交
99552604ac
共有 1 個文件被更改,包括 280 次插入0 次删除
  1. 280 0
      main.cpp

+ 280 - 0
main.cpp

@@ -0,0 +1,280 @@
+#include "opencv2/highgui/highgui.hpp"
+#include "opencv2/imgproc/imgproc.hpp"
+#include "opencv2/imgcodecs.hpp"
+#include <iostream>
+#include <stdio.h>
+#include <stdlib.h>
+
+using namespace cv;
+using namespace std;
+
+Mat src; Mat src_gray;
+int thresh = 100;
+int max_thresh = 255;
+RNG rng(12345);
+
+/// Function header
+void thresh_callback(int, void* );
+
+/** @function main */
+int main( int argc, char** argv )
+{
+  /// Load source image and convert it to gray
+  src = imread( "C:\\Users\\Sky\\Downloads\\photo.jpg", IMREAD_COLOR );
+
+  /// Convert image to gray and blur it
+  cvtColor( src, src_gray, COLOR_BGR2GRAY );
+  blur( src_gray, src_gray, Size(3,3) );
+
+  /// Create Window
+  char* source_window = "Source";
+  namedWindow( source_window, WINDOW_AUTOSIZE );
+  imshow( source_window, src );
+
+  createTrackbar( " Canny thresh:", "Source", &thresh, max_thresh, thresh_callback );
+  thresh_callback( 0, 0 );
+
+  waitKey(0);
+  return(0);
+}
+
+/** @function thresh_callback */
+void thresh_callback(int, void* )
+{
+  Mat canny_output;
+  vector<vector<Point> > contours;
+  vector<Vec4i> hierarchy;
+
+  /// Detect edges using canny
+  Canny( src_gray, canny_output, thresh, thresh*2, 3 );
+  /// Find contours
+  findContours( canny_output, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE, Point(0, 0) );
+
+  /// Draw contours
+  Mat drawing = Mat::zeros( canny_output.size(), CV_8UC3 );
+  for( int i = 0; i < contours.size(); i++ )
+     {
+       Scalar color = Scalar( rng.uniform(0, 255), rng.uniform(0,255), rng.uniform(0,255) );
+       drawContours( drawing, contours, i, color, 2, 8, hierarchy, 0, Point() );
+     }
+
+  /// Show in a window
+  namedWindow( "Contours", WINDOW_AUTOSIZE );
+  imshow( "Contours", drawing );
+}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+//#include "opencv2/imgproc.hpp"
+//#include "opencv2/imgcodecs.hpp"
+//#include "opencv2/highgui.hpp"
+//#include <iostream>
+//using namespace cv;
+//using std::cout;
+//int threshold_value = 0;
+//int threshold_type = 3;
+//int const max_value = 255;
+//int const max_type = 4;
+//int const max_binary_value = 255;
+//Mat src, src_gray, dst;
+//const char* window_name = "Threshold Demo";
+//const char* trackbar_type = "Type: \n 0: Binary \n 1: Binary Inverted \n 2: Truncate \n 3: To Zero \n 4: To Zero Inverted";
+//const char* trackbar_value = "Value";
+//static void Threshold_Demo( int, void* )
+//{
+//    /* 0: Binary
+//     1: Binary Inverted
+//     2: Threshold Truncated
+//     3: Threshold to Zero
+//     4: Threshold to Zero Inverted
+//    */
+//    threshold( src_gray, dst, threshold_value, max_binary_value, threshold_type );
+//    imshow( window_name, dst );
+//}
+//int main( int argc, char** argv )
+//{
+//    String imageName("C:\\Users\\Sky\\Downloads\\photo.jpg"); // by default
+//    if (argc > 1)
+//    {
+//        imageName = argv[1];
+//    }
+//    src = imread( samples::findFile( imageName ), IMREAD_COLOR ); // Load an image
+//    if (src.empty())
+//    {
+//        cout << "Cannot read the image: " << imageName << std::endl;
+//        return -1;
+//    }
+//    cvtColor( src, src_gray, COLOR_BGR2GRAY ); // Convert the image to Gray
+//    namedWindow( window_name, WINDOW_AUTOSIZE ); // Create a window to display results
+//    createTrackbar( trackbar_type,
+//                    window_name, &threshold_type,
+//                    max_type, Threshold_Demo ); // Create a Trackbar to choose type of Threshold
+//    createTrackbar( trackbar_value,
+//                    window_name, &threshold_value,
+//                    max_value, Threshold_Demo ); // Create a Trackbar to choose Threshold value
+//    Threshold_Demo( 0, 0 ); // Call the function to initialize
+//    waitKey();
+//    return 0;
+//}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+//#include <iostream>
+//#include <sstream>
+//#include <opencv2/imgcodecs.hpp>
+//#include <opencv2/imgproc.hpp>
+//#include <opencv2/videoio.hpp>
+//#include <opencv2/highgui.hpp>
+//#include <opencv2/video.hpp>
+
+
+//using namespace cv;
+//using namespace std;
+
+
+//const char* params
+//    = "{ help h         |           | Print usage }"
+//      "{ input          | C:\\Users\\Sky\\Downloads\\Umka video\\Umka video\\1_light.mp4 | Path to a video or a sequence of image }"
+//      "{ algo           | MOG2      | Background subtraction method (KNN, MOG2) }";
+//int main(int argc, char* argv[])
+//{
+//    CommandLineParser parser(argc, argv, params);
+//    parser.about( "This program shows how to use background subtraction methods provided by "
+//                  " OpenCV. You can process both videos and images.\n" );
+//    if (parser.has("help"))
+//    {
+//        //print help information
+//        parser.printMessage();
+//    }
+//    //create Background Subtractor objects
+//    Ptr<BackgroundSubtractor> pBackSub;
+//    if (parser.get<String>("algo") == "MOG2")
+//        pBackSub = createBackgroundSubtractorMOG2();
+//    else
+//        pBackSub = createBackgroundSubtractorKNN();
+//    VideoCapture capture( samples::findFile( parser.get<String>("input") ) );
+//    if (!capture.isOpened()){
+//        //error in opening the video input
+//        cerr << "Unable to open: " << parser.get<String>("input") << endl;
+//        return 0;
+//    }
+//    Mat frame, fgMask;
+//    while (true) {
+//        capture >> frame;
+//        if (frame.empty())
+//            break;
+//        //update the background model
+//        pBackSub->apply(frame, fgMask);
+//        //get the frame number and write it on the current frame
+//        rectangle(frame, cv::Point(10, 2), cv::Point(100,20),
+//                  cv::Scalar(255,255,255), -1);
+//        stringstream ss;
+//        ss << capture.get(CAP_PROP_POS_FRAMES);
+//        string frameNumberString = ss.str();
+//        putText(frame, frameNumberString.c_str(), cv::Point(15, 15),
+//                FONT_HERSHEY_SIMPLEX, 0.5 , cv::Scalar(0,0,0));
+//        //show the current frame and the fg masks
+//        imshow("Frame", frame);
+//        imshow("FG Mask", fgMask);
+//        //get the input from the keyboard
+//        int keyboard = waitKey(30);
+//        if (keyboard == 'q' || keyboard == 27)
+//            break;
+//    }
+//    return 0;
+//}
+