metafont
clone your own copy | download snapshot

Snapshots | iceberg

Inside this repository

cube4-eng.mp
text/x-tex

Download raw (3.1 KB)

verbatimtex
%&latex
\documentclass{article}

\begin{document}
etex

input 3danim
input 3dgeom
output_res:=72;
drawing_scale:=20cm;

vardef def_C(expr inst)=
  new_obj_points(inst,21); % 21 points
  set_C_points(inst);
enddef;

vardef set_C_points(expr inst)=
  set_point(1)(0,0,0);set_point(2)(0,0,1);
  set_point(3)(0,1,0);set_point(4)(0,1,1);
  set_point(5)(1,0,0);set_point(6)(1,0,1);
  set_point(7)(1,1,0);set_point(8)(1,1,1);

  % corners of the projection plane
  %set_point(9)(12.92993,12.37372,6.83334);
  %set_point(10)(15.68588,8.48413,6.8334);
  %set_point(11)(16.27899,8.90436,4.12851);
  %set_point(12)(13.52304,12.79395,4.12845);

  %set_point(9)(13.76718,11.50638,6.15714);
  %set_point(10)(15.14517,9.56158,6.15717);
  %set_point(11)(15.44174,9.7717,4.80472);
  %set_point(12)(14.06375,11.71649,4.80469);

  set_point(9)(0.80682,2.27571,1.939);
  set_point(10)(2.03946,0.2357,1.93903);
  set_point(11)(2.46796,0.49461,0.63113);
  set_point(12)(1.23532,2.53462,0.6311);

  % shown observator
  set_point(13)(3.23608,2.35114,2);

  % intersections with the projection plane
  new_plane(pl)(9,10,11);
  new_line(l)(1,13);
  if not def_inter_p_l_pl(14)(l)(pl):
    message "PROBLEM ";
  fi;
  set_line(l)(2,13);
  if not def_inter_p_l_pl(15)(l)(pl):
    message "PROBLEM ";
  fi;
  set_line(l)(3,13);
  if not def_inter_p_l_pl(16)(l)(pl):
    message "PROBLEM ";
  fi;
  set_line(l)(4,13);
  if not def_inter_p_l_pl(17)(l)(pl):
    message "PROBLEM ";
  fi;
  set_line(l)(5,13);
  if not def_inter_p_l_pl(18)(l)(pl):
    message "PROBLEM ";
  fi;
  set_line(l)(6,13);
  if not def_inter_p_l_pl(19)(l)(pl):
    message "PROBLEM ";
  fi;
  set_line(l)(7,13);
  if not def_inter_p_l_pl(20)(l)(pl):
    message "PROBLEM ";
  fi;
  set_line(l)(8,13);
  if not def_inter_p_l_pl(21)(l)(pl):
    message "PROBLEM ";
  fi;
  
  free_line(l);
  free_plane(pl);
  
enddef;

vardef draw_C(expr inst)=
  draw_lines(1,2,4,3,1);draw_lines(5,6,8,7,5);
  draw_line(1,5);draw_line(2,6);draw_line(3,7);draw_line(4,8);
  draw_lines(9,10,11,12,9);
  pickup pencircle scaled 2pt;
  draw_line(13,13);draw_line(1,1);draw_line(2,2);draw_line(3,3);draw_line(7,7);
  pickup pencircle scaled .4pt;
  draw fullcircle scaled 6pt shifted z[ipnt_(8)];
  label_obj.lft(btex \textit{Obs}$(3.23,2.35,2)$ etex,13);
  label_obj.rt(btex $(0,0,0)$ etex,1);
  label_obj.rt(btex $(0,0,1)$ etex,2);
  label_obj.bot(btex $(0,1,0)$ etex,3);
  label_obj.llft(btex $(1,1,0)$ etex,7);
  
  drawoptions(dashed withdots);
  draw_line(1,13);draw_line(2,13);draw_line(3,13);draw_line(4,13);
  draw_line(5,13);draw_line(6,13);draw_line(7,13);draw_line(8,13);
  drawoptions();
  draw_line(14,15,17,16,14);draw_lines(18,19,21,20,18);
  draw_line(14,18);draw_line(15,19);draw_line(16,20);draw_line(17,21);
enddef;

assign_obj("cube","C");

for i:=28 upto 28:
  beginfig(100+i);
    % Observator
    set_point_(Obs)(20*cosd(3.6*i),20*sind(3.6*i),4);
    show_point("Obs",Obs);
    Obs_phi:=90;Obs_dist:=2;point_of_view_obj("cube",14,Obs_phi);
    draw_obj("cube"); 
  endfig;
endfor; 

end.