FineKernelToolKit  2.9.0
 全て クラス ネームスペース ファイル 関数 変数 型定義 列挙型 列挙型の値 フレンド マクロ定義 ページ
Point.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_POINT_HEADER__
73 #define __FK_POINT_HEADER__
74 
75 #include <FK/Vector.h>
76 #include <FK/Array.H>
77 #include <FK/Shape.h>
78 
79 class fk_Window;
80 
82 
101 class fk_Point: public fk_Shape {
102 
103  friend class fk_PointDraw;
104 
105  private:
106  fk_Palette localPal;
107  fk_Array<fk_FVector> vec;
108  std::vector<char> drawMode;
109  int drawCount;
110  std::vector<int> colorID;
111  int colorCount;
112 
113  bool MakePoint(std::vector<fk_Vector> *);
114  bool MakePoint(int, fk_Vector *);
115 
116  public:
117 
119 
126  fk_Point(std::vector<fk_Vector> *array = NULL);
127 
129  virtual ~fk_Point();
130 
132 
139  int pushVertex(fk_Vector pos);
140 
142 
150  bool setVertex(int ID, fk_Vector pos);
151 
153  /*
154  * 配列データから点群全体を生成します。
155  * 関数を呼ぶ前に存在していた点は全て消去されます。
156  *
157  * \param[in] num 頂点数
158  * \param[in] array 頂点位置ベクトルの配列
159  *
160  * \return 生成に成功すれば true を、失敗すれば false を返します。
161  */
162  bool setVertex(int num, fk_Vector *array);
163 
165  /*
166  * 配列データから点群全体を生成します。
167  * 関数を呼ぶ前に存在していた点は全て消去されます。
168  *
169  * \param[in] array 頂点位置ベクトルの配列
170  *
171  * \return 生成に成功すれば true を、失敗すれば false を返します。
172  */
173  bool setVertex(std::vector<fk_Vector> *array);
174 
176  /*
177  * 頂点を削除します。
178  *
179  * \param[in] ID 頂点ID
180  *
181  * \return 削除に成功すれば true を、失敗すれば false を返します。
182  */
183  bool removeVertex(int ID);
184 
186 
197  fk_FVector * getVertex(int ID);
198 
200 
205  int getSize(void);
206 
208 
215  void setDrawMode(int ID, bool mode);
216 
218 
227  bool getDrawMode(void);
228 
230 
239  bool getDrawMode(int ID);
240 
242 
249  void setColorID(int vID, int cID);
250 
252 
259  bool getColorCount(void);
260 
262 
272  int getColorID(int vID);
273 
275 
282  void allClear(bool matFlag = true);
283 };
284 
285 #endif // !__FK_POINT_HEADER__
単精度浮動小数点型3次元ベクトルを管理するクラス
Definition: Vector.h:793
void setColorID(int vID, int cID)
描画色設定関数
マテリアルパレットを管理するクラス
Definition: Palette.h:95
bool setVertex(int ID, fk_Vector pos)
頂点位置設定関数
3次元ベクトルを管理するクラス
Definition: Vector.h:110
fk_Point(std::vector< fk_Vector > *array=NULL)
コンストラクタ
形状用基底クラス
Definition: Shape.h:86
int getSize(void)
頂点数取得関数
点群を生成、管理するクラス
Definition: Point.h:101
bool getDrawMode(void)
全頂点描画状態参照関数
bool removeVertex(int ID)
頂点削除関数
void allClear(bool matFlag=true)
点群全消去関数
int pushVertex(fk_Vector pos)
頂点追加関数
void setDrawMode(int ID, bool mode)
頂点描画制御関数
int getColorID(int vID)
描画色参照関数
fk_FVector * getVertex(int ID)
頂点位置ベクトル取得関数
bool getColorCount(void)
描画色設定有無参照関数
FLTK 用シーン描画ウィジェットクラス
Definition: Window.h:189
virtual ~fk_Point()
デストラクタ
friend class fk_PointDraw
Definition: Point.h:103