## 自定义检测五角星算子

自定义检测五角星算子

本算子通过自定义多项式拟合的参数来确定图像中的图形形状
#include "Ptest.h"
#include <QRect>
#include<opencv2/opencv.hpp>

void drawpp(cv::Mat &result, cv::Mat &img2)
{
	for (int i = 0; i < result.rows; i++)
	{
		if (i == result.rows - 1)
		{
			cv::Vec2i point1 = result.at<cv::Vec2i>(i);
			cv::Vec2i point2 = result.at<cv::Vec2i>(0);
			line(img2, point1, point2, cv::Scalar(0, 0, 255), 2, 8, 0);
			break;
		}
		cv::Vec2i point1 = result.at<cv::Vec2i>(i);
		cv::Vec2i point2 = result.at<cv::Vec2i>(i + 1);
		line(img2, point1, point2, cv::Scalar(0, 0, 255), 2, 8, 0);
	}

}
int a_fiveStar(aAlgoFunc &func)
{


	std::map<std::string, aParam> lstParams = func.lstParams;///算法函数参数

	std::map<std::string, inputParamS> inputsMap = func.lstInputs;///输入

	//再定义一个参数,用以定义函数的
	cv::Mat srcImg = inputsMap["src"].img.clone();///图片特殊取出

	int param1 = lstParams["param1"].varParam.toInt();
	int param2 = lstParams["param2"].varParam.toInt();
	int param3 = lstParams["param3"].varParam.toInt();
	//Mat srcImg = imread("C:\\Users\\rsopto\\Desktop\\img_practice\\test1.png");
	imshow("src", srcImg);

	//灰度图,平滑滤波,二值化
	cv::Mat gray, binary;
	cvtColor(srcImg, gray, cv::COLOR_RGB2GRAY);
	GaussianBlur(gray, gray, cv::Size(13, 13), 4, 4);
	threshold(gray, binary, 60, 255, cv::THRESH_BINARY | cv::THRESH_OTSU);

	//轮廓发现与绘制
	std::vector<std::vector<cv::Point>> contours;
	std::vector<cv::Vec4i> hierarcy;
	findContours(binary, contours, hierarcy, cv::RETR_TREE, cv::CHAIN_APPROX_SIMPLE, cv::Point());
	//绘制多边形
	for (int i = 0; i < contours.size(); i++)
	{
		//轮廓中心
		cv::RotatedRect rrect = cv::minAreaRect(contours[i]);
		cv::Point2f center = rrect.center;
		cv::Mat result;
		cv::approxPolyDP(contours[i], result,param3 , true);          //用以输入多边形拟合的精度
		drawpp(result, srcImg);
		//cout << result.rows << endl;

		if (result.rows > param1 && result.rows < param2)
		{
			cv::putText(srcImg, "five-pointed star", center, 0, 0.5, cv::Scalar(0, 255, 0), 1, 4);
		}
	}
	func.lstOutputs["dst"].img = srcImg.clone();///图片特殊取出
	return 0;

}

std::map<std::string, funStruct> Ptest::getDescription()
{
	std::map<std::string, funStruct> map;
	aAlgoFunc afun;
	afun.funcName = "a_fiveStar";  ///函数名,需要与定义一样!
	afun.displayName = "检测五角星";   ///函数的显示名
	afun.info = "本算子可以检测出图像中的五角星";///函数的详细说明
	std::map<std::string, aParam> paraMap;
	makeParam(paraMap, "param1", "输入多边形拟合的参数", "这个参数用以表示多边形边数的两个阈值,参数1表示下限", QVariant::Int, 9);///参数名,显示名,参数详细说明,参数类型
	makeParam(paraMap, "param2", "多边形顶点判断的条件阈值", "这个条件可以用以判断是否为五角星,同时,不同的条件也可以判断出不同的形状,如圆 三角形等", QVariant::Int, 15);
	makeParam(paraMap, "param3", "多边形顶点判断的条件阈值", "这个条件可以用以判断是否为五角星,同时,不同的条件也可以判断出不同的形状,如圆 三角形等", QVariant::Int, 15);

	std::map<std::string, inputParamS> lstInputs;
	makeInputs(lstInputs, "src", "输入图", "要处理的图片", QVariant::Image);

	std::map<std::string, outputParamS> lstOutputs;
	makeOutputs(lstOutputs, afun.displayName, "dst", "标定好五角星的图片", "结果图片", QVariant::Image);

	afun.lstParams = paraMap;
	afun.lstInputs = lstInputs;
	afun.lstOutputs = lstOutputs;
	afun.type = typeChangyong;
	funStruct funS;
	funS.funDescription = afun;
	funS.funPtr = a_fiveStar;
	map[afun.funcName] = funS;

	return map;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个用Kotlin语言自定义五角星View的示例: ```kotlin import android.content.Context import android.graphics.Canvas import android.graphics.Paint import android.util.AttributeSet import android.view.View class StarView(context: Context, attrs: AttributeSet) : View(context, attrs) { private val paint = Paint() private var starSize = 0f private var starColor = 0 init { paint.isAntiAlias = true paint.style = Paint.Style.FILL val typedArray = context.obtainStyledAttributes(attrs, R.styleable.StarView) starSize = typedArray.getDimension(R.styleable.StarView_starSize, 0f) starColor = typedArray.getColor(R.styleable.StarView_starColor, 0) typedArray.recycle() } override fun onDraw(canvas: Canvas?) { super.onDraw(canvas) canvas?.let { val centerX = width / 2f val centerY = height / 2f val outerRadius = starSize / 2f val innerRadius = outerRadius / 2.63f val rotationAngle = Math.PI / 2 val points = arrayOf( Pair(centerX, centerY - outerRadius), Pair(centerX + innerRadius * Math.cos(rotationAngle).toFloat(), centerY - innerRadius * Math.sin(rotationAngle).toFloat()), Pair(centerX + outerRadius * Math.cos(rotationAngle / 2).toFloat(), centerY - outerRadius * Math.sin(rotationAngle / 2).toFloat()), Pair(centerX + innerRadius * Math.cos(rotationAngle / 2 * 3).toFloat(), centerY - innerRadius * Math.sin(rotationAngle / 2 * 3).toFloat()), Pair(centerX + outerRadius * Math.cos(rotationAngle * 2).toFloat(), centerY - outerRadius * Math.sin(rotationAngle * 2).toFloat()), Pair(centerX, centerY + innerRadius), Pair(centerX - outerRadius * Math.cos(rotationAngle * 2).toFloat(), centerY - outerRadius * Math.sin(rotationAngle * 2).toFloat()), Pair(centerX - innerRadius * Math.cos(rotationAngle / 2 * 3).toFloat(), centerY - innerRadius * Math.sin(rotationAngle / 2 * 3).toFloat()), Pair(centerX - outerRadius * Math.cos(rotationAngle / 2).toFloat(), centerY - outerRadius * Math.sin(rotationAngle / 2).toFloat()), Pair(centerX - innerRadius * Math.cos(rotationAngle).toFloat(), centerY - innerRadius * Math.sin(rotationAngle).toFloat()) ) paint.color = starColor canvas.drawVertices( Canvas.VertexMode.TRIANGLE_FAN, points.size, points.flatMap { listOf(it.first, it.second) }.toFloatArray(), 0, null, 0, null, 0, null, 0, 0, paint ) } } fun setStarSize(starSize: Float) { this.starSize = starSize invalidate() } fun setStarColor(starColor: Int) { this.starColor = starColor invalidate() } } ``` 这个自定义View继承自Android中的View类,并覆盖了onDraw方法来绘制五角星。 在构造函数中初始化了一个Paint对象,并从属性集中读取了星星的大小和颜色。在onDraw方法中,我们首先计算了五角星的十个点的坐标,然后使用Canvas.drawVertices方法来绘制五角星。 最后,我们在自定义View中提供了两个setter方法,可以动态地改变星星的大小和颜色。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值