OpenCV绘制标记函数drawMarker()
时间:2022-07-24
本文章向大家介绍OpenCV绘制标记函数drawMarker(),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
OpenCV绘制标记函数drawMarker(),作用是在给定位置绘制一个标记,以OpenCV4.4.0为例:
https://docs.opencv.org/4.4.0/d6/d6e/group__imgproc__draw.html#ga644c4a170d4799a56b29f864ce984b7e
如下是C++ OpenCV 测试代码与效果:
#include <iostream>
#include <opencv2/opencv.hpp>
using namespace std;
using namespace cv;
int main()
{
Mat img = Mat::zeros(300, 300, CV_8UC3);
drawMarker(img, Point(30, 30), Scalar(0, 255, 0), MarkerTypes::MARKER_CROSS, 20, 2, 8);
drawMarker(img, Point(50, 50), Scalar(0, 0, 255), MarkerTypes::MARKER_TILTED_CROSS, 20, 2, 8);
drawMarker(img, Point(80, 80), Scalar(255, 0, 0), MarkerTypes::MARKER_STAR, 20, 2, 8);
drawMarker(img, Point(110, 110), Scalar(0, 255, 255), MarkerTypes::MARKER_DIAMOND, 20, 2, 8);
drawMarker(img, Point(150, 150), Scalar(255, 255, 0), MarkerTypes::MARKER_SQUARE, 20, 2, 8);
drawMarker(img, Point(180, 180), Scalar(255, 0, 255), MarkerTypes::MARKER_TRIANGLE_UP, 20, 2, 8);
drawMarker(img, Point(210, 210), Scalar(0, 255, 0), MarkerTypes::MARKER_TRIANGLE_DOWN, 20, 2, 8);
imshow("drawMarker", img);
waitKey(0);
return 0;
}
标记大小markerSize指标记的轴长,默认值20像素,可以根据自己的需要修改。一般我们在物体计数的时候经常使用十字标注物体来计数,比如下面简单的药片计数,将每个药片用十字标记,可以直接用drawMarker函数,下面例子比较简单,根据颜色提取每个药片轮廓,然后标记计数,本文重点在介绍drawMarker函数,故没有找比较粘连的药片实例,效果如下:
本例完整代码与素材将发布在知识星球主题中,欢迎关注。
- 通俗理解决策树中的熵&条件熵&信息增益
- KNN实现手写数字识别
- softmax分类算法原理(用python实现)
- DeepLearning.ai学习笔记(一)神经网络和深度学习--Week4深层神经网络
- 博客园自定义皮肤扁平化设计
- DeepLearning.ai学习笔记(四)卷积神经网络 -- week3 目标检测
- DeepLearning.ai学习笔记(四)卷积神经网络 -- week2深度卷积神经网络 实例探究
- DeepLearning.ai学习笔记(四)卷积神经网络 -- week1 卷积神经网络基础知识介绍
- Udacity并行计算课程笔记-The GPU Hardware and Parallel Communication Patterns
- DeepLearning.ai学习笔记(三)结构化机器学习项目--week2机器学习策略(2)
- DeepLearning.ai学习笔记(三)结构化机器学习项目--week1 机器学习策略
- coursera 视频总是缓冲或者无法观看的解决办法
- DeepLearning.ai学习笔记(二)改善深层神经网络:超参数调试、正则化以及优化--week3 超参数调试、Batch正则化和程序框架
- DeepLearning.ai学习笔记(一)神经网络和深度学习--Week3浅层神经网络
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法