FineKernelToolKit  2.9.0
 全て クラス ネームスペース ファイル 関数 変数 型定義 列挙型 列挙型の値 フレンド マクロ定義 ページ
Loop.h
説明を見る。
1 /****************************************************************************
2  *
3  * Copyright (c) 1999-2014, Fine Kernel Project, All rights reserved.
4  *
5  * Redistribution and use in source and binary forms,
6  * with or without modification, are permitted provided that the
7  * following conditions are met:
8  *
9  * - Redistributions of source code must retain the above
10  * copyright notice, this list of conditions and the
11  * following disclaimer.
12  *
13  * - Redistributions in binary form must reproduce the above
14  * copyright notice, this list of conditions and the
15  * following disclaimer in the documentation and/or
16  * other materials provided with the distribution.
17  *
18  * - Neither the name of the copyright holders nor the names
19  * of its contributors may be used to endorse or promote
20  * products derived from this software without specific
21  * prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
26  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
27  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
28  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
29  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
30  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
32  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
33  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34  * POSSIBILITY OF SUCH DAMAGE.
35  *
36  ****************************************************************************/
37 /****************************************************************************
38  *
39  * Copyright (c) 1999-2014, Fine Kernel Project, All rights reserved.
40  *
41  * 本ソフトウェアおよびソースコードのライセンスは、基本的に
42  * 「修正 BSD ライセンス」に従います。以下にその詳細を記します。
43  *
44  * ソースコード形式かバイナリ形式か、変更するかしないかを問わず、
45  * 以下の条件を満たす場合に限り、再頒布および使用が許可されます。
46  *
47  * - ソースコードを再頒布する場合、上記の著作権表示、本条件一覧、
48  * および下記免責条項を含めること。
49  *
50  * - バイナリ形式で再頒布する場合、頒布物に付属のドキュメント等の
51  * 資料に、上記の著作権表示、本条件一覧、および下記免責条項を
52  * 含めること。
53  *
54  * - 書面による特別の許可なしに、本ソフトウェアから派生した製品の
55  * 宣伝または販売促進に、本ソフトウェアの著作権者の名前または
56  * コントリビューターの名前を使用してはならない。
57  *
58  * 本ソフトウェアは、著作権者およびコントリビューターによって「現
59  * 状のまま」提供されており、明示黙示を問わず、商業的な使用可能性、
60  * および特定の目的に対する適合性に関す暗黙の保証も含め、またそれ
61  * に限定されない、いかなる保証もないものとします。著作権者もコン
62  * トリビューターも、事由のいかんを問わず、損害発生の原因いかんを
63  * 問わず、かつ責任の根拠が契約であるか厳格責任であるか(過失その
64  * 他の)不法行為であるかを問わず、仮にそのような損害が発生する可
65  * 能性を知らされていたとしても、本ソフトウェアの使用によって発生
66  * した(代替品または代用サービスの調達、使用の喪失、データの喪失、
67  * 利益の喪失、業務の中断も含め、またそれに限定されない)直接損害、
68  * 間接損害、偶発的な損害、特別損害、懲罰的損害、または結果損害に
69  * ついて、一切責任を負わないものとします。
70  *
71  ****************************************************************************/
72 #ifndef __FK_LOOP_HEADER__
73 #define __FK_LOOP_HEADER__
74 
75 #include <FK/Topology.h>
76 #include <FK/Vector.h>
77 
78 class fk_Surface;
79 class fk_Half;
80 class fk_Vertex;
81 
82 
83 #ifndef FK_DOXYGEN_USER_PROCESS
84 
85 enum fk_LoopCrossStatus {
86  FK_LOOP_FRONT_CROSS,
87  FK_LOOP_BACK_CROSS,
88  FK_LOOP_ONEDGE_CROSS,
89  FK_LOOP_ONFACE_CROSS,
90  FK_LOOP_NO_CROSS,
91  FK_LOOP_ERROR_CROSS
92 };
93 
94 #endif
95 
96 
97 
99 
114 class fk_Loop : public fk_Topology, public fk_TopologyMaterial {
115 
116  friend class fk_Operation;
117  friend class fk_DataBase;
118  friend class fk_FileInput;
119  friend class fk_FileOutput;
120  friend class fk_IFSetHandle;
121 
122  private:
123  fk_Half *oneHalf;
124  fk_Vector norm;
125  bool normFlag, errorFlag;
126  bool tesselateFlag, tesselateMode;
127  fk_Surface *surf;
128  std::vector<fk_Vertex *> tesselateVertex;
129  std::vector<int> tesselateIndex;
130  int ifsID;
131 
132  bool SetNormal(void);
133  void ModifyLoop(void);
134  fk_Half * SetOneHalf(fk_Half *);
135  void MakeTesselateData(void);
136 
137  public:
139  fk_Loop(int);
141  virtual ~fk_Loop();
142 
143 #ifndef FK_DOXYGEN_USER_PROCESS
144  void Init(int);
145 #endif
146 
148 
155  fk_Half * getOneHalf(void) const;
156 
158 
166  fk_Vector * getNormal(void);
167 
169 
176  int getVNum(void) const;
177 
179 
196  void setTesselateMode(bool mode);
197 
199 
207  bool getTesselateMode(void);
208 
210 
221  bool isTesselated(void);
222 
224 
231  void setSurfGeometry(fk_Surface *surface);
232 
234 
240  fk_Surface * getSurfGeometry(void);
241 
242 #ifndef FK_DOXYGEN_USER_PROCESS
243 
244  std::vector<fk_Vector> * GetTesselatePos(void);
245  std::vector<fk_Vertex *> * GetTesselateVertex(void);
246  std::vector<int> * GetTesselateIndex(void);
247  void Print(void) const;
248  bool Check(void) const;
249  bool Compare(fk_Loop *) const;
250  void SetIFSID(int);
251  int GetIFSID(void);
252 
253  fk_LoopCrossStatus IsCross(const fk_Vector &,
254  const fk_Vector &,
255  fk_Vector * = NULL);
256 
257 #endif
258 
259 };
260 
261 #endif // !__FK_LOOP_HEADER__
void setSurfGeometry(fk_Surface *surface)
幾何曲面形状設定関数
fk_Vector * getNormal(void)
法線ベクトル取得関数
ソリッドモデル位相要素用基底クラス
Definition: Topology.h:97
fk_Half * getOneHalf(void) const
接続半稜線取得関数
fk_Surface * getSurfGeometry(void)
幾何曲面形状取得関数
3次元ベクトルを管理するクラス
Definition: Vector.h:110
bool getTesselateMode(void)
テセレーション設定取得関数
ソリッドモデルのループ位相を管理するクラス
Definition: Loop.h:114
friend class fk_FileOutput
Definition: Loop.h:119
int getVNum(void) const
頂点数取得関数
friend class fk_IFSetHandle
Definition: Loop.h:120
ソリッドモデルの頂点位相を管理するクラス
Definition: Vertex.h:95
オイラー操作用クラス
Definition: Operation.h:135
曲面用純粋仮想クラス
Definition: Surface.h:102
friend class fk_DataBase
Definition: Loop.h:117
fk_Loop(int)
コンストラクタ
bool isTesselated(void)
テセレーション状態参照関数
virtual ~fk_Loop()
デストラクタ
ソリッドモデルの半稜線位相を管理するクラス
Definition: Half.h:94
位相要素個別マテリアル管理クラス
Definition: Topology.h:157
void setTesselateMode(bool mode)
テセレーション設定関数
friend class fk_FileInput
Definition: Loop.h:118