% D. Roegel
% Three orthogonal projections of a tetrahedron
% January 7, 2001
%
[email protected]
verbatimtex
%&latex
\documentclass{article}
\usepackage{mathpple}
\begin{document}
etex
input 3dgeom; % definitions for geometry
input 3danim; % animations
% We modify some of the default settings.
output_res:=72;
drawing_scale:=7cm;
filled_faces:=false;
show_animation_parameters:=true;
%projection_type:=1; % parallel projection
%================ DEFINITION OF OBJECT (BEGIN) =========================
vardef def_fig(expr inst)=
new_obj_points(inst,28); % 28 points 4+3*(4+4)
set_fig_points(inst);
enddef;
% Definition of the points that belong to the general figure.
vardef set_fig_points(expr inst)=
set_point(1)(0.3,0.45,0.8); % A
set_point(2)(0.6,0.45,0.8); % B
set_point(3)(0.5,0.6,0.5); % C
set_point(4)(0.5,0.3,0.5); % D
% the three planes (four corners at a time)
% horizontal
set_point(5)(0,0,-.2);
set_point(6)(1,0,-.2);
set_point(7)(1,1,-.2);
set_point(8)(0,1,-.2);
% vertical left
set_point(9) (-.45,0,0);
set_point(10)(-.45,1,0);
set_point(11)(-.45,1,1);
set_point(12)(-.45,0,1);
% vertical front
set_point(13)(0,-.45,0);
set_point(14)(1,-.45,0);
set_point(15)(1,-.45,1);
set_point(16)(0,-.45,1);
% we now compute the verticals and therefore introduce plane structures
new_plane(f)(9,10,11);
new_plane(g)(13,14,15);
new_plane(h)(5,6,7);
% bottow figure
def_vert_pl(17)(1)(h);
def_vert_pl(18)(2)(h);
def_vert_pl(19)(3)(h);
def_vert_pl(20)(4)(h);
% left figure
def_vert_pl(21)(1)(f);
def_vert_pl(22)(2)(f);
def_vert_pl(23)(3)(f);
def_vert_pl(24)(4)(f);
% front figure
def_vert_pl(25)(1)(g);
def_vert_pl(26)(2)(g);
def_vert_pl(27)(3)(g);
def_vert_pl(28)(4)(g);
free_plane(h);free_plane(g);free_plane(f);
enddef;
% Method to draw a general figure
vardef draw_fig(expr inst)=
% tetrahedron
pickup pencircle scaled 1pt;
drawoptions();
draw_line(1,2);draw_line(1,3);draw_line(2,3);
draw_line(2,4);draw_line(3,4);
drawoptions(dashed withdots);draw_line(1,4);
drawoptions();
% projection on f:
draw_line(21,22);draw_line(21,23);draw_line(21,24);
draw_line(22,23);draw_line(22,24);draw_line(23,24);
% projection on g:
draw_line(25,26);draw_line(25,27);draw_line(25,28);
draw_line(26,27);draw_line(26,28);draw_line(27,28);
% projection on h:
draw_line(17,18);draw_line(17,19);draw_line(17,20);
draw_line(18,19);draw_line(18,20);draw_line(19,20);
pickup pencircle scaled .4pt;
% les plans
draw_line(5,6);draw_line(6,7);draw_line(7,8);draw_line(8,5);
draw_line(9,10);draw_line(10,11);draw_line(11,12);draw_line(12,9);
draw_line(13,14);draw_line(14,15);draw_line(15,16);draw_line(16,13);
pickup pencircle scaled .4pt;
% dotted projection lines:
save i;drawoptions(dashed evenly);
for i:=1 upto 4: draw_line(i,i+16);endfor;
for i:=1 upto 4: draw_line(i,i+20);endfor;
for i:=1 upto 4: draw_line(i,i+24);endfor;
% and a few labels:
label_obj.top(btex $A$ etex,1);
label_obj.llft(btex $B$ etex,2);
label_obj.lrt(btex $C$ etex,3);
label_obj.llft(btex $D$ etex,4);
label_obj.bot(btex $H$ etex,7);
label_obj.top(btex $F$ etex,12);
label_obj.llft(btex $G$ etex,14);
enddef;
assign_obj("figa","fig");
%================ DEFINITION OF OBJECT (END) =========================
% Call of drawing instruction
%for i:=0 upto 20:%99:
i=12;
beginfig(100+i);
% Positionning of the observer
set_point_(Obs)(4*cosd(3.6*i),4*sind(3.6*i),2.2);
Obs_phi:=90;Obs_dist:=2;point_of_view_obj("figa",1,Obs_phi);
draw_obj("figa"); % main figure
endfig;
%endfor; show_animation_bbox;
end.