I've been using a function file
[ret]=drawellipse(x,y,a,b,angle,steps,color,img). Calling the function through a script file to draw random ellipses in image. But once i set the random center point(x,y), and random a, b, there is high possibility that the ellipses intersection would occur. How can i prevent the intersection? (I'm supposed to draw the ellipses that are all separate from each other)
Well, over here i have a function file which is to check whether the ellipses got overlap or not,
overlap = overlap_ellipses(x0,y0,a0,b0,angle0,x1,y1,a1,b1,angle1). If the two ellipses are overlap, then the 'overlap=1', otherwise 'overlap=0'.
Based on all these, i tested in the command window:
x=rand(4,1)*400; % x and y are the random coodinates for the center of ellipses y=rand(4,1)*400; a=[50 69 30 60]; % major axis for a and b, i intend to use random also in the future b=[20 40 10 40]; % minor axis angle=[30 90 45 0]; % angle of ellipse steps=10000; color=[255 0 0]; % inputs for another function file to draw the ellipse img=zeros(500,500,3);
The following i want to dispaly the ellipses
if overlap==0, and 'if overlap==1', decrease the a and b, till there is no intersection. Lastly, to imshow the img.
for i=1:length(x) img=drawellipse(x(i),y(i),a(i),b(i),angle(i),steps,color,img); end
For me now, i have difficulty in coding the middle part. How can i use the if statement to get the value of
overlap and how to make the index corresponding to the ellipse i need to draw.
i tested a bit like
for k=1:(length(x)-1) overlap = overlap_ellipses(x(1),y(1),a(1),b(1),angle(1),x(1+k),y(1+k),a(1+k),b(1+k),angle(1+k)) end
overlap=0 overlap=0 overlap=1
it is not [0 0 1]. I can't figure it out, thus stuck in the process. The final image shoule look like the picture in this voronoi diagram of ellipses. (There is no intersection between any two ellipses)