source: GTP/trunk/Lib/Geom/shared/GTGeometry/src/GeoMeshSimpSequence.cpp @ 1009

Revision 1009, 2.6 KB checked in by gumbau, 18 years ago (diff)
Line 
1#include "GeoMeshSimpSequence.h"
2
3using namespace Geometry;
4using namespace std;
5
6MeshSimplificationSequence::MeshSimplificationSequence()
7{
8        meshName="";
9}
10
11MeshSimplificationSequence::~MeshSimplificationSequence()
12{
13}
14
15void MeshSimplificationSequence::Load(Serializer &s)
16{
17        //Loads a simplification sequence from a file
18        char buffer[256];
19        unsigned int modVertex;
20        char name[256];
21
22        if (s.ReadData(buffer,256) != NULL)
23        {
24                sscanf(buffer,"%s",&name);
25                meshName=new char[strlen(name)];
26                strcpy(meshName,name);
27        }
28
29        while (s.ReadData(buffer,256) != NULL)
30        {
31                Geometry::MeshSimplificationSequence::Step simplifstep;
32                //new step
33                sscanf(buffer,"%u %u %u %u %u %f %f %f &",&simplifstep.mV1,&simplifstep.mV0, &simplifstep.mT0,&simplifstep.mT1, &simplifstep.obligatorio,&simplifstep.x, &simplifstep.y, &simplifstep.z);
34                //sscanf(buffer,"%u %u %u %u %u &",&simplifstep.mV1,&simplifstep.mV0, &simplifstep.mT0,&simplifstep.mT1, &simplifstep.obligatorio);
35                //sscanf(buffer + 3,"%u %u %f %f %f %u %u &",&simplifstep.mV0,&simplifstep.mV1,&simplifstep.x, &simplifstep.y, &simplifstep.z, &simplifstep.mT0,&simplifstep.mT1);
36                //sscanf(buffer,"%u %u %u %u %u &",&simplifstep.mV0,&simplifstep.mV1,&simplifstep.mT0,&simplifstep.mT1, &simplifstep.obligatorio);
37
38                buffer[strlen(buffer)-1]='\0';
39
40                //if(!simplifstep.obligatorio)
41                //{
42                char *ptr1;
43                ptr1=strtok(buffer,"&");
44                ptr1=strtok(NULL,"&");
45
46                if (ptr1!=NULL)
47                {
48                        char *ptr;
49                        ptr=strtok(ptr1," ");
50                       
51                        while(ptr != NULL )
52                        {
53                                modVertex = (unsigned int)atoi(ptr);
54                                simplifstep.mModfaces.push_back(modVertex);
55                                ptr=strtok(NULL," ");
56                        }
57                }
58                mSteps.push_back(simplifstep);
59                //}
60
61        }
62
63}
64
65void MeshSimplificationSequence::Save(Serializer &s)
66{
67        //Stores the simplification sequence in a file
68        char simp[256];
69
70        //Name of the mesh
71        sprintf(simp,"%s\n",meshName);
72        s.WriteData(simp,sizeof(char),strlen(simp));
73
74        for(unsigned int i=0; i<mSteps.size(); i++)
75        {
76                Geometry::MeshSimplificationSequence::Step paso = mSteps.operator [](i);
77                //sprintf(simp,"%u %u %u %u %u &", paso.mV0, paso.mV1, paso.mT0, paso.mT1,paso.obligatorio);
78                sprintf(simp,"%u %u %u %u %u %f &", paso.mV0, paso.mV1, paso.mT0, paso.mT1,paso.obligatorio,paso.x);
79                s.WriteData(simp,sizeof(char),strlen(simp));
80                for (unsigned int j=0; j<paso.mModfaces.size(); j++)
81                {
82                        sprintf(simp," %u",paso.mModfaces.operator [](j));
83                        s.WriteData(simp,sizeof(char),strlen(simp));
84                }
85                s.WriteData("\n",sizeof(char),1);
86        }
87}
88
89void MeshSimplificationSequence::putMeshName(char *name)
90{
91        meshName=name;
92}
93
94char *MeshSimplificationSequence::getMeshName(void)
95{
96        return meshName;
97}
Note: See TracBrowser for help on using the repository browser.