1 |
function d3d_model_ellipsoid(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9) |
2 |
{ |
3 |
var __ind = arg0; |
4 |
var __x1 = arg1; |
5 |
var __y1 = arg2; |
6 |
var __z1 = arg3; |
7 |
var __x2 = arg4; |
8 |
var __y2 = arg5; |
9 |
var __z2 = arg6; |
10 |
var __hrepeat = arg7; |
11 |
var __vrepeat = arg8; |
12 |
var __steps = arg9; |
13 |
if (__steps < 3) |
14 |
__steps = 3; |
15 |
if (__steps > 128) |
16 |
__steps = 128; |
17 |
var __cc; |
18 |
__cc[__steps] = 0; |
19 |
var __ss; |
20 |
__ss[__steps] = 0; |
21 |
for (var __i = 0; __i <= __steps; __i++) |
22 |
{ |
23 |
var __rad = (__i * 2 * pi) / __steps; |
24 |
__cc[__i] = cos(__rad); |
25 |
__ss[__i] = sin(__rad); |
26 |
} |
27 |
var __mx = (__x2 + __x1) / 2; |
28 |
var __my = (__y2 + __y1) / 2; |
29 |
var __mz = (__z2 + __z1) / 2; |
30 |
var __rx = (__x2 - __x1) / 2; |
31 |
var __ry = (__y2 - __y1) / 2; |
32 |
var __rz = (__z2 - __z1) / 2; |
33 |
var __rows = (__steps + 1) / 2; |
34 |
for (var __j = 0; __j <= (__rows - 1); __j++) |
35 |
{ |
36 |
var __row1rad = (__j * pi) / __rows; |
37 |
var __row2rad = ((__j + 1) * pi) / __rows; |
38 |
var __rh1 = cos(__row1rad); |
39 |
var __rd1 = sin(__row1rad); |
40 |
var __rh2 = cos(__row2rad); |
41 |
var __rd2 = sin(__row2rad); |
42 |
d3d_model_primitive_begin(__ind, 5); |
43 |
for (var __i = 0; __i <= __steps; __i++) |
44 |
{ |
45 |
d3d_model_vertex_normal_texture(__ind, __mx + (__rx * __rd1 * __cc[__i]), __my + (__ry * __rd1 * __ss[__i]), __mz + (__rz * __rh1), __rd1 * __cc[__i], __rd1 * __ss[__i], __rh1, (__hrepeat * __i) / __steps, (__j * __vrepeat) / __rows); |
46 |
d3d_model_vertex_normal_texture(__ind, __mx + (__rx * __rd2 * __cc[__i]), __my + (__ry * __rd2 * __ss[__i]), __mz + (__rz * __rh2), __rd2 * __cc[__i], __rd2 * __ss[__i], __rh2, (__hrepeat * __i) / __steps, ((__j + 1) * __vrepeat) / __rows); |
47 |
} |
48 |
d3d_model_primitive_end(__ind); |
49 |
} |
50 |
} |