129 |
|
double y1 |
130 |
|
) |
131 |
|
{ |
132 |
– |
static char ill_crop[] = "zero crop area"; |
132 |
|
static char ill_hemi[] = "illegal crop for hemispherical view"; |
133 |
|
double d; |
134 |
|
/* order crop extrema */ |
135 |
|
if (x0 > x1) { d=x0; x0=x1; x1=d; } |
136 |
|
if (y0 > y1) { d=y0; y0=y1; y1=d; } |
137 |
|
|
138 |
< |
d = x1 - x0; |
139 |
< |
if (d == .0) |
140 |
< |
return(ill_crop); |
141 |
< |
if (!FABSEQ(d, 1.)) /* adjust horizontal size? */ |
138 |
> |
if ((x1-x0 <= FTINY) | (y1-y0 <= FTINY)) |
139 |
> |
return("zero crop area"); |
140 |
> |
|
141 |
> |
d = x1 - x0; /* adjust horizontal size? */ |
142 |
> |
if (!FABSEQ(d, 1.)) |
143 |
|
switch (v->type) { |
144 |
|
case VT_PER: |
145 |
|
v->horiz = 360./PI*atan( d*tan(PI/360.*v->horiz) ); |
161 |
|
v->horiz = 360./PI*acos( (1. - d*d) / (1. + d*d) ); |
162 |
|
break; |
163 |
|
} |
164 |
< |
d = y1 - y0; |
165 |
< |
if (d == .0) |
166 |
< |
return(ill_crop); |
167 |
< |
if (!FABSEQ(d, 1.)) /* adjust vertical size? */ |
164 |
> |
|
165 |
> |
d = y1 - y0; /* adjust vertical size? */ |
166 |
> |
if (!FABSEQ(d, 1.)) |
167 |
|
switch (v->type) { |
168 |
|
case VT_PER: |
169 |
|
case VT_CYL: |
185 |
|
v->vert = 360./PI*acos( (1. - d*d) / (1. + d*d) ); |
186 |
|
break; |
187 |
|
} |
188 |
< |
/* fix offsets */ |
188 |
> |
/* adjust offsets */ |
189 |
|
v->hoff = ((x0 + x1)*.5 - .5 + v->hoff) / (x1 - x0); |
190 |
|
v->voff = ((y0 + y1)*.5 - .5 + v->voff) / (y1 - y0); |
191 |
|
|