zoukankan      html  css  js  c++  java
  • opencv3.3.1+vs2015+c++实现直接在图像上画掩码,保存掩码图片

    左键红右键蓝,保存为k

    #include "opencv2imgprocimgproc.hpp"  // Gaussian Blur
    #include "opencv2corecore.hpp"        // Basic OpenCV structures (cv::Mat, Scalar)
    #include <opencv2highguihighgui.hpp> // OpenCV window I/O
    #include <iostream> // for standard I/O
    #include <string>   // for strings
    #include <iomanip>  // for controlling float print precision
    #include <sstream>  // string to number conversion
    using namespace  cv;
    using namespace  std;
    bool rButtonDown = false; bool lButtonDown = false; int numUsedBins = 0; float varianceSquared = 0; int scribbleRadius = 10; Mat inputImg = imread("0.jpg", 3), showImg = imread("0.jpg", 3); Mat fgScribbleMask; Mat bgScribbleMask; static void onMouse(int event, int x, int y, int, void*) { cout << "On Mouse: (" << x << "," << y << ")" <<endl; if (event == CV_EVENT_LBUTTONDOWN) { lButtonDown = true; } else if (event == CV_EVENT_RBUTTONDOWN) { rButtonDown = true; } else if (event == CV_EVENT_LBUTTONUP) { lButtonDown = false; } else if (event == CV_EVENT_RBUTTONUP) { rButtonDown = false; } else if (event == CV_EVENT_MOUSEMOVE) { if (rButtonDown) { // scribble the background circle(bgScribbleMask, Point(x, y), scribbleRadius, 255, -1); circle(showImg, Point(x, y), scribbleRadius, CV_RGB(0, 0, 255), -1); } else if (lButtonDown) { // scribble the foreground circle(showImg, Point(x, y), scribbleRadius, CV_RGB(255, 0, 0), -1); circle(fgScribbleMask, Point(x, y), scribbleRadius, 255, -1); } } imshow("draw", showImg); imshow("fg mask", fgScribbleMask); imshow("bg mask", bgScribbleMask); } int main() { bgScribbleMask.create(2, inputImg.size, CV_8UC1); bgScribbleMask = 0; fgScribbleMask.create(2, inputImg.size, CV_8UC1); fgScribbleMask = 0; namedWindow("draw"); imshow("draw", showImg); namedWindow("input"); imshow("input", inputImg); setMouseCallback("draw", onMouse, 0); while (1) {   char key = waitKey(0);   if (key == 'k') { imwrite("1123.jpg", fgScribbleMask); cout << "successed"; } } }

      

  • 相关阅读:
    1365 Fib(N) mod Fib(K) [斐波那契相关]
    51nod1439 互质对 [莫比乌斯函数, 容斥]
    UVA1642 魔法GCD Magical GCD [gcd, 双向链表]
    李超线段树学习笔记 [模板]
    P4297 [NOI2006]网络收费 [树形dp]
    田忌赛马 [贪心(完成) / 动态规划(待填坑)]
    菌落 [状压dp?]
    异或约数和 [异或相关]
    java 驼峰命名
    java 静态构造函数
  • 原文地址:https://www.cnblogs.com/l2017/p/8371124.html
Copyright © 2011-2022 走看看