c++求两条直线的交点

一、已知每条直线的两个点:

cv::Point2d get2lineIPoint(cv::Point2d lineOnePt1, cv::Point2d lineOnePt2, cv::Point2d lineTwoPt1, cv::Point2d lineTwoPt2)
{
    
    
	double x;
	double y;

	cv::Point2d result(-1,-1);
	double k = (lineOnePt1.y - lineOnePt2.y) / (lineOnePt1.x- lineOnePt2.x);
	double b = lineOnePt1.y - k * lineOnePt1.x;

	double k1 = (lineTwoPt1.y - lineTwoPt2.y) / (lineTwoPt1.x - lineTwoPt2.x);
	double b1 = lineTwoPt1.y - k1 * lineTwoPt1.x;

	x = (b1 - b) / (k - k1);
	y = k * x + b;
	result.x = x;
	result.y = y;

	return result;
}

测试如下:
在这里插入图片描述

二、已知每条直线的一个点和方向(点斜式直线)

cv::Point2d get2lineIPoint(cv::Vec4f lineParam1, cv::Vec4f lineParam2)
{
    
    
	//Vec4f :参数的前半部分给出的是直线的方向,而后半部分给出的是直线上的一点
	cv::Point2d result(-1, -1);

	double cos_theta = lineParam1[0];
	double sin_theta = lineParam1[1];
	double x = lineParam1[2];
	double y = lineParam1[3];
	double k = sin_theta / cos_theta;
	double b = y - k * x;

	cos_theta = lineParam2[0];
	sin_theta = lineParam2[1];
	x = lineParam2[2];
    y = lineParam2[3];
	double k1 = sin_theta / cos_theta;
	double b1 = y - k1 * x;

	result.x = (b1 - b) / (k - k1);
	result.y = k * x + b;

	return result;
}

猜你喜欢

转载自blog.csdn.net/weixin_44901043/article/details/123002562#comments_21986450