X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;ds=sidebyside;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Fvaluenode_dotproduct.cpp;fp=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Fvaluenode_dotproduct.cpp;h=20f8ae5b078c79feea2edf535d0a53d2c30be560;hb=b035e8067b5b072d68e7de25fe635079d70de8ec;hp=0000000000000000000000000000000000000000;hpb=14e04a85295c165ca5a16c65c6793c0c61f8a67d;p=synfig.git diff --git a/synfig-core/trunk/src/synfig/valuenode_dotproduct.cpp b/synfig-core/trunk/src/synfig/valuenode_dotproduct.cpp new file mode 100644 index 0000000..20f8ae5 --- /dev/null +++ b/synfig-core/trunk/src/synfig/valuenode_dotproduct.cpp @@ -0,0 +1,194 @@ +/* === S Y N F I G ========================================================= */ +/*! \file valuenode_dotproduct.cpp +** \brief Implementation of the "DotProduct" valuenode conversion. +** +** $Id$ +** +** \legal +** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2008 Chris Moore +** +** This package is free software; you can redistribute it and/or +** modify it under the terms of the GNU General Public License as +** published by the Free Software Foundation; either version 2 of +** the License, or (at your option) any later version. +** +** This package is distributed in the hope that it will be useful, +** but WITHOUT ANY WARRANTY; without even the implied warranty of +** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +** General Public License for more details. +** \endlegal +*/ +/* ========================================================================= */ + +/* === H E A D E R S ======================================================= */ + +#ifdef USING_PCH +# include "pch.h" +#else +#ifdef HAVE_CONFIG_H +# include +#endif + +#include "valuenode_dotproduct.h" +#include "valuenode_const.h" +#include "general.h" + +#endif + +/* === U S I N G =========================================================== */ + +using namespace std; +using namespace etl; +using namespace synfig; + +/* === M A C R O S ========================================================= */ + +/* === G L O B A L S ======================================================= */ + +/* === P R O C E D U R E S ================================================= */ + +/* === M E T H O D S ======================================================= */ + +ValueNode_DotProduct::ValueNode_DotProduct(const ValueBase &value): + LinkableValueNode(value.get_type()) +{ + switch(value.get_type()) + { + case ValueBase::TYPE_REAL: + set_link("lhs",ValueNode_Const::create(Vector(1,0))); + set_link("rhs",ValueNode_Const::create(Vector(0,1))); + break; + case ValueBase::TYPE_ANGLE: + set_link("lhs",ValueNode_Const::create(Vector(1,0))); + set_link("rhs",ValueNode_Const::create(Vector(0,1))); + break; + default: + throw Exception::BadType(ValueBase::type_local_name(value.get_type())); + } + + DCAST_HACK_ENABLE(); +} + +LinkableValueNode* +ValueNode_DotProduct::create_new()const +{ + return new ValueNode_DotProduct(get_type()); +} + +ValueNode_DotProduct* +ValueNode_DotProduct::create(const ValueBase &x) +{ + return new ValueNode_DotProduct(x); +} + +ValueNode_DotProduct::~ValueNode_DotProduct() +{ + unlink_all(); +} + +ValueBase +ValueNode_DotProduct::operator()(Time t)const +{ + Vector lhs((*lhs_)(t).get(Vector())); + Vector rhs((*rhs_)(t).get(Vector())); + + switch (get_type()) + { + case ValueBase::TYPE_ANGLE: + return Angle::cos(lhs * rhs / lhs.mag() / rhs.mag()).mod(); + case ValueBase::TYPE_REAL: + return lhs * rhs; + } + + assert(0); + return ValueBase(); +} + +String +ValueNode_DotProduct::get_name()const +{ + return "dotproduct"; +} + +String +ValueNode_DotProduct::get_local_name()const +{ + return _("Dot Product"); +} + +bool +ValueNode_DotProduct::set_link_vfunc(int i,ValueNode::Handle value) +{ + assert(i>=0 && i=0 && i=0 && i=0 && i