FineKernelToolKit  2.8.10
FK/Loop.h
説明を見る。
00001 /****************************************************************************
00002  *
00003  *  Copyright (c) 1999-2011, Fine Kernel Project, All rights reserved.
00004  *
00005  *  Redistribution and use in source and binary forms,
00006  *  with or without modification, are permitted provided that the
00007  *  following conditions are met:
00008  *
00009  *      - Redistributions of source code must retain the above
00010  *          copyright notice, this list of conditions and the
00011  *          following disclaimer.
00012  *
00013  *      - Redistributions in binary form must reproduce the above
00014  *          copyright notice, this list of conditions and the
00015  *          following disclaimer in the documentation and/or
00016  *          other materials provided with the distribution.
00017  *
00018  *      - Neither the name of the copyright holders nor the names
00019  *          of its contributors may be used to endorse or promote
00020  *          products derived from this software without specific
00021  *          prior written permission.
00022  *
00023  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00024  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00025  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00026  *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00027  *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00028  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
00029  *  (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
00030  *  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
00031  *  HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
00032  *  STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
00033  *  IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00034  *  POSSIBILITY OF SUCH DAMAGE. 
00035  *
00036  ****************************************************************************/
00037 /****************************************************************************
00038  *
00039  *  Copyright (c) 1999-2011, Fine Kernel Project, All rights reserved.
00040  *
00041  *  本ソフトウェアおよびソースコードのライセンスは、基本的に
00042  *  「修正 BSD ライセンス」に従います。以下にその詳細を記します。
00043  *
00044  *  ソースコード形式かバイナリ形式か、変更するかしないかを問わず、
00045  *  以下の条件を満たす場合に限り、再頒布および使用が許可されます。
00046  *
00047  *  - ソースコードを再頒布する場合、上記の著作権表示、本条件一覧、
00048  *      および下記免責条項を含めること。
00049  *
00050  *  - バイナリ形式で再頒布する場合、頒布物に付属のドキュメント等の
00051  *      資料に、上記の著作権表示、本条件一覧、および下記免責条項を
00052  *      含めること。
00053  *
00054  *  - 書面による特別の許可なしに、本ソフトウェアから派生した製品の
00055  *      宣伝または販売促進に、本ソフトウェアの著作権者の名前または
00056  *      コントリビューターの名前を使用してはならない。
00057  *
00058  *  本ソフトウェアは、著作権者およびコントリビューターによって「現
00059  *  状のまま」提供されており、明示黙示を問わず、商業的な使用可能性、
00060  *  および特定の目的に対する適合性に関す暗黙の保証も含め、またそれ
00061  *  に限定されない、いかなる保証もないものとします。著作権者もコン
00062  *  トリビューターも、事由のいかんを問わず、損害発生の原因いかんを
00063  *  問わず、かつ責任の根拠が契約であるか厳格責任であるか(過失その
00064  *  他の)不法行為であるかを問わず、仮にそのような損害が発生する可
00065  *  能性を知らされていたとしても、本ソフトウェアの使用によって発生
00066  *  した(代替品または代用サービスの調達、使用の喪失、データの喪失、
00067  *  利益の喪失、業務の中断も含め、またそれに限定されない)直接損害、
00068  *  間接損害、偶発的な損害、特別損害、懲罰的損害、または結果損害に
00069  *  ついて、一切責任を負わないものとします。
00070  *
00071  ****************************************************************************/
00072 #ifndef __FK_LOOP_HEADER__
00073 #define __FK_LOOP_HEADER__
00074 
00075 #include <FK/Topology.h>
00076 #include <FK/Vector.h>
00077 
00078 class fk_Surface;
00079 class fk_Half;
00080 class fk_Vertex;
00081 
00082 
00083 #ifndef FK_DOXYGEN_USER_PROCESS
00084 
00085 enum fk_LoopCrossStatus {
00086     FK_LOOP_FRONT_CROSS,
00087     FK_LOOP_BACK_CROSS,
00088     FK_LOOP_ONEDGE_CROSS,
00089     FK_LOOP_ONFACE_CROSS,
00090     FK_LOOP_NO_CROSS,
00091     FK_LOOP_ERROR_CROSS
00092 };
00093 
00094 #endif
00095 
00096 
00097 
00099 
00114 class fk_Loop : public fk_Topology, public fk_TopologyMaterial {
00115 
00116     friend class    fk_Operation;
00117     friend class    fk_DataBase;
00118     friend class    fk_FileInput;
00119     friend class    fk_FileOutput;
00120     friend class    fk_IFSetHandle;
00121 
00122  private:
00123     fk_Half                     *oneHalf;
00124     fk_Vector                   norm;
00125     bool                        normFlag, errorFlag;
00126     bool                        tesselateFlag, tesselateMode;
00127     fk_Surface                  *surf;
00128     std::vector<fk_Vertex *>    tesselateVertex;
00129     std::vector<int>            tesselateIndex;
00130     int                         ifsID;
00131 
00132     bool                    SetNormal(void);
00133     void                    ModifyLoop(void);
00134     fk_Half *               SetOneHalf(fk_Half *);
00135     void                    MakeTesselateData(void);
00136 
00137  public:
00139     fk_Loop(int);
00141     virtual ~fk_Loop();
00142 
00143 #ifndef FK_DOXYGEN_USER_PROCESS
00144     void                        Init(int);
00145 #endif
00146 
00148 
00155     fk_Half *                   getOneHalf(void) const;
00156 
00158 
00166     fk_Vector *                 getNormal(void);
00167 
00169 
00176     int                         getVNum(void) const;
00177 
00179 
00196     void                        setTesselateMode(bool mode);
00197 
00199 
00207     bool                        getTesselateMode(void);
00208 
00210 
00221     bool                        isTesselated(void);
00222 
00224 
00231     void                        setSurfGeometry(fk_Surface *surface);
00232 
00234 
00240     fk_Surface *                getSurfGeometry(void);
00241 
00242 #ifndef FK_DOXYGEN_USER_PROCESS
00243 
00244     std::vector<fk_Vector> *    GetTesselatePos(void);
00245     std::vector<fk_Vertex *> *  GetTesselateVertex(void);
00246     std::vector<int> *          GetTesselateIndex(void);
00247     void                        Print(void) const;
00248     bool                        Check(void) const;
00249     bool                        Compare(fk_Loop *) const;
00250     void                        SetIFSID(int);
00251     int                         GetIFSID(void);
00252 
00253     fk_LoopCrossStatus          IsCross(const fk_Vector &,
00254                                         const fk_Vector &,
00255                                         fk_Vector * = NULL);
00256 
00257 #endif
00258 
00259 };
00260 
00261 #endif // !__FK_LOOP_HEADER__
 全て クラス ネームスペース ファイル 関数 変数 型定義 列挙型 列挙型の値 フレンド マクロ定義