How to scan a circle that is drawn over an image object?

3 ビュー (過去 30 日間)
Zara Khan
Zara Khan 2018 年 7 月 14 日
コメント済み: Zara Khan 2018 年 7 月 15 日
A circle is drawn over a binary image object using plot. After this drawn I again want to scan this circle and want to store its circumference coordinates points to an array. How to do that?
  4 件のコメント
Walter Roberson
Walter Roberson 2018 年 7 月 14 日
編集済み: Walter Roberson 2018 年 7 月 14 日
Quantize the coordinates to integers, and take the unique pairs. No drawing required. If you need them in order, you can use boundary() or you can subtract the centroid so that the points circle the centroid, and then convert to polar coordinates, and sort by angle.
Zara Khan
Zara Khan 2018 年 7 月 14 日
編集済み: Zara Khan 2018 年 7 月 14 日
I have got my unique points and this is forming a straight line . I am not getting any circle. How to resolve this ?

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

採用された回答

Image Analyst
Image Analyst 2018 年 7 月 14 日
The form or size of the image below doesn't matter. It could be binary (with various irregularly shaped blobs in it), RGB, gray scale, whatever - it just doesn't matter.
Since you already have your (x,y) points of the "circle" (because you plotted them), if they're not already your circumference points (like it's a wiggly circle instead of a perfect circle), then you can fit a circle to what you have to get the "perfect" circle radius and center using the FAQ: https://matlab.wikia.com/wiki/FAQ#How_can_I_fit_a_circle_to_a_set_of_XY_data.3F
Now once you have the perfect circle, you can regenerate the perfect circle coordinates. Call round() on them if you want to quantize them to integer row, column values.
  6 件のコメント
Image Analyst
Image Analyst 2018 年 7 月 14 日
The just call poly2mask() with your x,y coordinates, and get an image, then just call bwboundaries() on that image. Done. Simple.
Zara Khan
Zara Khan 2018 年 7 月 15 日
Thank you I am done.

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

その他の回答 (0 件)

Community Treasure Hunt

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

Start Hunting!

Translated by