| 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 |
} |