青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

eryar

PipeCAD - Plant Piping Design Software.
RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
posts - 603, comments - 590, trackbacks - 0, articles - 0

Read DXF File

Posted on 2011-12-17 18:38 eryar 閱讀(5216) 評論(3)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

設(shè)計(jì)類圖如下所示:


定義代碼為:
File: Entity.h
 1 
 2 #ifndef _ENTITY_H_
 3 #define _ENTITY_H_
 4 
 5 #include <iostream>
 6 #include <list>
 7 #include <fstream>
 8 #include <string>
 9 using namespace std;
10 
11 class CEntity
12 {
13 public:
14     CEntity(void);
15     ~CEntity(void);
16 
17     // 顯示數(shù)據(jù)
18     virtual void Show(void= 0;
19 
20 private:
21 
22 };
23 
24 #endif // _ENTITY_H_

File : Entity.cpp
 1 #include "Entity.h"
 2 
 3 CEntity::CEntity(void)
 4 {
 5 }
 6 
 7 CEntity::~CEntity(void)
 8 {
 9 }
10 
File : Line.h
 1 
 2 #ifndef _LINE_H_
 3 #define _LINE_H_
 4 
 5 #include "Entity.h"
 6 
 7 class CLine : public CEntity
 8 {
 9 public:
10     CLine(void);
11     ~CLine(void);
12 
13     // 顯示數(shù)據(jù)
14     void Show(void);
15 
16     // 設(shè)值
17     void SetX1(double x);
18     void SetY1(double y);
19     void SetZ1(double z);
20     void SetX2(double x);
21     void SetY2(double y);
22     void SetZ2(double z);
23 
24 private:
25     // 直線起點(diǎn)x: 10
26     double    m_x1;
27     // 直線起點(diǎn)y: 20
28     double    m_y1;
29     // 直線起點(diǎn)z: 30
30     double    m_z1;
31     // 直線終點(diǎn)x: 11
32     double    m_x2;
33     // 直線終點(diǎn)y: 21
34     double    m_y2;
35     // 直線終點(diǎn)z: 31
36     double    m_z2;
37 
38 };
39 
40 #endif // _LINE_H_
File: Line.cpp
 1 #include "Line.h"
 2 
 3 CLine::CLine(void)
 4 {
 5     m_x1 = m_x2 = m_y1 = m_y2 = m_z1 = m_z2 = 0;
 6 }
 7 
 8 CLine::~CLine(void)
 9 {
10 }
11 
12 void CLine::Show( void )
13 {
14     cout<<"-----------------LINE------------------"<<endl;
15     cout<<"Start : ("<<m_x1<<","<<m_y1<<","<<m_z1<<")"<<endl;
16     cout<<"End   : ("<<m_x2<<","<<m_y2<<","<<m_z2<<")"<<endl;
17     cout<<"======================================="<<endl;
18 }
19 
20 void CLine::SetX1( double x )
21 {
22     m_x1    = x;
23 }
24 
25 void CLine::SetY1( double y )
26 {
27     m_y1    = y;
28 }
29 
30 void CLine::SetZ1( double z )
31 {
32     m_z1    = z;
33 }
34 
35 void CLine::SetX2( double x )
36 {
37     m_x2    = x;
38 }
39 
40 void CLine::SetY2( double y )
41 {
42     m_y2    = y;
43 }
44 
45 void CLine::SetZ2( double z )
46 {
47     m_z2    = z;
48 }
File : Circle.h
 1 
 2 #ifndef _CIRCLE_H_
 3 #define _CIRCLE_H_
 4 
 5 #include "Entity.h"
 6 
 7 class CCircle : public CEntity
 8 {
 9 public:
10     CCircle(void);
11     ~CCircle(void);
12 
13     // 顯示數(shù)據(jù)
14     void Show(void);
15 
16     // 設(shè)值
17     void SetX(double x);
18     void SetY(double y);
19     void SetZ(double z);
20     void SetRadius(double r);
21 
22 private:
23     // 圓心坐標(biāo)x: 10
24     double    m_x;
25     // 圓心坐標(biāo)x: 20
26     double    m_y;
27     // 圓心坐標(biāo)x: 30
28     double    m_z;
29     // 半徑R: 40
30     double    m_Radius;
31 };
32 
33 #endif // _CIRCLE_H_
File : Circle.cpp
 1 #include "Circle.h"
 2 
 3 CCircle::CCircle(void)
 4 {
 5     m_x    = m_y = m_z = m_Radius = 0;
 6 }
 7 
 8 CCircle::~CCircle(void)
 9 {
10 }
11 
12 void CCircle::Show( void )
13 {
14     cout<<"----------------CIRCLE-----------------"<<endl;
15     cout<<"Center : ("<<m_x<<","<<m_y<<","<<m_z<<")"<<endl;
16     cout<<"Radius : "<<m_Radius<<endl;
17     cout<<"======================================="<<endl;
18 }
19 
20 void CCircle::SetX( double x )
21 {
22     m_x    = x;
23 }
24 
25 void CCircle::SetY( double y )
26 {
27     m_y    = y;
28 }
29 
30 void CCircle::SetZ( double z )
31 {
32     m_z    = z;
33 }
34 
35 void CCircle::SetRadius( double r )
36 {
37     m_Radius    = r;
38 }
File. : Arc.h
 1 
 2 #ifndef _ARC_H_
 3 #define _ARC_H_
 4 
 5 #include "Entity.h"
 6 
 7 class CArc : public CEntity
 8 {
 9 public:
10     CArc(void);
11     ~CArc(void);
12 
13     // 顯示數(shù)據(jù)
14     void Show(void);
15 
16     // 設(shè)值
17     void SetStartAngle(double s);
18     void SetEndAngle(double e);
19 
20 private:
21     // 起點(diǎn)角度: 50
22     double    m_StartAngle;
23     // 端點(diǎn)角度: 51
24     double    m_EndAngle;
25 };
26 
27 #endif // _ARC_H_
File : Arc.cpp
 1 #include "Arc.h"
 2 
 3 CArc::CArc(void)
 4 {
 5     m_StartAngle = 0;
 6     m_EndAngle     = 0;
 7 }
 8 
 9 CArc::~CArc(void)
10 {
11 }
12 
13 void CArc::Show( void )
14 {
15     cout<<"-----------------ARC-------------------"<<endl;
16     cout<<"Start : "<<m_StartAngle<<endl;
17     cout<<"End   : "<<m_EndAngle<<endl;
18     cout<<"======================================="<<endl;
19 }
20 
21 void CArc::SetStartAngle( double s )
22 {
23     m_StartAngle    = s;
24 }
25 
26 void CArc::SetEndAngle( double e )
27 {
28     m_EndAngle    = e;
29 }
Put it all together :
File : main.cpp
  1 
  2 #include "Arc.h"
  3 #include "Line.h"
  4 #include "Circle.h"
  5 
  6 
  7 int main(int argc, char* argv[])
  8 {
  9     char            szFileName[_MAX_FNAME];
 10     int                iGroupCode = 0;
 11     string            strGroupValue;
 12     string            strBuffer;
 13     list<CEntity*>    EntitiesList;
 14 
 15     cout<<"Input a DXF file name :";
 16     cin>>szFileName;
 17 
 18     CLine*        pLine    = NULL;
 19     CCircle*    pCircle    = NULL;
 20     CArc*        pArc    = NULL;
 21 
 22     ifstream    iDxfFile(szFileName);
 23 
 24     if (!iDxfFile.is_open())
 25     {
 26         cout<<"Open DXF file "<<szFileName<<" failed!"<<endl;
 27         return -1;
 28     }
 29 
 30     while ( !iDxfFile.eof())
 31     {
 32         getline(iDxfFile, strBuffer);
 33         iGroupCode    = atoi(strBuffer.c_str());
 34         getline(iDxfFile, strGroupValue);
 35 
 36         // Just Read Entities Section.
 37         if (iGroupCode == 2 && strGroupValue.compare("ENTITIES"== 0)
 38         {
 39             getline(iDxfFile, strBuffer);
 40             getline(iDxfFile, strGroupValue);
 41             iGroupCode    = atoi(strBuffer.c_str());
 42 
 43             while (strGroupValue.compare("ENDSEC"!= 0)
 44             {
 45                 // Read Line Data
 46                 if (iGroupCode == 0 && strGroupValue.compare("LINE"== 0)
 47                 {
 48                     pLine    = new CLine;
 49                     getline(iDxfFile, strBuffer);
 50                     getline(iDxfFile, strGroupValue);
 51                     iGroupCode = atoi(strBuffer.c_str());
 52 
 53                     while (iGroupCode)
 54                     {
 55                         // 
 56                         getline(iDxfFile, strBuffer);
 57                         getline(iDxfFile, strGroupValue);
 58                         iGroupCode = atoi(strBuffer.c_str());
 59                         switch(iGroupCode)
 60                         {
 61                         case 10: pLine->SetX1(atof(strGroupValue.c_str())); break;
 62                         case 20: pLine->SetY1(atof(strGroupValue.c_str())); break;
 63                         case 30: pLine->SetZ1(atof(strGroupValue.c_str())); break;
 64                         case 11: pLine->SetX2(atof(strGroupValue.c_str())); break;
 65                         case 21: pLine->SetY2(atof(strGroupValue.c_str())); break;
 66                         case 31: pLine->SetZ2(atof(strGroupValue.c_str())); break;
 67                         }
 68                     }
 69 
 70                     EntitiesList.push_front(pLine);
 71                 }
 72 
 73                 // Read Circle Data
 74                 else if (iGroupCode == 0 && strGroupValue.compare("CIRCLE"== 0)
 75                 {
 76                     pCircle    = new CCircle;
 77                     getline(iDxfFile, strBuffer);
 78                     getline(iDxfFile, strGroupValue);
 79                     iGroupCode = atoi(strBuffer.c_str());
 80 
 81                     while (iGroupCode)
 82                     {
 83                         // 
 84                         getline(iDxfFile, strBuffer);
 85                         getline(iDxfFile, strGroupValue);
 86                         iGroupCode = atoi(strBuffer.c_str());
 87                         switch(iGroupCode)
 88                         {
 89                         case 10: pCircle->SetX(atof(strGroupValue.c_str()));        break;
 90                         case 20: pCircle->SetY(atof(strGroupValue.c_str()));        break;
 91                         case 30: pCircle->SetZ(atof(strGroupValue.c_str()));        break;
 92                         case 40: pCircle->SetRadius(atof(strGroupValue.c_str()));    break;
 93                         }
 94                     }
 95 
 96                     EntitiesList.push_front(pCircle);
 97                 }
 98 
 99                 // Read Arc Data
100                 else if (iGroupCode == 0 && strGroupValue.compare("ARC"== 0)
101                 {
102                     pArc    = new CArc;
103                     getline(iDxfFile, strBuffer);
104                     getline(iDxfFile, strGroupValue);
105                     iGroupCode = atoi(strBuffer.c_str());
106 
107                     while (iGroupCode)
108                     {
109                         // 
110                         getline(iDxfFile, strBuffer);
111                         getline(iDxfFile, strGroupValue);
112                         iGroupCode = atoi(strBuffer.c_str());
113                         switch(iGroupCode)
114                         {
115                         case 50: pArc->SetStartAngle(atof(strGroupValue.c_str()));    break;
116                         case 51: pArc->SetEndAngle(atof(strGroupValue.c_str()));    break;
117                         }
118                     }
119 
120                     EntitiesList.push_front(pArc);
121                 }
122 
123                 // Other entities
124                 else
125                 {
126                     // Move to next two lines
127                     getline(iDxfFile, strBuffer);
128                     getline(iDxfFile, strGroupValue);
129                     /*iGroupCode = atoi(strBuffer.c_str());*/
130                 }
131             }
132         }
133 
134     }
135 
136     // Output Entities
137     for (list<CEntity*>::iterator iter = EntitiesList.begin(); 
138         iter != EntitiesList.end(); 
139         iter++)
140     {
141         (*iter)->Show();
142     }
143 
144     return 0;
145 }

Feedback

# re: Read DXF File  回復(fù)  更多評論   

2013-03-26 16:33 by 王婷
很厲害啊,牛掰哥哥,廣大單身MM可瘋狂追之...

# re: Read DXF File[未登錄]  回復(fù)  更多評論   

2014-08-14 09:34 by 張輝
哥們,看了你很多文章,很佩服你!!

# re: Read DXF File  回復(fù)  更多評論   

2014-08-14 10:36 by eryar
過獎了,
我也是在學(xué)習(xí)中……

@張輝
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲永久视频| 久久久综合视频| 国产专区一区| 国产一区二区三区久久久久久久久| 欧美精品系列| 欧美日韩视频在线一区二区观看视频| 免费在线观看日韩欧美| 欧美福利视频一区| 国产精品成人播放| 国产情人节一区| 国模吧视频一区| 亚洲精品视频免费观看| 夜夜嗨av一区二区三区四区| 在线一区二区三区四区五区| 免费视频一区| 91久久久国产精品| 一区二区欧美视频| 久久精品一二三区| 欧美精品一区二区视频| 欧美性视频网站| 国内偷自视频区视频综合| 国产一区二区三区四区hd| 最新国产拍偷乱拍精品 | 欧美日韩成人一区| 国产精品嫩草影院av蜜臀| 精品动漫一区| 亚洲综合色在线| 暖暖成人免费视频| 亚洲天堂免费观看| 欧美成人免费在线视频| 国产情侣一区| 午夜精品成人在线视频| 亚洲电影第三页| 欧美一区二区黄色| 欧美日韩综合网| 亚洲国产日韩欧美| 久久久久国产成人精品亚洲午夜| 亚洲美女视频在线观看| 久久嫩草精品久久久精品一| 国产精品毛片a∨一区二区三区|国| 在线成人中文字幕| 性8sex亚洲区入口| 亚洲激情在线观看视频免费| 久久国产综合精品| 国产精品久久久久av| 亚洲国产福利在线| 麻豆freexxxx性91精品| 99视频精品免费观看| 欧美不卡视频一区发布| 伊人久久噜噜噜躁狠狠躁| 午夜精品一区二区三区在线视| 亚洲黄色在线看| 欧美激情精品久久久久久蜜臀 | 亚洲精品在线观看免费| 久久久久久久久久码影片| 亚洲午夜激情免费视频| 欧美性大战久久久久久久| 亚洲人成网站色ww在线| 亚洲第一精品久久忘忧草社区| 久久精品成人一区二区三区| 国产欧美婷婷中文| 久久久www成人免费无遮挡大片| 一区二区三区|亚洲午夜| 久久先锋影音| 亚洲精品视频免费在线观看| 免费观看30秒视频久久| 久久精品麻豆| 亚洲国产精品激情在线观看| 亚洲第一天堂av| 老司机午夜精品视频| 久久精品在这里| 亚洲成人在线网| 欧美国产先锋| 欧美另类在线播放| 亚洲丝袜av一区| 亚洲一区二区三区777| 国产精品美女一区二区在线观看| 亚洲欧美日韩国产一区二区三区| 亚洲视频欧洲视频| 国产私拍一区| 美女精品在线观看| 欧美激情影音先锋| 亚洲欧美成人一区二区在线电影| 中文在线资源观看网站视频免费不卡| 国产精品高潮呻吟久久av无限| 性欧美暴力猛交69hd| 久久国产福利| 日韩一级黄色大片| 亚洲在线一区二区| 在线观看亚洲精品视频| 欧美护士18xxxxhd| 国产精品乱码一区二三区小蝌蚪 | 欧美制服丝袜第一页| 在线欧美小视频| av成人免费观看| 合欧美一区二区三区| 欧美电影在线免费观看网站| 欧美日韩国产成人在线观看| 欧美一进一出视频| 欧美gay视频| 久久国产精品黑丝| 欧美激情精品久久久| 久久成人免费日本黄色| 欧美黄色aa电影| 久久天堂成人| 欧美日韩网址| 久久影院亚洲| 国产精品久久久亚洲一区| 欧美freesex交免费视频| 欧美偷拍一区二区| 亚洲国产成人久久综合一区| 国产精品成人观看视频国产奇米| 欧美成人综合一区| 国产日韩欧美一区二区三区在线观看| 亚洲国产日韩欧美在线99| 国产精品日韩电影| 亚洲黄色三级| 亚洲电影激情视频网站| 午夜精品久久久久99热蜜桃导演| 一本色道久久综合亚洲精品婷婷| 久久精品一区中文字幕| 欧美成人免费大片| 国产欧美日韩亚洲精品| 国产精品三区www17con| 久久久久久亚洲精品杨幂换脸| 久久视频在线免费观看| 亚洲一区制服诱惑| 欧美一区影院| 一区二区三区欧美亚洲| …久久精品99久久香蕉国产| 国产精品va在线播放| 欧美日韩国产成人精品| 国产精品素人视频| 午夜激情久久久| 欧美日韩亚洲一区二区| 亚洲二区在线观看| 影音先锋亚洲电影| 久久综合福利| 欧美激情在线| 99re成人精品视频| 欧美天天视频| 性xx色xx综合久久久xx| 鲁大师成人一区二区三区| 伊人久久av导航| 欧美成人免费全部观看天天性色| 欧美高清视频一二三区| 亚洲看片免费| 国产精品久久久久天堂| 亚洲男同1069视频| 久久久成人精品| 亚洲国产日韩欧美在线99| 久久亚洲春色中文字幕久久久| 亚洲国产精品一区二区www在线| 久久九九热re6这里有精品| 久久久久久久久久久成人| 亚洲国产高清一区| 欧美aⅴ99久久黑人专区| 欧美成人精品1314www| 狠狠色伊人亚洲综合网站色| 欧美ab在线视频| 亚洲久色影视| 亚洲视频欧美视频| 欧美午夜电影网| 久久免费视频在线观看| 免费在线日韩av| 亚洲国产福利在线| 欧美va亚洲va国产综合| 亚洲天堂黄色| 亚洲综合日韩在线| 国产伦精品一区二区三区视频黑人 | 亚洲欧美日韩成人| 欧美综合激情网| 久久综合久久综合这里只有精品 | 欧美午夜一区二区| 亚洲国产精品免费| 亚洲精品一区中文| 亚洲国产精品精华液网站| 亚洲专区一区| 久久精品国产亚洲高清剧情介绍| 影音先锋久久久| 亚洲精品欧美日韩专区| 一区二区精品| 欧美日韩三区| 亚洲美女尤物影院| 久久久噜噜噜久久久| 亚洲尤物精选| 亚洲精品乱码久久久久久黑人| 香蕉亚洲视频| 亚洲伊人伊色伊影伊综合网| 亚洲福利视频一区| 欧美日韩国产免费| 亚洲手机成人高清视频| 麻豆久久婷婷| 欧美一区二区三区视频在线观看| 国产日韩欧美亚洲| 麻豆成人精品| 亚洲一区在线观看免费观看电影高清| 亚洲国产福利在线| 久久精品国产免费观看| 亚洲精品影院|