FineKernelToolKit  2.9.0
 全て クラス ネームスペース ファイル 関数 変数 型定義 列挙型 列挙型の値 フレンド マクロ定義 ページ
Modify.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_MODIFY_HEADER__
73 #define __FK_MODIFY_HEADER__
74 
75 #include <FK/Operation.h>
76 
78 
107 class fk_Modify : public fk_Operation {
108 
109  private:
110  bool CheckLoop4Cont(fk_Half *);
111 
112  public:
114  fk_Modify(fk_DataBase * = (fk_DataBase *)NULL);
115 
117  virtual ~fk_Modify();
118 
120 
121 
123 
146 
148 
178  bool contractEdge(fk_Edge *E, bool R = true);
179 
181 
195  bool contractEdge(fk_Edge *E, fk_Vector P, bool R = true);
196 
198 
205  bool checkContract(fk_Edge *E);
207 
209 
210 
231  fk_Loop * makePolygon(std::vector<fk_Vector> *array,
232  bool openFlg, bool initFlg = true);
233 
235 
255  fk_Loop * makePolygon(int num, fk_Vector *array,
256  bool openFlg, bool initFlg = true);
257 
259 
277  fk_Loop * pushPolygon(std::vector<fk_Vector> *array,
278  bool openFlg = false);
279 
281 
299  fk_Loop * pushPolygon(int num, fk_Vector *array,
300  bool openFlg = false);
301 
303 
316  void pushPolygonVertex(fk_Vector pos, bool openFlg);
318 
320 
321 
328  void makePoint(std::vector<fk_Vector> *array);
329 
331 
338  void makePoint(int num, fk_Vector *array);
339 
341 
350 
352 
353 
362  void makeLines(std::vector<fk_Vector> *array);
363 
365 
376  void makeLines(int num, fk_Vector *array);
377 
379 
387  fk_Edge * pushLines(fk_Vector pos1, fk_Vector pos2);
388 
390 
402  bool setLinePos(int ID, fk_Vector pos);
403 
405 
420  bool setLinePos(int edgeID, int vertexID, fk_Vector pos);
421 
423 
437  bool changeLine(int edgeID, fk_Vector pos1, fk_Vector pos2);
439 
441 
442 
466  void makeBlock(double x, double y, double z);
467 
469 
481  void setBlockSize(double x, double y, double z);
482 
484 
498  void setBlockSize(double length, fk_Axis axis);
499 
501 
511  void setBlockScale(double scale);
512 
514 
528  void setBlockScale(double scale, fk_Axis axis);
529 
531 
543  void setBlockScale(double x, double y, double z);
545 
547 
548 
568  void makeCircle(int div, double rad);
569 
571 
581  void setCircleRadius(double rad);
582 
584 
594  void setCircleDivide(int div);
595 
597 
607  void setCircleScale(double scale);
609 
611 
612 
630  void makeSphere(int div, double rad);
631 
633 
643  void setSphereRadius(double rad);
644 
646 
656  void setSphereDivide(int div);
657 
659 
669  void setSphereScale(double scale);
671 
673 
674 
695  void makePrism(int div, double top,
696  double bottom, double height);
697 
699 
709  void setPrismDivide(int div);
710 
712 
722  void setPrismTopRadius(double top);
723 
725 
735  void setPrismBottomRadius(double bottom);
736 
738 
748  void setPrismHeight(double height);
750 
752 
753 
773  void makeCone(int div, double rad, double height);
774 
776 
786  void setConeDivide(int div);
787 
789 
799  void setConeRadius(double rad);
800 
802 
812  void setConeHeight(double height);
814 
816 
817 
827  bool moveVPosition(int vertexID, fk_Vector pos, int order = 0);
828 
830 
841  bool moveVPosition(int vertexID, double x, double y, double z,
842  int order = 0);
843 
845 
855  bool moveVPosition(int vertexID, double *array, int order = 0);
857 };
858 
859 #endif // !__FK_MODIFY_HEADER__
fk_Loop * pushPolygon(std::vector< fk_Vector > *array, bool openFlg=false)
多角形追加関数1
void setSphereRadius(double rad)
球形状半径設定関数
void setSphereDivide(int div)
球形状分割数設定関数
bool moveVPosition(int vertexID, fk_Vector pos, int order=0)
頂点移動関数1
void setConeDivide(int div)
正多角錐(円錐)角数設定関数
bool changeLine(int edgeID, fk_Vector pos1, fk_Vector pos2)
線分両端点移動関数
void setPrismBottomRadius(double bottom)
正多角柱(円柱)角数設定関数
void setBlockSize(double x, double y, double z)
直方体辺長変更関数
void pushPolygonVertex(fk_Vector pos, bool openFlg)
多角形頂点追加関数
3次元ベクトルを管理するクラス
Definition: Vector.h:110
fk_Axis
座標軸を表す列挙型
Definition: Vector.h:82
void setCircleDivide(int div)
円形状分割数設定関数
void makeBlock(double x, double y, double z)
直方体生成関数
void setConeRadius(double rad)
正多角錐(円錐)底面半径設定関数
ソリッドモデルのループ位相を管理するクラス
Definition: Loop.h:114
fk_Vertex * pushPointVertex(fk_Vector pos)
頂点追加関数
void setPrismHeight(double height)
正多角柱(円柱)高さ設定関数
void setPrismDivide(int div)
正多角柱(円柱)角数設定関数
fk_Edge * pushLines(fk_Vector pos1, fk_Vector pos2)
線分追加関数
bool checkContract(fk_Edge *E)
稜線削除可能判定関数
fk_Modify(fk_DataBase *=(fk_DataBase *) NULL)
コンストラクタ
void makeCone(int div, double rad, double height)
正多角錐(円錐)形状生成関数
void makeCircle(int div, double rad)
円形状生成関数
void makePrism(int div, double top, double bottom, double height)
正多角柱(円柱)形状生成関数
void makeLines(std::vector< fk_Vector > *array)
線分群生成関数1
ソリッドモデルの頂点位相を管理するクラス
Definition: Vertex.h:95
オイラー操作用クラス
Definition: Operation.h:135
void setConeHeight(double height)
正多角錐(円錐)高さ設定関数
ソリッドモデル変形操作用クラス
Definition: Modify.h:107
void setCircleScale(double scale)
円形状拡大縮小関数
void setSphereScale(double scale)
球形状拡大縮小関数
void setBlockScale(double scale)
直方体全体拡大縮小関数
virtual ~fk_Modify()
デストラクタ
void setPrismTopRadius(double top)
正多角柱(円柱)上面半径設定関数
void makeSphere(int div, double rad)
球形状生成関数
void setCircleRadius(double rad)
円形状半径設定関数
void makePoint(std::vector< fk_Vector > *array)
頂点群生成関数1
fk_Loop * removeVertexInLoop(fk_Vertex *V)
頂点削除関数
ソリッドモデルの半稜線位相を管理するクラス
Definition: Half.h:94
bool setLinePos(int ID, fk_Vector pos)
線分頂点移動関数1
fk_Loop * makePolygon(std::vector< fk_Vector > *array, bool openFlg, bool initFlg=true)
多角形生成関数1
ソリッドモデルの稜線位相を管理するクラス
Definition: Edge.h:110
bool contractEdge(fk_Edge *E, bool R=true)
稜線削除関数1