FineKernelToolKit
2.8.10
|
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_PARTICLE_HEADER__ 00073 #define __FK_PARTICLE_HEADER__ 00074 00075 #include <FK/Base.h> 00076 #include <FK/Vector.h> 00077 #include <FK/Material.h> 00078 #include <FK/Attribute.h> 00079 00080 class fk_Point; 00081 class fk_IDAdmin; 00082 class fk_Shape; 00083 00085 00124 class fk_Particle: public fk_BaseObject, public fk_Attribute { 00125 00126 private: 00127 int id; // 頂点 ID 00128 fk_Point *base; // 全体位相 00129 unsigned int count; // 年齢 00130 fk_Vector velocity; // 速度 00131 fk_Vector accel; // 加速度 00132 00133 public: 00134 #ifndef FK_DOXYGEN_USER_PROCESS 00135 00136 fk_Particle(fk_Point *, int); 00137 virtual ~fk_Particle(); 00138 00139 #endif 00140 00142 00145 void init(void); 00146 00148 00153 int getID(void) const; 00154 00156 00163 unsigned int getCount(void) const; 00164 00166 00171 fk_Vector getPosition(void) const; 00172 00174 00179 void setPosition(const fk_Vector &pos); 00180 00182 00189 void setPosition(double x, double y, double z); 00190 00192 00197 fk_Vector getVelocity(void) const; 00198 00200 00205 void setVelocity(const fk_Vector &vel); 00206 00208 00215 void setVelocity(double x, double y, double z); 00216 00218 00223 fk_Vector getAccel(void) const; 00224 00226 00231 void setAccel(const fk_Vector &acc); 00232 00234 00241 void setAccel(double x, double y, double z); 00242 00244 00251 int getColorID(void) const; 00252 00254 00261 void setColorID(int ID); 00262 00264 00270 bool getDrawMode(void) const; 00271 00273 00279 void setDrawMode(bool mode); 00280 00282 00290 void handle(void); 00291 }; 00292 00294 00315 class fk_ParticleSet: public fk_BaseObject { 00316 00317 private: 00318 std::vector<fk_Particle *> pSet; 00319 fk_IDAdmin *pAdmin; 00320 fk_Point *point; 00321 unsigned int count; 00322 bool allMode, indivMode; 00323 unsigned int maxNum; 00324 00325 protected: 00327 00336 fk_Particle * newParticle(void); 00337 00339 00350 fk_Particle * newParticle(const fk_Vector &pos); 00351 00353 00366 fk_Particle * newParticle(double x, double y, double z); 00367 00369 00378 bool removeParticle(fk_Particle *p); 00379 00381 00390 bool removeParticle(int ID); 00391 00393 00400 unsigned int getCount(void) const; 00401 00403 00410 fk_Particle * getParticle(int ID) const; 00411 00413 00443 fk_Particle * getNextParticle(fk_Particle *p) const; 00444 00446 00451 unsigned int getParticleNum(void) const; 00452 00454 00461 void setMaxSize(unsigned int max); 00462 00464 00471 unsigned int getMaxSize(void) const; 00472 00474 00486 void setColorPalette(int ID, const fk_Color &col); 00487 00489 00504 void setColorPalette(int ID, float R, float G, float B); 00505 00507 00522 void setColorPalette(int ID, double R, double G, double B); 00523 00525 00534 virtual void genMethod(fk_Particle *p); 00535 00537 00544 virtual void allMethod(void); 00545 00547 00557 virtual void indivMethod(fk_Particle *p); 00558 00560 00568 void setAllMode(bool mode); 00569 00571 00578 bool getAllMode(void) const; 00579 00581 00589 void setIndivMode(bool mode); 00590 00592 00599 bool getIndivMode(void) const; 00600 00601 public: 00603 00608 fk_ParticleSet(unsigned int max = 0); 00609 00611 virtual ~fk_ParticleSet(); 00612 00614 00620 void handle(void); 00621 00623 00635 fk_Shape * getShape(void) const; 00636 }; 00637 00638 #endif // !__FK_PARTICLE_HEADER__