FineKernelToolKit  2.9.0
 全て クラス ネームスペース ファイル 関数 変数 型定義 列挙型 列挙型の値 フレンド マクロ定義 ページ
Operation.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_OPERATION_HEADER__
73 #define __FK_OPERATION_HEADER__
74 
75 #include <vector>
76 #include <FK/DrawCache.h>
77 #include <FK/History.H>
78 
79 #ifdef __FK_OPERATION_CODE__
80 static const int MAKEV = 1;
81 static const int DELV = 2;
82 static const int MOVEV = 3;
83 static const int MAKEE1 = 4;
84 static const int MAKEE2 = 5;
85 static const int MAKEE3 = 6;
86 static const int DELE1 = 7;
87 static const int DELE2 = 8;
88 static const int DELE3 = 9;
89 static const int MAKEL = 10;
90 static const int DELL = 11;
91 static const int SEPL = 12;
92 static const int UNITL = 13;
93 static const int SEPE = 14;
94 static const int UNITE = 15;
95 static const int NEGATE = 16;
96 
97 #endif
98 
100 
135 class fk_Operation : public fk_DrawCache {
136 
137  private:
138  fk_History history;
139  bool historyMode;
140  bool tesselateMode;
141 
142  fk_Loop * SetLoop(fk_Half *, bool,
143  fk_Loop * = NULL, int = FK_UNDEFINED);
144  void UndefVNorm(fk_Vertex *);
145 
146  fk_Vertex * MakeVertex(const fk_Vector, int);
147  bool DeleteVertex(fk_Vertex *);
148  bool MoveVertex(fk_Vertex *, fk_Vector);
149 
150  fk_Edge * MakeEdge1(fk_Vertex *, fk_Vertex *,
151  int = FK_UNDEFINED,
152  int = FK_UNDEFINED,
153  int = FK_UNDEFINED);
154  fk_Edge * MakeEdge2(fk_Vertex *, fk_Vertex *,
155  fk_Half *, fk_Half *, bool, bool,
156  int = FK_UNDEFINED,
157  int = FK_UNDEFINED,
158  int = FK_UNDEFINED);
159  fk_Edge * MakeEdge3(fk_Vertex *, fk_Vertex *,
160  fk_Half *, fk_Half *,
161  fk_Half *, fk_Half *, bool, bool,
162  int = FK_UNDEFINED,
163  int = FK_UNDEFINED,
164  int = FK_UNDEFINED);
165 
166  bool DeleteEdge1(fk_Edge *);
167  bool DeleteEdge2(fk_Half *);
168  bool DeleteEdge3(fk_Edge *);
169 
170  fk_Loop * MakeLoop(fk_Half *, int = FK_UNDEFINED);
171  bool DeleteLoop(fk_Loop *);
172 
173  fk_Edge * SeparateLoop(fk_Half *, fk_Half *, fk_Half *, fk_Half *,
174  bool, bool,
175  int = FK_UNDEFINED,
176  int = FK_UNDEFINED,
177  int = FK_UNDEFINED,
178  int = FK_UNDEFINED);
179 
180  bool UniteLoop(fk_Edge *, fk_Half *);
181  fk_Vertex * SeparateEdge(fk_Edge *, bool, bool, bool, bool,
182  fk_Vector *,
183  int = FK_UNDEFINED,
184  int = FK_UNDEFINED,
185  int = FK_UNDEFINED,
186  int = FK_UNDEFINED);
187 
188  bool UniteEdge(fk_Vertex *);
189  void NegateBody(void);
190 
191 
192  void UndoCom(fk_Command *);
193  void RedoCom(fk_Command *);
194 
195  void DeleteAllTesselateData(void);
196  public:
198  fk_Operation(fk_DataBase * = (fk_DataBase *)NULL);
199 
201  virtual ~fk_Operation();
202 
204 
205 
207 
219  fk_Vertex * makeVertex(const fk_Vector P);
220 
222 
235  bool deleteVertex(fk_Vertex *V);
236 
238 
252  bool moveVertex(fk_Vertex *V, fk_Vector P);
253 
255 
296  fk_Edge * makeEdge(fk_Vertex *V_1, fk_Vertex *V_2,
297  fk_Half *H_11 = (fk_Half *)NULL,
298  fk_Half *H_12 = (fk_Half *)NULL,
299  fk_Half *H_21 = (fk_Half *)NULL,
300  fk_Half *H_22 = (fk_Half *)NULL);
301 
303 
316  bool deleteEdge(fk_Edge *E);
317 
319 
335  fk_Loop * makeLoop(fk_Half *H);
336 
338 
352  bool deleteLoop(fk_Loop *L);
353 
355 
377  fk_Edge * separateLoop(fk_Half *H1, fk_Half *H2);
378 
380 
395  bool uniteLoop(fk_Edge *E);
396 
398 
412 
414 
429  bool uniteEdge(fk_Vertex *V);
430 
432 
447  void negateBody(void);
448 
450 
452 
453 
455 
470  void setHistoryMode(bool mode);
471 
473 
481  bool getHistoryMode(void);
482 
484 
494  void setHistoryMark(void);
495 
497 
546  bool undoHistory(void);
547 
549 
559  bool redoHistory(void);
561 
563 
564 
566 
577  void setTesselateMode(bool mode);
578 
580 
590  bool getTesselateMode(void);
592 
593 #ifndef FK_DOXYGEN_USER_PROCESS
594  void PrintHistorySize(void);
595 #endif
596 };
597 
598 
599 #endif // !__FK_OPERATION_HEADER__
const int FK_UNDEFINED
Definition: Base.h:110
bool redoHistory(void)
REDO 操作実行関数
virtual ~fk_Operation()
デストラクタ
3次元ベクトルを管理するクラス
Definition: Vector.h:110
fk_Operation(fk_DataBase *=(fk_DataBase *) NULL)
コンストラクタ
bool moveVertex(fk_Vertex *V, fk_Vector P)
頂点移動関数
bool getHistoryMode(void)
履歴保存モード参照関数
fk_Vertex * makeVertex(const fk_Vector P)
頂点生成関数
ソリッドモデルのループ位相を管理するクラス
Definition: Loop.h:114
void negateBody(void)
形状反転関数
bool uniteLoop(fk_Edge *E)
ループ結合関数
描画用キャッシュデータを管理するクラス
Definition: DrawCache.h:85
bool deleteVertex(fk_Vertex *V)
頂点削除関数
fk_Edge * makeEdge(fk_Vertex *V_1, fk_Vertex *V_2, fk_Half *H_11=(fk_Half *) NULL, fk_Half *H_12=(fk_Half *) NULL, fk_Half *H_21=(fk_Half *) NULL, fk_Half *H_22=(fk_Half *) NULL)
稜線生成関数
fk_Edge * separateLoop(fk_Half *H1, fk_Half *H2)
ループ分割関数
bool deleteEdge(fk_Edge *E)
稜線削除関数
void setHistoryMode(bool mode)
履歴保存モード設定関数
bool getTesselateMode(void)
形状全体テセレーション状態参照関数
ソリッドモデルの頂点位相を管理するクラス
Definition: Vertex.h:95
オイラー操作用クラス
Definition: Operation.h:135
void setTesselateMode(bool mode)
形状全体テセレーション設定関数
bool uniteEdge(fk_Vertex *V)
稜線結合関数
bool undoHistory(void)
UNDO 操作実行関数
fk_Loop * makeLoop(fk_Half *H)
ループ生成関数
ソリッドモデルの半稜線位相を管理するクラス
Definition: Half.h:94
ソリッドモデルの稜線位相を管理するクラス
Definition: Edge.h:110
void setHistoryMark(void)
履歴マーク設定関数
bool deleteLoop(fk_Loop *L)
ループ削除関数
fk_Vertex * separateEdge(fk_Edge *E)
稜線分離関数