| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 | 
//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//// Arcane-FX for MIT Licensed Open Source version of Torque 3D from GarageGames// Copyright (C) 2015 Faust Logic, Inc.//// Permission is hereby granted, free of charge, to any person obtaining a copy// of this software and associated documentation files (the "Software"), to// deal in the Software without restriction, including without limitation the// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or// sell copies of the Software, and to permit persons to whom the Software is// furnished to do so, subject to the following conditions://// The above copyright notice and this permission notice shall be included in// all copies or substantial portions of the Software.//// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS// IN THE SOFTWARE.////~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//#include "afx/arcaneFX.h"#include "math/mathIO.h"#include "math/mathUtils.h"#include "afx/afxEffectWrapper.h"#include "afx/afxChoreographer.h"#include "afx/xm/afxXfmMod.h"//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//class afxXM_RandomRotData : public afxXM_BaseData{  typedef afxXM_BaseData Parent;public:  Point3F       axis;  F32           theta_min;  F32           theta_max;  F32           phi_min;  F32           phi_max;public:  /*C*/         afxXM_RandomRotData();   /*C*/         afxXM_RandomRotData(const afxXM_RandomRotData&, bool = false);  void          packData(BitStream* stream) override;  void          unpackData(BitStream* stream) override;  bool          onAdd() override;  bool  allowSubstitutions() const override { return true; }  static void   initPersistFields();  afxXM_Base*   create(afxEffectWrapper* fx, bool on_server) override;  DECLARE_CONOBJECT(afxXM_RandomRotData);};class afxXM_RandomRot : public afxXM_Base{  typedef afxXM_Base Parent;  MatrixF       rand_ori;public:  /*C*/         afxXM_RandomRot(afxXM_RandomRotData*, afxEffectWrapper*);  void  updateParams(F32 dt, F32 elapsed, afxXM_Params& params) override;};//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//IMPLEMENT_CO_DATABLOCK_V1(afxXM_RandomRotData);ConsoleDocClass( afxXM_RandomRotData,   "@brief An xmod datablock.\n\n"   "@ingroup afxXMods\n"   "@ingroup AFX\n"   "@ingroup Datablocks\n");afxXM_RandomRotData::afxXM_RandomRotData(){  axis.set(0,0,1);  theta_min = 0.0f;   theta_max = 360.0f;  phi_min = 0.0f;   phi_max = 360.0f;}afxXM_RandomRotData::afxXM_RandomRotData(const afxXM_RandomRotData& other, bool temp_clone) : afxXM_BaseData(other, temp_clone){  axis = other.axis;  theta_min = other.theta_min;  theta_max = other.theta_max;  phi_min = other.phi_min;  phi_max = other.phi_max;}void afxXM_RandomRotData::initPersistFields(){   docsURL;  addField("axis",      TypePoint3F,  Offset(axis, afxXM_RandomRotData),    "...");  addFieldV("thetaMin", TypeRangedF32,      Offset(theta_min, afxXM_RandomRotData), &CommonValidators::PosDegreeRangeHalf,    "...");  addFieldV("thetaMax", TypeRangedF32,      Offset(theta_max, afxXM_RandomRotData), &CommonValidators::PosDegreeRangeHalf,    "...");  addFieldV("phiMin", TypeRangedF32,      Offset(phi_min, afxXM_RandomRotData), &CommonValidators::PosDegreeRange,    "...");  addFieldV("phiMax", TypeRangedF32,      Offset(phi_max, afxXM_RandomRotData), &CommonValidators::PosDegreeRange,    "...");  Parent::initPersistFields();}void afxXM_RandomRotData::packData(BitStream* stream){  Parent::packData(stream);  mathWrite(*stream, axis);  stream->write(theta_min);  stream->write(theta_max);  stream->write(phi_min);  stream->write(phi_max);}void afxXM_RandomRotData::unpackData(BitStream* stream){  Parent::unpackData(stream);  mathRead(*stream, &axis);  stream->read(&theta_min);  stream->read(&theta_max);  stream->read(&phi_min);  stream->read(&phi_max);}bool afxXM_RandomRotData::onAdd(){  if (Parent::onAdd() == false)    return false;  axis.normalizeSafe();  return true;}afxXM_Base* afxXM_RandomRotData::create(afxEffectWrapper* fx, bool on_server){  afxXM_RandomRotData* datablock = this;  if (getSubstitutionCount() > 0)  {    datablock = new afxXM_RandomRotData(*this, true);    this->performSubstitutions(datablock, fx->getChoreographer(), fx->getGroupIndex());  }  return new afxXM_RandomRot(datablock, fx);}//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//afxXM_RandomRot::afxXM_RandomRot(afxXM_RandomRotData* db, afxEffectWrapper* fxw): afxXM_Base(db, fxw) {   Point3F rand_dir = MathUtils::randomDir(db->axis, db->theta_min, db->theta_max, db->phi_min, db->phi_max);  rand_ori = MathUtils::createOrientFromDir(rand_dir);}void afxXM_RandomRot::updateParams(F32 dt, F32 elapsed, afxXM_Params& params){  params.ori = rand_ori;}//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//
 |