/// <summary>
/// 图像旋转
/// </summary>
private Mat MatRotate(Mat src, float angle)
{
Mat dst = new Mat();
Point2f center = new Point2f(src.Cols / 2, src.Rows / 2);
Mat rot = Cv2.GetRotationMatrix2D(center, angle, 1);
Size2f s2f = new Size2f(src.Size().Width, src.Size().Height);
OpenCvSharp.Rect box = new RotatedRect(new Point2f(0, 0), s2f, angle).BoundingRect();
double xx = rot.At<double>(0, 2) + box.Width / 2 - src.Cols / 2;
double zz = rot.At<double>(1, 2) + box.Height / 2 - src.Rows / 2;
rot.Set(0, 2, xx);
rot.Set(1, 2, zz);
Cv2.WarpAffine(src, dst, rot, box.Size);
Cv2.ImShow("output", dst);
return dst;
}
OpenCVSharp图片旋转
最新推荐文章于 2024-01-17 13:43:46 发布