FineKernelToolKit 4.2.13
読み取り中…
検索中…
一致する文字列を見つけられません
Modify.h
[詳解]
1#if !defined(__FK_MODIFY_HEADER__)
2#define __FK_MODIFY_HEADER__
3
4#include <FK/Operation.h>
5
6namespace FK {
8
38 class fk_Modify : public fk_Operation {
39
40 public:
42 fk_Modify(fk_DataBase * = nullptr);
43
45 virtual ~fk_Modify();
46
49
51
75
77
109 bool contractEdge(fk_Edge *E, bool R = true);
110
112
128 bool contractEdge(fk_Edge *E, fk_Vector P, bool R = true);
129
131
140
143
145
169 fk_Loop * makePolygon(std::vector<fk_Vector> *array, bool openFlg, bool initFlg = true);
170
172
200 fk_Loop * makePolygon(int num, fk_Vector *array, bool openFlg, bool initFlg = true);
201
203
225 fk_Loop * pushPolygon(std::vector<fk_Vector> *array, bool openFlg = false);
226
228
251 fk_Loop * pushPolygon(int num, fk_Vector *array, bool openFlg = false);
252
254
268 void pushPolygonVertex(fk_Vector pos, bool openFlg);
270
273
275
281 void makePoint(std::vector<fk_Vector> *array);
282
284
291 void makePoint(int num, fk_Vector *array);
292
294
303
306
308
316 void makeLines(std::vector<fk_Vector> *array);
317
319
331 void makeLines(int num, fk_Vector *array);
332
334
343
345
359 bool setLinePos(int ID, fk_Vector pos);
360
362
380 bool setLinePos(int edgeID, int vertexID, fk_Vector pos);
381
383
396 bool changeLine(int edgeID, fk_Vector pos1, fk_Vector pos2);
398
401
403
426 void makeBlock(double x, double y, double z);
427
429
441 void setBlockSize(double x, double y, double z);
442
444
458 void setBlockSize(double length, fk_Axis axis);
459
461
471 void setBlockScale(double scale);
472
474
488 void setBlockScale(double scale, fk_Axis axis);
489
491
503 void setBlockScale(double x, double y, double z);
505
508
510
529 void makeCircle(int div, double rad);
530
532
542 void setCircleRadius(double rad);
543
545
555 void setCircleDivide(int div);
556
558
568 void setCircleScale(double scale);
570
573
575
592 void makeSphere(int div, double rad);
593
595
605 void setSphereRadius(double rad);
606
608
618 void setSphereDivide(int div);
619
621
631 void setSphereScale(double scale);
633
636
638
658 void makePrism(int div, double top, double bottom, double height);
659
661
671 void setPrismDivide(int div);
672
674
684 void setPrismTopRadius(double top);
685
687
697 void setPrismBottomRadius(double bottom);
698
700
710 void setPrismHeight(double height);
712
715
717
736 void makeCone(int div, double rad, double height);
737
739
749 void setConeDivide(int div);
750
752
762 void setConeRadius(double rad);
763
765
775 void setConeHeight(double height);
777
780
782
791 bool moveVPosition(int vertexID, fk_Vector pos, int order = 0);
792
794
805 bool moveVPosition(int vertexID, double x, double y, double z, int order = 0);
806
808
817 bool moveVPosition(int vertexID, double *array, int order = 0);
819
822
824
832 void subdivShape(int count);
833
835
836 private:
837 bool CheckLoop4Cont(fk_Half *);
838 };
839}
840
841#endif // !__FK_MODIFY_HEADER__
842
843/****************************************************************************
844 *
845 * Copyright (c) 1999-2024, Fine Kernel Project, All rights reserved.
846 *
847 * Redistribution and use in source and binary forms,
848 * with or without modification, are permitted provided that the
849 * following conditions are met:
850 *
851 * - Redistributions of source code must retain the above
852 * copyright notice, this list of conditions and the
853 * following disclaimer.
854 *
855 * - Redistributions in binary form must reproduce the above
856 * copyright notice, this list of conditions and the
857 * following disclaimer in the documentation and/or
858 * other materials provided with the distribution.
859 *
860 * - Neither the name of the copyright holders nor the names
861 * of its contributors may be used to endorse or promote
862 * products derived from this software without specific
863 * prior written permission.
864 *
865 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
866 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
867 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
868 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
869 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
870 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
871 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
872 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
873 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
874 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
875 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
876 * POSSIBILITY OF SUCH DAMAGE.
877 *
878 ****************************************************************************/
879/****************************************************************************
880 *
881 * Copyright (c) 1999-2024, Fine Kernel Project, All rights reserved.
882 *
883 * 本ソフトウェアおよびソースコードのライセンスは、基本的に
884 * 「修正 BSD ライセンス」に従います。以下にその詳細を記します。
885 *
886 * ソースコード形式かバイナリ形式か、変更するかしないかを問わず、
887 * 以下の条件を満たす場合に限り、再頒布および使用が許可されます。
888 *
889 * - ソースコードを再頒布する場合、上記の著作権表示、本条件一覧、
890 * および下記免責条項を含めること。
891 *
892 * - バイナリ形式で再頒布する場合、頒布物に付属のドキュメント等の
893 * 資料に、上記の著作権表示、本条件一覧、および下記免責条項を
894 * 含めること。
895 *
896 * - 書面による特別の許可なしに、本ソフトウェアから派生した製品の
897 * 宣伝または販売促進に、本ソフトウェアの著作権者の名前または
898 * コントリビューターの名前を使用してはならない。
899 *
900 * 本ソフトウェアは、著作権者およびコントリビューターによって「現
901 * 状のまま」提供されており、明示黙示を問わず、商業的な使用可能性、
902 * および特定の目的に対する適合性に関す暗黙の保証も含め、またそれ
903 * に限定されない、いかなる保証もないものとします。著作権者もコン
904 * トリビューターも、事由のいかんを問わず、損害発生の原因いかんを
905 * 問わず、かつ責任の根拠が契約であるか厳格責任であるか(過失その
906 * 他の)不法行為であるかを問わず、仮にそのような損害が発生する可
907 * 能性を知らされていたとしても、本ソフトウェアの使用によって発生
908 * した(代替品または代用サービスの調達、使用の喪失、データの喪失、
909 * 利益の喪失、業務の中断も含め、またそれに限定されない)直接損害、
910 * 間接損害、偶発的な損害、特別損害、懲罰的損害、または結果損害に
911 * ついて、一切責任を負わないものとします。
912 *
913 ****************************************************************************/
ソリッドモデルの稜線位相を管理するクラス
Definition Edge.h:41
ソリッドモデルの半稜線位相を管理するクラス
Definition Half.h:25
ソリッドモデルのループ位相を管理するクラス
Definition Loop.h:43
ソリッドモデル変形操作用クラス
Definition Modify.h:38
void makeLines(std::vector< fk_Vector > *array)
線分群生成関数1
void setBlockScale(double scale, fk_Axis axis)
直方体軸方向拡大縮小関数
void makeSphere(int div, double rad)
球形状生成関数
void makeCircle(int div, double rad)
円形状生成関数
void makePoint(std::vector< fk_Vector > *array)
頂点群生成関数1
void setCircleRadius(double rad)
円形状半径設定関数
void makePrism(int div, double top, double bottom, double height)
正多角柱(円柱)形状生成関数
void pushPolygonVertex(fk_Vector pos, bool openFlg)
多角形頂点追加関数
void setPrismHeight(double height)
正多角柱(円柱)高さ設定関数
void setSphereScale(double scale)
球形状拡大縮小関数
bool setLinePos(int edgeID, int vertexID, fk_Vector pos)
線分頂点移動関数2
bool contractEdge(fk_Edge *E, fk_Vector P, bool R=true)
稜線削除関数2
fk_Loop * pushPolygon(std::vector< fk_Vector > *array, bool openFlg=false)
多角形追加関数1
void setPrismDivide(int div)
正多角柱(円柱)角数設定関数
void setPrismBottomRadius(double bottom)
正多角柱(円柱)角数設定関数
fk_Loop * pushPolygon(int num, fk_Vector *array, bool openFlg=false)
多角形追加関数2
fk_Edge * pushLines(fk_Vector pos1, fk_Vector pos2)
線分追加関数
bool changeLine(int edgeID, fk_Vector pos1, fk_Vector pos2)
線分両端点移動関数
bool contractEdge(fk_Edge *E, bool R=true)
稜線削除関数1
void setBlockSize(double x, double y, double z)
直方体辺長変更関数
void setConeRadius(double rad)
正多角錐(円錐)底面半径設定関数
bool moveVPosition(int vertexID, fk_Vector pos, int order=0)
頂点移動関数1
fk_Modify(fk_DataBase *=nullptr)
コンストラクタ
bool setLinePos(int ID, fk_Vector pos)
線分頂点移動関数1
void makePoint(int num, fk_Vector *array)
頂点群生成関数2
fk_Loop * makePolygon(int num, fk_Vector *array, bool openFlg, bool initFlg=true)
多角形生成関数2
void subdivShape(int count)
細分割曲面生成関数
void setCircleScale(double scale)
円形状拡大縮小関数
fk_Vertex * pushPointVertex(fk_Vector pos)
頂点追加関数
void setBlockSize(double length, fk_Axis axis)
直方体個別辺長設定関数
void setConeHeight(double height)
正多角錐(円錐)高さ設定関数
fk_Loop * makePolygon(std::vector< fk_Vector > *array, bool openFlg, bool initFlg=true)
多角形生成関数1
void setCircleDivide(int div)
円形状分割数設定関数
bool checkContract(fk_Edge *E)
稜線削除可能判定関数
bool moveVPosition(int vertexID, double x, double y, double z, int order=0)
頂点移動関数2
void setPrismTopRadius(double top)
正多角柱(円柱)上面半径設定関数
void setSphereDivide(int div)
球形状分割数設定関数
void setSphereRadius(double rad)
球形状半径設定関数
void setConeDivide(int div)
正多角錐(円錐)角数設定関数
void setBlockScale(double scale)
直方体全体拡大縮小関数
void makeLines(int num, fk_Vector *array)
線分群生成関数2
fk_Loop * removeVertexInLoop(fk_Vertex *V)
頂点削除関数
virtual ~fk_Modify()
デストラクタ
bool moveVPosition(int vertexID, double *array, int order=0)
頂点移動関数2
void setBlockScale(double x, double y, double z)
直方体軸方向個別拡大縮小関数
void makeCone(int div, double rad, double height)
正多角錐(円錐)形状生成関数
void makeBlock(double x, double y, double z)
直方体生成関数
オイラー操作用クラス
Definition Operation.h:47
3次元ベクトルを管理するクラス
Definition Vector.h:45
ソリッドモデルの頂点位相を管理するクラス
Definition Vertex.h:26
Fine Kernel Toolkit 名前空間
Definition Angle.h:6
fk_Axis
座標軸を表す列挙型
Definition Vector.h:16