当前位置: 首页 > article >正文

加强版第十七章空间色彩转换

API:cvtColor(frame, hsv, COLOR_BGR2HSV);



将视频进行空间色彩转换

#include<opencv2/opencv.hpp>
#include<iostream>
using namespace std;
using namespace cv;
int main(int argv, char** argc) {
    //VideoCapture capture(0);
    
    VideoCapture capture("C:/newword/image/21.mp4");
       if (!capture.isOpened()) {
           printf("0");
        }
       namedWindow("frame", WINDOW_AUTOSIZE);
       int fps = capture.get(CAP_PROP_FPS);
       int width = capture.get(CAP_PROP_FRAME_WIDTH);
       int heigh = capture.get(CAP_PROP_FRAME_HEIGHT);
       int num_of_frame = capture.get(CAP_PROP_FRAME_COUNT);
       int type = capture.get(CAP_PROP_FOURCC);
       printf("frame size(f=%d,w=%d,h=%d,m=%d)", fps, width, heigh, num_of_frame);
        

       Mat frame,hsv;
       VideoWriter writer("C:/newword/image/232320.mp4", type, fps, Size(width, heigh), true);
       while (true) {
           bool ret = capture.read(frame);
           if (!ret)break;
           imshow("ret", frame);
           cvtColor(frame, hsv, COLOR_BGR2HSV);
           imshow("hsv",hsv);
           writer.write(frame);
           char c = waitKey(50);
           if (c == 27) {
               break;
           }
       }
       waitKey(0);
           destroyAllWindows();
}
 



API:inRange(hsv, Scalar(35, 43, 46), Scalar(77, 255, 255), mask);根据bgr修改高低值

API:bitwise_not(mask, mask);取反

API:bitwise_and(frame, frame, result, mask);根据mask来将人物提取出来



将视频转化为白底黑色人物后取反

#include<opencv2/opencv.hpp>
#include<iostream>
using namespace std;
using namespace cv;
int main(int argv, char** argc) {
    //VideoCapture capture(0);
    
    VideoCapture capture("C:/newword/image/21.mp4");
       if (!capture.isOpened()) {
           printf("0");
        }
       namedWindow("frame", WINDOW_AUTOSIZE);
       int fps = capture.get(CAP_PROP_FPS);
       int width = capture.get(CAP_PROP_FRAME_WIDTH);
       int heigh = capture.get(CAP_PROP_FRAME_HEIGHT);
       int num_of_frame = capture.get(CAP_PROP_FRAME_COUNT);
       int type = capture.get(CAP_PROP_FOURCC);
       printf("frame size(f=%d,w=%d,h=%d,m=%d)", fps, width, heigh, num_of_frame);
        

       Mat frame,hsv,mask;
       VideoWriter writer("C:/newword/image/232320.mp4", type, fps, Size(width, heigh), true);
       while (true) {
           bool ret = capture.read(frame);
           if (!ret)break;
           imshow("ret", frame);
           cvtColor(frame, hsv, COLOR_BGR2HSV);
           inRange(hsv, Scalar(35, 43, 46), Scalar(77, 255, 255), mask):

          bitwise_not(mask, mask);
        bitwise_and(frame, frame, result, mask);

           imshow("mask", mask);
           imshow("hsv",hsv);
           writer.write(frame);
           char c = waitKey(50);
           if (c == 27) {
               break;
           }
       }
       waitKey(0);
           destroyAllWindows();
}


http://www.kler.cn/a/455537.html

相关文章:

  • 【连续学习之SSL算法】2018年论文Selfless sequential learning
  • 【Python系列】Python 连接 PostgreSQL 数据库并查询数据
  • VUE3+VITE简单的跨域代理配置
  • C语言----变量与常量
  • Vue.js组件开发-实现访问页面自动获取数据
  • 使用sam进行零样本、零学习的分割实践
  • 水电站视频智能监控系统方案设计与技术应用方案
  • 高频生活场景带动低频金融服务,美团企业版点燃场景金融建设引擎
  • Network Slice | Android 网络切片流程简介和日志分析
  • 【模电刷题复习--填空】
  • 04软件测试需求分析案例-用户登录
  • Word批量更改公式字体为Times New Roman
  • 领域自适应
  • 掌握Docker命令与Dockerfile实战技巧:快速构建高效容器化应用
  • 网络攻防环境搭建
  • 探索寄存器读写函数:writeb, writew, writel 与 readb, readw, readl
  • Debian系统宝塔面板安装LiteSpeed Memcached(LSMCD)
  • 5、栈应用-表达式求值
  • VSCode搭建Java开发环境 2024保姆级安装教程(Java环境搭建+VSCode安装+运行测试+背景图设置)
  • 如何安全获取股票实时数据API并在服务器运行?
  • Microsoft word@【标题样式】应用不生效(主要表现为在导航窗格不显示)
  • React里使用lodash工具库
  • 嵌入式学习-QT-Day05
  • 【2024年最新】BilibiliB站视频动态评论爬虫
  • Docker-构建自己的Web-Linux系统-镜像webtop:ubuntu-kde
  • 时空信息平台-运维篇:线上监控诊断Java服务、服务部署指引