leda.c
上传用户:gzelex
上传日期:2007-01-07
资源大小:707k
文件大小:5k
开发平台:

MultiPlatform

  1. #include <LEDA/graph.h>
  2. #include <LEDA/stream.h>
  3. #include <LEDA/array.h>
  4. #include <LEDA/window.h>
  5. #include <math.h>
  6. typedef GRAPH<vector,int> polyhedron;
  7. void rotate(float alpha1,float alpha2, vector& p)
  8.   // rotate 3d-point p about the origin
  9.   // by alpha2 in yz-plane and alpha1 in xy-plane
  10.     double R  = hypot(p[1],p[2]);
  11.     double phi = asin(p[1]/R);
  12.   
  13.     if (p[2] < 0) phi = LEDA_PI - phi;
  14.   
  15.     p[1]  = ((R != 0) ? R*sin(phi+alpha2) : 0);
  16.     p[2]  = ((R != 0) ? R*cos(phi+alpha2) : 0);
  17.     R   = hypot(p[0],p[2]);
  18.     phi = asin(p[0]/R);
  19.     if (p[2] < 0) phi = LEDA_PI - phi;
  20.   
  21.     p[0]  = ((R != 0) ? R*sin(phi+alpha1) : 0);
  22.     p[2]  = ((R != 0) ? R*cos(phi+alpha1) : 0);
  23. }
  24. inline point project(vector p)   // project p into xy-plane
  25. { return point(p[0],p[1]); }
  26. void draw_poly(window& W, polyhedron& poly, vector trans)
  27. { edge e;
  28.   forall_edges(e,poly) 
  29.   { point a = project(poly[source(e)] + trans );
  30.     point b = project(poly[target(e)] + trans );
  31.     W.draw_segment(a,b,blue);
  32.    }
  33.  }
  34. void make_side(polyhedron& poly, node* L, float z)
  35. {
  36.   L[0]= poly.new_node(vector(-70,-20,z));
  37.   L[1]= poly.new_node(vector(-40,-20,z));
  38.   L[2]= poly.new_node(vector(-40,-10,z));
  39.   L[3]= poly.new_node(vector(-60,-10,z));
  40.   L[4]= poly.new_node(vector(-60,+20,z));
  41.   L[5]= poly.new_node(vector(-70,+20,z));
  42.   poly.new_edge(L[0],L[5]);
  43.   int i;
  44.   for(i = 1; i<=5; i++) poly.new_edge(L[i], L[i-1]);
  45.   L[6] = poly.new_node(vector(-30,-20,z));
  46.   L[7] = poly.new_node(vector( -5,-20,z));
  47.   L[8] = poly.new_node(vector( -5,-10,z));
  48.   L[9] = poly.new_node(vector(-20,-10,z));
  49.   L[10]= poly.new_node(vector(-20, -5,z));
  50.   L[11]= poly.new_node(vector( -5, -5,z));
  51.   L[12]= poly.new_node(vector( -5, +5,z));
  52.   L[13]= poly.new_node(vector(-20, +5,z));
  53.   L[14]= poly.new_node(vector(-20,+10,z));
  54.   L[15]= poly.new_node(vector( -5,+10,z));
  55.   L[16]= poly.new_node(vector( -5,+20,z));
  56.   L[17]= poly.new_node(vector(-30,+20,z));
  57.   poly.new_edge(L[6],L[17]);
  58.   for(i = 7; i<=17; i++) poly.new_edge(L[i], L[i-1]);
  59.   L[18]= poly.new_node(vector( 5,-20,z));
  60.   L[19]= poly.new_node(vector(20,-20,z));
  61.   L[20]= poly.new_node(vector(35,-10,z));
  62.   L[21]= poly.new_node(vector(35,+10,z));
  63.   L[22]= poly.new_node(vector(20,+20,z));
  64.   L[23]= poly.new_node(vector( 5,+20,z));
  65.   poly.new_edge(L[18],L[23]);
  66.   for(i = 19; i<=23; i++) poly.new_edge(L[i], L[i-1]);
  67.   L[24]= poly.new_node(vector(15,-10,z));
  68.   L[25]= poly.new_node(vector(20,-10,z));
  69.   L[26]= poly.new_node(vector(25, -5,z));
  70.   L[27]= poly.new_node(vector(25, +5,z));
  71.   L[28]= poly.new_node(vector(20,+10,z));
  72.   L[29]= poly.new_node(vector(15,+10,z));
  73.   poly.new_edge(L[24],L[29]);
  74.   for(i = 25; i<=29; i++) poly.new_edge(L[i], L[i-1]);
  75.   L[30]= poly.new_node(vector(40,-20,z));
  76.   L[31]= poly.new_node(vector(50,-20,z));
  77.   L[32]= poly.new_node(vector(55, -5,z));
  78.   L[33]= poly.new_node(vector(65, -5,z));
  79.   L[34]= poly.new_node(vector(70,-20,z));
  80.   L[35]= poly.new_node(vector(80,-20,z));
  81.   L[36]= poly.new_node(vector(65, 20,z));
  82.   L[37]= poly.new_node(vector(55, 20,z));
  83.   poly.new_edge(L[30],L[37]);
  84.   for(i = 31; i<=37; i++) poly.new_edge(L[i], L[i-1]);
  85.   L[38]= poly.new_node(vector(55, 0,z));
  86.   L[39]= poly.new_node(vector(65, 0,z));
  87.   L[40]= poly.new_node(vector(60,15,z));
  88.   poly.new_edge(L[38],L[40]);
  89.   poly.new_edge(L[39],L[38]);
  90.   poly.new_edge(L[40],L[39]);
  91. }
  92. void make_logo(polyhedron& poly)
  93.   node L[41];
  94.   node R[41];
  95.   make_side(poly,L,-5);
  96.   make_side(poly,R,+5);
  97.   for(int i = 0; i<41; i++) poly.new_edge(L[i],R[i]);
  98. }
  99.   
  100. main()
  101.   int w,h;
  102.   char* map = Read_Leda_Bitmap("../../incl/LEDA/bitmaps/leda.lbm",w,h);
  103.   window W(w,h,window::center,window::center);
  104.   W.set_frame_label(
  105.               "The LEDA Platform for Combinatorial and Geometric Computing");
  106.   W.init(-100,100,-100);
  107.   W.set_show_coordinates(false);
  108.   W.insert_bitmap(w,h,map);
  109.   W.set_node_width(4);
  110.   W.set_mode(xor_mode);
  111.   node v;
  112.   int speed = 30;
  113.   // define a polyhedron in 3d space
  114.   polyhedron poly;
  115.   make_logo(poly);
  116.   //W.draw_point(0,0);
  117.   forall_nodes(v,poly) rotate(0.3,0.5,poly[v]);
  118.   polyhedron poly0 = poly;
  119.   vector dir(2);   // direction and speed of rotation
  120.   vector trans0(0,0,0);
  121.   vector trans(0,0,0);
  122.   draw_poly(W,poly,trans);
  123.   
  124.   for(;;)
  125.   { dir[0] += rand_int(-10000,10000)/1000000.0;
  126.     dir[1] += rand_int(-10000,10000)/1000000.0;
  127.     dir = dir.norm()*(speed/500.0);
  128.     //trans[0] += rand_int(-1000,1000)/5000.0;
  129.     //trans[1] += rand_int(-1000,1000)/5000.0;
  130.     //trans[1] += rand_int(-1000,1000)/5000.0;
  131.     if (W.get_button() && W.confirm("quit leda demo ?")) break;
  132.     forall_nodes(v,poly) rotate(dir[0],dir[1],poly[v]);
  133.  
  134.     draw_poly(W,poly,trans);   // draw new position
  135.     draw_poly(W,poly0,trans0);  // erase old position  (xor_mode !!)
  136.     //trans0 = trans;
  137.     // poly0 = poly;
  138.     node w = poly.first_node();
  139.     forall_nodes(v,poly0) 
  140.     { poly0[v] = poly[w];
  141.       w = poly.succ_node(w);
  142.      }
  143.   }
  144.  return 0;
  145. }