我拥有一张被手机倾斜的图像。我想要在两个矩形之间裁剪图像的部分/区域,以找到它们之间的圆形。我已经获取了中间部分的所有4个坐标,例如(x0,y0),(x1,y1),(x2,y2),(x3,y3)。
但是,我现有的裁剪函数如下:
public static Bitmap CropImage(int x, int y, int width, int height, Bitmap bitmap)
{
Bitmap croppedImage;
var originalImage = bitmap;
{
Rectangle crop = new Rectangle(x, y, width, height);
croppedImage = originalImage.Clone(crop, originalImage.PixelFormat);
} // Here we release the original resource - bitmap in memory and file on disk.
return croppedImage;
}
但是上述函数将像第1个和第2个红色方框所示的部分切割成矩形。
我正在寻找代码来切割第3个红色矩形中显示的部分。我已经搜索了代码并找到了以下代码
List<IntPoint> corners = new List<IntPoint>();
corners.Add(new IntPoint(x0, y0));
corners.Add(new IntPoint(x3, y3));
corners.Add(new IntPoint(x1 + 30, y1 + 20));
corners.Add(new IntPoint(x2 + 30, y2 + 0));
AForge.Imaging.Filters.QuadrilateralTransformation filter = new AForge.Imaging.Filters.QuadrilateralTransformation(corners, WidthOfCut, HeightOfCut);
Bitmap newImage = filter.Apply(mainOuterWindow);
使用AForge.Imaging库进行裁剪,但会像下面这样切割一部分
这会扭曲圆形的形状,使其变成椭圆,并对其他计算造成问题。
请告诉我如何使用4个点裁剪图像。
或者通过传递校正角度来纠正图像的倾斜是否有任何方法?