opencv常用api

opencv常用api

截取图像

cpp 复制代码
cv::Mat pic2;
pic(cv::Rect(50, 50, 200, 200)).copyTo(pic2);
cv::imshow("Image Display2", pic2);

将图像区域复制到图像指定的区域

cpp 复制代码
pic2.copyTo(pic(cv::Rect(200, 200, 200, 200)));
cv::imshow("Image Display3", pic);

通过迭代器获取图像像素

cpp 复制代码
void ModifyColorData(cv::Mat& img , cv::Mat& out , int pixel) {
    // 通过迭代器获取图像的像素
    out = img.clone();
    cv::Mat_<cv::Vec3b>::iterator itstart = out.begin<cv::Vec3b>();
    cv::Mat_<cv::Vec3b>::iterator itend = out.end<cv::Vec3b>();
    for (; itstart != itend; itstart++) {
        (*itstart)[0] = (*itstart)[0] / pixel * pixel + pixel / 3;
        (*itstart)[1] = (*itstart)[1] / pixel * pixel + pixel / 3;
        (*itstart)[2] = (*itstart)[2] / pixel * pixel + pixel / 3;
    }
    cv::imshow("目标图像", out);
    /*
    vec3b
    * 全部类型为 cv::Vec{2,3,4,6,8}{b,d,f,i,s,w}
    * 其中数字2,3,4,6,8表示列向量的长度
    * 字母 b ,d , f, i ,s ,w表示类型
    * b-->uchar , d-_>double , f-->float , i-->int , s-->showt , w-->ushort
    * 数字和类型之间的组合,构成不同的Vec向量
    */
}

绘制直线

cpp 复制代码
void drawLine(cv::Mat& img) {
    // 定义点  ,第一种方式
    cv::Point p1 = cv::Point(20, 30);
    // 定义点  ,第二种方式
    cv::Point p2;
    p2.x = 250;
    p2.y = 30;
    // 定义线的颜色
    cv::Scalar myColor = cv::Scalar(0,0,255); // bgr
    // 在背景绘制线条
    cv::line(img, p1, p2, myColor , 5 , cv::LINE_8);  // cv::LINE_8
}

绘制矩形

cpp 复制代码
void drawrectangle(cv::Mat& img) {
    cv::Rect rect = cv::Rect(50, 50, 250, 300);
    // 设置颜色
    cv::Scalar color = cv::Scalar(255, 0, 0);
    cv::rectangle(img, rect, color, 3, cv::LINE_8);
}

绘制圆

cpp 复制代码
void drawcircle(cv::Mat& img) {
    // 确定圆心
    cv::Point point = cv::Point(img.cols / 2, img.rows / 2);
    // 设置颜色
    cv::Scalar color = cv::Scalar(0, 255, 0);
    // 绘制园
    cv::circle(img, point, 100, color, 2 , cv::LINE_8);
}

绘制椭圆

cpp 复制代码
void drawellipse(cv::Mat& img) {
    // 确定圆心
    cv::Point point = cv::Point(img.cols / 2, img.rows / 2);
    // 设置颜色
    cv::Scalar color = cv::Scalar(0, 255, 255);
    cv::ellipse(img , point , cv::Size(20, 50) , 0 , 0 , 360 , color);
}

绘制多边形

cpp 复制代码
void drawpolyline(cv::Mat& img) {
    // 定义多边形的顶点坐标
    std::vector<cv::Point> pts;
    pts.push_back(cv::Point(50, 50));
    pts.push_back(cv::Point(200, 50));
    pts.push_back(cv::Point(200, 200));
    pts.push_back(cv::Point(50, 200));
    cv::polylines(img , pts , true , cv::Scalar(0, 255, 0) , 3 , cv::LINE_8);
}
相关推荐
B博士25 分钟前
科研进展 | JAG: 大光斑高光谱激光雷达遥感辐射传输模型从垂直视角解锁森林叶绿素分布密码
人工智能·jag·高光谱激光雷达·森林分层叶绿素诊断
Yao.Li1 小时前
PVN3D ORT CUDA Custom Ops 实现与联调记录
人工智能·3d·具身智能
诺伦1 小时前
LocalClaw 在智能制造的新机会:6部门AI+电商政策下的工厂AI升级方案
人工智能·制造
小陈工3 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
墨染天姬8 小时前
【AI】端侧AIBOX可以部署哪些智能体
人工智能
AI成长日志8 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
2501_948114248 小时前
2026年大模型API聚合平台技术评测:企业级接入层的治理演进与星链4SAPI架构观察
大数据·人工智能·gpt·架构·claude
小小工匠8 小时前
LLM - awesome-design-md 从 DESIGN.md 到“可对话的设计系统”:用纯文本驱动 AI 生成一致 UI 的新范式
人工智能·ui
黎阳之光8 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
小超同学你好8 小时前
面向 LLM 的程序设计 6:Tool Calling 的完整生命周期——从定义、决策、执行到观测回注
人工智能·语言模型