summaryrefslogtreecommitdiff
path: root/vis.c
diff options
context:
space:
mode:
authorrodri <rgl@antares-labs.eu>2024-09-21 16:14:16 +0000
committerrodri <rgl@antares-labs.eu>2024-09-21 16:14:16 +0000
commit11b9c1697a3fd518c8b133544f0abbdb915a2491 (patch)
tree2de168b17636b9061b4f58d219ceb41270adb72f /vis.c
parentcdb4aca6643ebde7cfb7af332cb323ba2afacf15 (diff)
download3dee-11b9c1697a3fd518c8b133544f0abbdb915a2491.tar.gz
3dee-11b9c1697a3fd518c8b133544f0abbdb915a2491.tar.bz2
3dee-11b9c1697a3fd518c8b133544f0abbdb915a2491.zip
vis: use a single viewport for all the cameras.HEADmaster
Diffstat (limited to 'vis.c')
-rw-r--r--vis.c33
1 files changed, 16 insertions, 17 deletions
diff --git a/vis.c b/vis.c
index fae1465..a6538e7 100644
--- a/vis.c
+++ b/vis.c
@@ -624,6 +624,7 @@ void
threadmain(int argc, char *argv[])
{
Renderer *rctl;
+ Viewport *v;
Channel *keyc;
Entity *subject;
char *texpath, *mdlpath, *s;
@@ -698,26 +699,24 @@ threadmain(int argc, char *argv[])
clr = eallocimage(display, UR, XRGB32, 1, 0x888888FF);
screenb = eallocimage(display, rectsubpt(screen->r, screen->r.min), XRGB32, 0, DNofill);
fprint(2, "screen %R\n", screenb->r);
+
+ v = mkviewport(fbw == 0 || fbh == 0? screenb->r: Rect(0,0,fbw,fbh));
+ v->setscale(v, scale, scale);
+ v->createraster(v, "normals", COLOR32);
+ v->p.x = (Dx(screenb->r) - v->getwidth(v))/2;
+ v->p.y = (Dy(screenb->r) - v->getheight(v))/2;
+ if(scale == 2)
+ v->setscalefilter(v, UFScale2x);
+ else if(scale == 3)
+ v->setscalefilter(v, UFScale3x);
+fprint(2, "view off %v scalex %g scaley %g\n", v->p, v->bx.x, v->by.y);
+
for(i = 0; i < nelem(cams); i++){
- if(fbw == 0 || fbh == 0)
- cams[i] = Cam(screenb->r, rctl,
- camcfgs[i].ptype, camcfgs[i].fov, camcfgs[i].clipn, camcfgs[i].clipf);
- else
- cams[i] = Cam(Rect(0,0,fbw,fbh), rctl,
- camcfgs[i].ptype, camcfgs[i].fov, camcfgs[i].clipn, camcfgs[i].clipf);
+ cams[i] = Camv(v, rctl,
+ camcfgs[i].ptype, camcfgs[i].fov, camcfgs[i].clipn, camcfgs[i].clipf);
if(cams[i] == nil)
- sysfatal("Cam: %r");
+ sysfatal("Camv: %r");
placecamera(cams[i], scene, camcfgs[i].p, camcfgs[i].lookat, camcfgs[i].up);
- cams[i]->view->setscale(cams[i]->view, scale, scale);
- cams[i]->view->createraster(cams[i]->view, "normals", COLOR32);
-
- if(scale == 2)
- cams[i]->view->setscalefilter(cams[i]->view, UFScale2x);
- else if(scale == 3)
- cams[i]->view->setscalefilter(cams[i]->view, UFScale3x);
- cams[i]->view->p.x = (Dx(screenb->r) - cams[i]->view->getwidth(cams[i]->view))/2;
- cams[i]->view->p.y = (Dy(screenb->r) - cams[i]->view->getheight(cams[i]->view))/2;
-fprint(2, "cam%d off %v scalex %g scaley %g\n", i+1, cams[i]->view->p, cams[i]->view->bx.x, cams[i]->view->by.y);
}
maincam = cams[3];
light.p = Pt3(0,100,100,1);