How to crop a square that has a rotational angle?

2 ビュー (過去 30 日間)
Guilherme Pelegrini
Guilherme Pelegrini 2017 年 3 月 9 日
回答済み: Image Analyst 2022 年 4 月 19 日
I need to crop one square of this image:
As you can see, I can't use imcrop() because it isn't horizontal, the squares has a rotational angle, and the region cropped need to be precisely on the edge of the line.
How can I do it?

回答 (3 件)

Massimo Zanetti
Massimo Zanetti 2017 年 3 月 9 日
編集済み: Massimo Zanetti 2017 年 3 月 9 日
Inspect this: roipoly
Here is an example of what you can do:
%open an image
A = imread('coins.png');
%run roi tool, where you can define your polygon
BW = roipoly(A);
%extract image pixels in the roi
S = regionprops(BW,'ConvexImage','BoundingBox');
r = S.BoundingBox;
Q = A( round(r(2)) + (1:r(4)) , round(r(1)) + (1:r(3)) );
%display cropped image
im = imagesc(Q);
im.AlphaData = S.ConvexImage;
axis image; colormap gray;
In the roipoly window track your points manually to define a polygon, as in the picture:
Then, right-click and "Create Mask", you will get your cropped image:
  1 件のコメント
Selina
Selina 2019 年 4 月 1 日
Hi,
Is it possible to use rectangle crop using the ROI function? If so, can anyone please send a sample coding?

サインインしてコメントする。


cui,xingxing
cui,xingxing 2022 年 3 月 5 日
I wrote an enhanced 'imcrop' function that supports rotating rectangle interception, but yours is an irregular quadrilateral, but you can also refer to what I wrote with 'estimateGeometricTransform2D' to estimate the conversion matrix, and then bring in the 'imwarp' function can be completed arbitrary shape interception, I hope it helps you

Image Analyst
Image Analyst 2022 年 4 月 19 日
If you need to find the white lines automatically, you can try hough(), houghlines(), or radon().
I'm attaching a demo for how to use the radon transform to find the angle or rotation, and then it uses imrotate() to rotate the image until it's straight. Adapt as needed.

カテゴリ

Help Center および File ExchangeGeometric Transformation and Image Registration についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by