Advertisement
Guest User

Untitled

a guest
Dec 30th, 2014
256
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 7.16 KB | None | 0 0
  1. //#include <stdlib.h>
  2. #include <iostream>
  3. #include <cassert>
  4. #include <vector>
  5. #include <stdint.h>
  6. #include <cfloat>
  7.  
  8. template<int N>
  9. struct VecF
  10. {
  11.   float d[N];
  12.   VecF(float x[N])
  13.   {
  14.     for(int i=0;i<N;i++) d[i]=x[i];
  15.   }
  16.   VecF()
  17.   {
  18.     for(int i=0;i<N;i++) d[i]=0.0f;
  19.   }
  20. };
  21.  
  22. template<typename T>
  23. struct timestampedValue
  24. {
  25.   uint32_t stamp;
  26.   T data;
  27. };
  28.  
  29. template<typename T>
  30. void wr(char* file,size_t pos,T value)
  31. {
  32.   *((T*)(file+pos)) = value;
  33. }
  34.  
  35. void wrHeader(char* file)
  36. {
  37.   wr(file,0x000,'02DM');
  38.   wr(file,0x004,0x00000108);
  39.   wr(file,0x008,0x00000005);
  40.   wr(file,0x00c,0x00000130);
  41.   wr(file,0x01c,0x00000001);
  42.   wr(file,0x020,0x00000140);
  43.   wr(file,0x02c,0x00000001);
  44.   wr(file,0x030,0x00000180);
  45.   wr(file,0x034,0x00000001);
  46.   wr(file,0x038,0x000001e0);
  47.   wr(file,0x044,0x00000001);
  48.   wr(file,0x0a0,0x7F7FFFFF);
  49.   wr(file,0x0a4,0x7F7FFFFF);
  50.   wr(file,0x0a8,0x7F7FFFFF);
  51.   wr(file,0x0ac,0xFF7FFFFF);
  52.   wr(file,0x0b0,0xFF7FFFFF);
  53.   wr(file,0x0b4,0xFF7FFFFF);
  54.   wr(file,0x110,0x00000001);
  55.   wr(file,0x114,0x00000200);
  56.   wr(file,0x118,0x00000001);
  57.   wr(file,0x11c,0x000001f0);
  58.   wr(file,0x130,'_MAC');
  59. }
  60.  
  61. void wrAnimations(char* file, int animationlength)
  62. {
  63.   wr(file,0x144,animationlength);
  64.   wr(file,0x14c,0x00000020);
  65.   wr(file,0x150,0x00007fff);
  66.   wr(file,0x160,0x7F7FFFFF);
  67.   wr(file,0x164,0x7F7FFFFF);
  68.   wr(file,0x168,0x7F7FFFFF);
  69.   wr(file,0x16c,0xFF7FFFFF);
  70.   wr(file,0x170,0xFF7FFFFF);
  71.   wr(file,0x174,0xFF7FFFFF);
  72.   wr(file,0x17c,0x0000FFFF);
  73. }
  74.  
  75. void wrBones(char* file)
  76. {
  77.   wr(file,0x180,0xFFFFFFFF);
  78.   wr(file,0x188,0x0000FFFF);
  79.   wr(file,0x190,0xFFFF0000);
  80.   wr(file,0x1a4,0xFFFF0000);
  81.   wr(file,0x1b8,0xFFFF0000);
  82.  
  83.   wr(file,0x1e0,0x0000FFFF);
  84. }
  85.  
  86. void wrCameras(char* file, const VecF<3>& position, const VecF<3>& target, const std::vector<timestampedValue<VecF<3> > >& rolls, const std::vector<timestampedValue<VecF<9> > >& positions, const std::vector<timestampedValue<VecF<9> > >& targets)
  87. {
  88.   float fov = 0.785398f;
  89.   float farclip = 27.7778f;
  90.   float nearclip = 0.222222f;
  91.  
  92.   wr(file,0x1f0,0x0000FFFF);
  93.  
  94.   wr(file,0x200,0xFFFFFFFF);
  95.   wr(file,0x204,fov);
  96.   wr(file,0x208,farclip);
  97.   wr(file,0x20c,nearclip);
  98.   wr(file,0x210,0xFFFF0001);
  99.   wr(file,0x214,0x00000001);
  100.   wr(file,0x218,0x00000270);
  101.   wr(file,0x21c,0x00000001);
  102.   wr(file,0x220,0x00000278);
  103.   wr(file,0x224,position);
  104.   wr(file,0x230,0xFFFF0001);
  105.   wr(file,0x234,0x00000001);
  106.   wr(file,0x238,0x00000280);
  107.   wr(file,0x23c,0x00000001);
  108.   wr(file,0x240,0x00000288);
  109.   wr(file,0x244,target);
  110.   wr(file,0x250,0xFFFF0002);
  111.   wr(file,0x254,0x00000001);
  112.   wr(file,0x258,0x00000290);
  113.   wr(file,0x25c,0x00000001);
  114.   wr(file,0x260,0x00000298);
  115.  
  116.   uint32_t pos_timestamps = 0x2a0;
  117.   uint32_t pos_data = pos_timestamps + positions.size() * sizeof(uint32_t);
  118.  
  119.   uint32_t tar_timestamps = pos_data + positions.size() * sizeof(float)*9;
  120.   uint32_t tar_data = tar_timestamps + targets.size() * sizeof(uint32_t);
  121.  
  122.   uint32_t roll_timestamps = tar_data + targets.size() * sizeof(float)*9;
  123.   uint32_t roll_data = roll_timestamps + rolls.size() * sizeof(uint32_t);
  124.  
  125.   wr(file,0x270,positions.size());
  126.   wr(file,0x274,pos_timestamps);
  127.   wr(file,0x278,positions.size());
  128.   wr(file,0x27c,pos_data);
  129.   wr(file,0x280,targets.size());
  130.   wr(file,0x284,tar_timestamps);
  131.   wr(file,0x288,targets.size());
  132.   wr(file,0x28c,tar_data);
  133.   wr(file,0x290,rolls.size());
  134.   wr(file,0x294,roll_timestamps);
  135.   wr(file,0x298,rolls.size());
  136.   wr(file,0x29c,roll_data);
  137.  
  138.   for(int i=0;i<positions.size();++i)
  139.   {
  140.     wr(file,pos_timestamps+sizeof(uint32_t)*i,positions[i].stamp);
  141.     wr(file,pos_data+sizeof(float)*9*i,positions[i].data);
  142.   }
  143.  
  144.   for(int i=0;i<targets.size();++i)
  145.   {
  146.     wr(file,tar_timestamps+sizeof(uint32_t)*i,targets[i].stamp);
  147.     wr(file,tar_data+sizeof(float)*9*i,targets[i].data);
  148.   }
  149.  
  150.   for(int i=0;i<rolls.size();++i)
  151.   {
  152.     wr(file,roll_timestamps+sizeof(uint32_t)*i,rolls[i].stamp);
  153.     wr(file,roll_data+sizeof(float)*3*i,rolls[i].data);
  154.   }
  155. }
  156.  
  157. int main(int argc,char** argv)
  158. {
  159.   int animationlength = 12000;
  160.  
  161.   //timestampedValue<VecF<3> > fake3;
  162.  
  163.   std::vector<timestampedValue<VecF<3> > > rolls;
  164.   std::vector<timestampedValue<VecF<9> > > positions;
  165.   std::vector<timestampedValue<VecF<9> > > targets;
  166.  
  167.   /*int n = 10;
  168.   int ts = 10000 / n;
  169.   float pitens = 3.14f * 2 / float(n);
  170.  
  171.   for(int i = 0; i<=n;i++)
  172.   {
  173.     fake3.stamp = ts * i; fake3.data.d[0] = pitens * i; fake3.data.d[1] = pitens * i; fake3.data.d[2] = pitens * i;
  174.     rolls.push_back(fake3);
  175.   }*/
  176.  
  177.   timestampedValue<VecF<9> > fake9;
  178.   fake9.stamp = 0000; fake9.data.d[0] = 0.0000000f; fake9.data.d[1] = 0.0000000f; fake9.data.d[2] = 0.0000000f;
  179.   positions.push_back(fake9);
  180.   fake9.stamp = 1000; fake9.data.d[0] = 9.5917970f; fake9.data.d[1] = -0.1142580; fake9.data.d[2] = 0.1422460f;
  181.   positions.push_back(fake9);
  182.   fake9.stamp = 2000; fake9.data.d[0] = 10.3173830f; fake9.data.d[1] = 3.9326170; fake9.data.d[2] = 0.1911900f;
  183.   positions.push_back(fake9);
  184.   fake9.stamp = 3000; fake9.data.d[0] = 4.9677730f; fake9.data.d[1] = 5.3388670; fake9.data.d[2] = -0.9971700f;
  185.   positions.push_back(fake9);
  186.   fake9.stamp = 4000; fake9.data.d[0] = -0.2636720f; fake9.data.d[1] = 6.9013670; fake9.data.d[2] = -0.9992230f;
  187.   positions.push_back(fake9);
  188.   fake9.stamp = 5000; fake9.data.d[0] = -5.1162110f; fake9.data.d[1] = 4.0312500; fake9.data.d[2] = 0.7678370f;
  189.   positions.push_back(fake9);
  190.   fake9.stamp = 6000; fake9.data.d[0] = -4.4160160f; fake9.data.d[1] = 1.4306640; fake9.data.d[2] = 3.3333390f;
  191.   positions.push_back(fake9);
  192.   fake9.stamp = 7000; fake9.data.d[0] = -7.3105470f; fake9.data.d[1] = -1.3779300; fake9.data.d[2] = 1.1820770f;
  193.   positions.push_back(fake9);
  194.   fake9.stamp = 8000; fake9.data.d[0] = -4.0244140f; fake9.data.d[1] = -3.8632810; fake9.data.d[2] = 0.7357670f;
  195.   positions.push_back(fake9);
  196.   fake9.stamp = 9000; fake9.data.d[0] = -0.2363280f; fake9.data.d[1] = -4.2187500; fake9.data.d[2] = 0.3637150f;
  197.   positions.push_back(fake9);
  198.   fake9.stamp = 10000; fake9.data.d[0] = 1.6210940f; fake9.data.d[1] = -1.3789060; fake9.data.d[2] = -0.3569140f;
  199.   positions.push_back(fake9);
  200.   fake9.stamp = 11000; fake9.data.d[0] = 0.1699220f; fake9.data.d[1] = 0.4082030; fake9.data.d[2] = 0.3884770f;
  201.   positions.push_back(fake9);
  202.   fake9.stamp = 12000; fake9.data.d[0] = 0.0000000f; fake9.data.d[1] = 0.0000000f; fake9.data.d[2] = 0.0000000f;
  203.   positions.push_back(fake9);
  204.  
  205.   //timestampedValue<VecF<9> > fake9_; fake9_.stamp = 0;
  206.   //targets.push_back(fake9_);
  207.  
  208.   VecF<3> position; position.d[0] = 0.0f; position.d[1] = 0.0f; position.d[2] = 1.0f;
  209.   VecF<3> target; target.d[0] = 0.0f; target.d[1] = 0.0f; target.d[2] = 2.0f;
  210.    
  211.   uint32_t size = 0x2a0 + (positions.size()+targets.size()) * (sizeof(uint32_t)+sizeof(float)*9) + rolls.size() * (sizeof(uint32_t)+sizeof(float)*3);
  212.  
  213.   char* file = new char[size];
  214.   memset(file,0,size);
  215.  
  216.   wrHeader(file);
  217.   wrAnimations(file, animationlength);
  218.   wrBones(file);
  219.   wrCameras(file, position, target, rolls, positions, targets);
  220.  
  221.   FILE* f = fopen("patch-Z/Cameras/Scry_cam.m2","w+");
  222.   fwrite(file,size,1,f);
  223.   fclose(f);
  224.  
  225.   delete[] file;
  226.  
  227.   return 0;
  228. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement