Pixel-Composer/scripts/d3d_camera_object/d3d_camera_object.gml

56 lines
2 KiB
Text
Raw Normal View History

function __3dCamera_object() : __3dObject() constructor {
ivw = 0.2; //innerViewWidth
ivh = 0.2; //innerViewHeight
ovw = 0.5; //outerViewWidth
ovh = 0.5; //outerViewHeight
len = 0.5; //cameraLength
vertex = [[
new __vertex( -len, -ivw, ivh ), new __vertex( -len, ivw, ivh ),
new __vertex( -len, ivw, ivh ), new __vertex( -len, ivw, -ivh ),
new __vertex( -len, ivw, -ivh ), new __vertex( -len, -ivw, -ivh ),
new __vertex( -len, -ivw, -ivh ), new __vertex( -len, -ivw, ivh ),
new __vertex( len, -ovw, ovh ), new __vertex( len, ovw, ovh ),
new __vertex( len, ovw, ovh ), new __vertex( len, ovw, -ovh ),
new __vertex( len, ovw, -ovh ), new __vertex( len, -ovw, -ovh ),
new __vertex( len, -ovw, -ovh ), new __vertex( len, -ovw, ovh ),
2023-08-16 20:16:31 +02:00
new __vertex( -len, -ivw, ivh ), new __vertex( len, -ovw, ovh ),
new __vertex( -len, ivw, ivh ), new __vertex( len, ovw, ovh ),
new __vertex( -len, ivw, -ivh ), new __vertex( len, ovw, -ovh ),
new __vertex( -len, -ivw, -ivh ), new __vertex( len, -ovw, -ovh ),
new __vertex( len, -ovw * 0.5, ovh + 0.2 ), new __vertex( len, ovw * 0.5, ovh + 0.2 ),
new __vertex( len, 0, ovh + 0.6 ), new __vertex( len, ovw * 0.5, ovh + 0.2 ),
new __vertex( len, -ovw * 0.5, ovh + 0.2 ), new __vertex( len, 0, ovh + 0.6 ),
]];
VF = global.VF_POS_COL;
render_type = pr_linelist;
VB = build();
2023-08-30 16:40:45 +02:00
transform.position.set(-5, -5, 5);
transform.rotation.FromEuler(0, 30, 135);
2023-08-30 16:40:45 +02:00
transform.scale.set(1, room_width / room_height, 1);
2023-08-16 20:16:31 +02:00
static submitSel = function(params = {}) {
shader_set(sh_d3d_wireframe);
2023-11-15 02:35:30 +01:00
shader_set_color("blend", c_white);
2023-08-16 20:16:31 +02:00
submitVertex(params);
shader_reset();
}
}
function calculate_3d_position(camFx, camFy, camFz, camAx, camAy, camDist) {
var pos = new __vec3();
var radAx = degtorad(camAx);
var radAy = degtorad(camAy);
pos.x = camFx + (cos(radAy) * sin(radAx)) * camDist;
pos.y = camFy + (cos(radAy) * cos(radAx)) * camDist;
pos.z = camFz + (sin(radAy)) * camDist;
return pos;
}