summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/graphics_c3.c70
1 files changed, 41 insertions, 29 deletions
diff --git a/src/graphics_c3.c b/src/graphics_c3.c
index 256a57c..2a275bb 100644
--- a/src/graphics_c3.c
+++ b/src/graphics_c3.c
@@ -45,6 +45,7 @@ real distance3(c3_t p1,c3_t p2) {
return sqrt(( (p1.x-p2.x)*(p1.x-p2.x) )+( (p1.y-p2.y)*(p1.y-p2.y) )+( (p1.z-p2.z)*(p1.z-p2.z) ));
}
+/* moved to math.c
int between_angles(degrees d,real lower,real upper) {
//lower may be higher than upper.
//because lower is < 0 which wraps to higher. lower is 270, upper is 90. 270-90 is in front.
@@ -57,6 +58,7 @@ int between_angles(degrees d,real lower,real upper) {
}
return 0;
}
+*/
/*
B (x2,y2)
@@ -161,6 +163,21 @@ c2_t c3_to_c2(c3_t p3) { //DO NOT DRAW STUFF IN HERE
return p2;
}
+void draw_minimap_shape(c3_s_t s) {//this should replace the draw_minimap_line and actually do circles.
+ //hrm... should I have functions for converting c3 points into minimap points?
+ c2_s_t s2;
+ s2.len=s.len;
+ s2.id=s.id;
+ int i=0;
+ //if(gra_global.drawminimap == 1) {
+ for(i=0;i<s.len+(s.len==1);i++) {
+ s2.p[i]=(c2_t){(s.p[i].z - global.camera.p.z) * global.mmz,(s.p[i].x - global.camera.p.x) * global.mmz};
+ }
+ draw_c2_shape(s2);
+ // }
+}
+
+/*
void draw_minimap_line(c3_t p1,c3_t p2) {
if(gra_global.drawminimap == 1) {//map moves but doesn't rotate.
draw_c2_line((c2_t){(p1.z-global.camera.p.z)*global.mmz,(global.camera.p.x-p1.x)*global.mmz},
@@ -172,6 +189,7 @@ void draw_minimap_line(c3_t p1,c3_t p2) {
draw_c2_line((c2_t){t1.x*global.mmz,t1.z*global.mmz},(c2_t){t2.x*global.mmz,t2.z*global.mmz});
}
}
+*/
void draw_c3_shape(c3_s_t s) {//outlined. needs to be filled? //draw minimap shit in here too? probably...
int i;
@@ -190,22 +208,24 @@ void draw_c3_shape(c3_s_t s) {//outlined. needs to be filled? //draw minimap shi
//s2.p[i]=c3_to_c2(s.p[i]);
}
}
+ if(s.len == 1) {
+ real dist=distance3(s.p[0],s.p[1]);
+ s2.p[0]=s.p[0];
+ s2.p[1]=c3_add(s.p[0],(c3_t){dist,0,0});
+ }
+ //all s2 needs to bet set before this loop.
for(i=0;i<s.len+(s.len==1);i++) {//
r=points_to_angle((c2_t){global.camera.p.x,global.camera.p.z},(c2_t){s2.p[i].x,s2.p[i].z});
if(between_angles(r2d(r),(360-global.camera.r.y.d-45+360+90)%360,(360-global.camera.r.y.d+45+360+90)%360)) {
drawthefucker=1;//damn it. somewhere in this shape needs to be drawn.
- }
+ }
}
if(!drawthefucker) return;//fuck yeah. didn't have to do all that other crap.
- if(s.len == 1) {
- real dist=distance3(s.p[0],s.p[1]);
- s2.p[0]=s.p[0];
- s2.p[1]=c3_add(s.p[0],(c3_t){dist,0,0});//whatever
- }
for(i=0;i<s.len+(s.len==1);i++) {
- if(s.len > 1) draw_minimap_line(s2.p[i],s2.p[(i+1)%s2.len]);//we shouldn't draw circles in here.
+// if(s.len > 1) draw_minimap_line(s2.p[i],s2.p[(i+1)%s2.len]);//we shouldn't draw circles in here. //yeah. we probably should.
s3.p[i]=c3_to_c2(s2.p[i]);//we need to convert all points in the shape if we have to draw any parts of it.
}
+ draw_minimap_shape(s2);
if(gra_global.draw3d == 1) {
set_ansi_color(s.attrib.col%16);
draw_c2_shape(s3);
@@ -385,6 +405,7 @@ void draw_screen() {
global.camera.p.z-=(gra_global.split_flip)*((gra_global.split/gra_global.split_screen)*cos( tmprad.r ));
global.camera.p.x-=(gra_global.split_flip)*((gra_global.split/gra_global.split_screen)*sin( tmprad2.r ));
}
+ //return 0;//after this
for(cn=0;cn<gra_global.split_screen;cn++) {
set_color();//restart each draw with the default color.
if(gra_global.red_and_blue) {
@@ -431,18 +452,6 @@ void draw_screen() {
// draw_c2_text((cs_t){gra_global.xoff,(gra_global.height/2)+40},tmp);
}
}
-
-// if(global.drawminimap) {//this isn't even useful I guess.
- //cx1=(sin(d2r(camera.yr+270))*7l);
- //cy1=(cos(d2r(camera.yr+270))*7l);
- //cx2=(sin(d2r(camera.yr+90))*7l);
- //cy2=(cos(d2r(camera.yr+90))*7l);
-// draw_c2_line((c2_t){0,0},(c2_t){10,10});
-// draw_c2_line((c2_t){0,0},(c2_t){-10,10});
-// draw_c2_line((c2_t){10,10},(c2_t){-10,10});
-// }
-
-
///// shiiiit. I should be applying group rotations to all these shapes before sorting them.
//when I do that. I need to make sure to take the group rotation out of draw_c3_shape()'s code.
for(i=0;global.shape[i];i++) {
@@ -450,17 +459,13 @@ void draw_screen() {
}
qsort(&zs,i,sizeof(zs[0]),(int (*)(const void *,const void *))compar);//sort these zs structs based on d.
//draw all triangles
- if(global.debug) {
- //snprintf(tmp,sizeof(tmp)-1,"selected object: %s",global.selected_object);
- //draw_c2_text((c2_t){gra_global.xoff,(gra_global.height/2)+50},tmp);
- }
//i already equals the length of the array.
i-=gra_global.maxshapes;
if(i<0) i=0;
for(;global.shape[i];i++) {
//now we pick the color of this triangle!
- if(gra_global.red_and_blue) {
+ if(gra_global.red_and_blue) {//this can be moved to the draw_c3_shape function and color can be set then.
if(cn%2==0) {
set_color_red();
} else {
@@ -480,7 +485,7 @@ void draw_screen() {
draw_c3_shape(*(zs[i].s));
//}
}
-
+/*
if(gra_global.drawminimap == 1) {
set_color();
c2_t t1=rotate_c2((c2_t){3*global.mmz,0},(c2_t){0,0},d2r(global.camera.r.y));
@@ -491,7 +496,7 @@ void draw_screen() {
draw_c2_line(t2,t3);
draw_c2_line(t3,t4);
draw_c2_line(t4,t1);
- }
+ }*/
// XSetForeground(global.dpy, global.backgc, global.green.pixel);
radians tmprad=d2r((degrees){global.camera.r.y.d+90});
@@ -502,8 +507,10 @@ void draw_screen() {
//just draw a line from center to 40 away from the center at the angle of the camera's y-rotation
//this should be minimap shit draw_c2_line((c2_t){0,0},rotate_c2((c2_t){40,0},(c2_t){0,0},d2r(global.camera.r.y)));
//draw a line from the center to 80 away from the center in the angle of what should point at the mouse.
-// draw_c2_line((c2_t){0,0},rotate_c2((c2_t){80,0},(c2_t){0,0},points_to_angle((c2_t){0,0},cs_to_c2((cs_t){gra_global.mousex,gra_global.mousey}))));
-// draw_c2_line((c2_t){0,0},cs_to_c2((cs_t){gra_global.mousex,gra_global.mousey}));
+ //if(points_on_same_side_of_line((c2_t){gra_global.mousex,gra_global.mousey},(c2_t){80,80},(c2_t){0,0},(c2_t){0,80})) {
+ // draw_c2_line((c2_t){0,0},rotate_c2((c2_t){80,0},(c2_t){0,0},points_to_angle((c2_t){0,0},cs_to_c2((cs_t){gra_global.mousex,gra_global.mousey}))));
+ //}
+ //draw_c2_line((c2_t){0,0},cs_to_c2((cs_t){gra_global.mousex,gra_global.mousey}));
global.camera.p.x = oldx;
global.camera.p.z = oldz; //-= cn*CAMERA_SEPARATION;
flipscreen();
@@ -516,6 +523,12 @@ int graphics_init() {
global.camera.r.y.d=0;//we should be facing east.
global.camera.r.z.d=0;
global.mmz=1;//this is minimap zoom.
+
+ global.shape[0]=0;//we'll allocate as we need more.
+ global.camera.id=global.user;
+ global.group_rot[0]=&global.camera;
+ global.group_rot[1]=0;
+
global.camera.p.x=0;
global.camera.p.y=10;//10 units above the ground should be as low as it goes.
global.camera.p.z=-6;
@@ -542,4 +555,3 @@ int graphics_init() {
graphics_sub_init();
return 0;//we're fine
}
-