| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 | 
//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//// 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 <typeinfo>#include "afx/arcaneFX.h"#include "afx/afxEffectDefs.h"#include "afx/afxEffectWrapper.h"#include "afx/afxChoreographer.h"#include "afx/afxResidueMgr.h"#include "afx/ce/afxBillboard.h"//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//// afxEA_Billboard -- This is the adapter for geometry primitives.class afxEA_Billboard : public afxEffectWrapper{  typedef afxEffectWrapper Parent;  afxBillboardData*  bb_data;  afxBillboard*      bb;  void              do_runtime_substitutions();public:  /*C*/             afxEA_Billboard();  /*D*/             ~afxEA_Billboard();  void      ea_set_datablock(SimDataBlock*) override;  bool      ea_start() override;  bool      ea_update(F32 dt) override;  void      ea_finish(bool was_stopped) override;  void      ea_set_scope_status(bool flag) override;  void      onDeleteNotify(SimObject*) override;  void      getUpdatedBoxCenter(Point3F& pos) override;  void      getBaseColor(LinearColorF& color) override { if (bb_data) color = bb_data->color; }};afxEA_Billboard::afxEA_Billboard(){  bb_data = 0;  bb = 0;}afxEA_Billboard::~afxEA_Billboard(){  if (bb)    bb->deleteObject();  if (bb_data && bb_data->isTempClone())    delete bb_data;  bb_data = 0;}void afxEA_Billboard::ea_set_datablock(SimDataBlock* db){  bb_data = dynamic_cast<afxBillboardData*>(db);}bool afxEA_Billboard::ea_start(){  if (!bb_data)  {    Con::errorf("afxEA_Billboard::ea_start() -- missing or incompatible datablock.");    return false;  }  do_runtime_substitutions();  return true;}bool afxEA_Billboard::ea_update(F32 dt){  if (!bb)  {    // create and register effect    bb = new afxBillboard();    bb->onNewDataBlock(bb_data, false);    if (!bb->registerObject())    {      delete bb;      bb = 0;      Con::errorf("afxEA_Billboard::ea_update() -- effect failed to register.");      return false;    }    deleteNotify(bb);    ///bb->setSequenceRateFactor(datablock->rate_factor/prop_time_factor);    bb->setSortPriority(mDatablock->sort_priority);  }  if (bb)  {    bb->live_color = mUpdated_color;    if (mDo_fades)    {      bb->setFadeAmount(mFade_value);    }    bb->setTransform(mUpdated_xfm);    bb->setScale(mUpdated_scale);  }  return true;}void afxEA_Billboard::ea_finish(bool was_stopped){  if (!bb)    return;  bb->deleteObject();  bb = 0;}void afxEA_Billboard::ea_set_scope_status(bool in_scope){  if (bb)    bb->setVisibility(in_scope);}void afxEA_Billboard::onDeleteNotify(SimObject* obj){  if (bb == dynamic_cast<afxBillboard*>(obj))    bb = 0;  Parent::onDeleteNotify(obj);}void afxEA_Billboard::getUpdatedBoxCenter(Point3F& pos){  if (bb)    pos = bb->getBoxCenter();}void afxEA_Billboard::do_runtime_substitutions(){  // only clone the datablock if there are substitutions  if (bb_data->getSubstitutionCount() > 0)  {    // clone the datablock and perform substitutions    afxBillboardData* orig_db = bb_data;    bb_data = new afxBillboardData(*orig_db, true);    orig_db->performSubstitutions(bb_data, mChoreographer, mGroup_index);  }}//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//class afxEA_BillboardDesc : public afxEffectAdapterDesc, public afxEffectDefs {  static afxEA_BillboardDesc desc;public:  bool  testEffectType(const SimDataBlock*) const override;  bool  requiresStop(const afxEffectWrapperData*, const afxEffectTimingData&) const override;  bool  runsOnServer(const afxEffectWrapperData*) const override { return false; }  bool  runsOnClient(const afxEffectWrapperData*) const override { return true; }  afxEffectWrapper* create() const override { return new afxEA_Billboard; }};//~~~~~~~~~~~~~~~~~~~~//afxEA_BillboardDesc afxEA_BillboardDesc::desc;bool afxEA_BillboardDesc::testEffectType(const SimDataBlock* db) const{  return (typeid(afxBillboardData) == typeid(*db));}bool afxEA_BillboardDesc::requiresStop(const afxEffectWrapperData* ew, const afxEffectTimingData& timing) const{  return (timing.lifetime < 0);}//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//
 |