X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fmodules%2Fmod_noise%2Fvaluenode_random.cpp;h=2f2157b091abeda23206df672a5db2c92702fcc0;hb=470efd06824232321e3d34f01adcfd94512c4aea;hp=b49b57bc154227dec634a15e41e94ef3b13052b5;hpb=37c6cb877e2379a359285872940e0abe9012caa1;p=synfig.git diff --git a/synfig-core/trunk/src/modules/mod_noise/valuenode_random.cpp b/synfig-core/trunk/src/modules/mod_noise/valuenode_random.cpp index b49b57b..2f2157b 100644 --- a/synfig-core/trunk/src/modules/mod_noise/valuenode_random.cpp +++ b/synfig-core/trunk/src/modules/mod_noise/valuenode_random.cpp @@ -6,7 +6,7 @@ ** ** \legal ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley -** Copyright (c) 2007 Chris Moore +** Copyright (c) 2007, 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 @@ -60,13 +60,16 @@ ValueNode_Random::ValueNode_Random(const ValueBase &value): set_link("radius",ValueNode_Const::create(Real(1))); set_link("seed",ValueNode_Const::create(random.get_seed())); set_link("speed",ValueNode_Const::create(Real(1))); - set_link("smooth",ValueNode_Const::create(int(0))); + set_link("smooth",ValueNode_Const::create(int(RandomNoise::SMOOTH_CUBIC))); switch(get_type()) { case ValueBase::TYPE_ANGLE: set_link("link",ValueNode_Const::create(value.get(Angle()))); break; + case ValueBase::TYPE_BOOL: + set_link("link",ValueNode_Const::create(value.get(bool()))); + break; case ValueBase::TYPE_COLOR: set_link("link",ValueNode_Const::create(value.get(Color()))); break; @@ -83,7 +86,7 @@ ValueNode_Random::ValueNode_Random(const ValueBase &value): set_link("link",ValueNode_Const::create(value.get(Vector()))); break; default: - throw Exception::BadType(ValueBase::type_name(get_type())); + throw Exception::BadType(ValueBase::type_local_name(get_type())); } DCAST_HACK_ENABLE(); @@ -109,7 +112,7 @@ ValueNode_Random::~ValueNode_Random() ValueBase ValueNode_Random::operator()(Time t)const { - typedef const Random::SmoothType Smooth; + typedef const RandomNoise::SmoothType Smooth; Real radius = (*radius_)(t).get(Real()); int seed = (*seed_)(t).get(int()); @@ -124,6 +127,10 @@ ValueNode_Random::operator()(Time t)const return ((*link_)(t).get( Angle()) + Angle::deg(random(Smooth(smooth), 0, 0, 0, speed) * radius)); + case ValueBase::TYPE_BOOL: + return round_to_int((*link_)(t).get( bool()) + + random(Smooth(smooth), 0, 0, 0, speed) * radius) > 0; + case ValueBase::TYPE_COLOR: return (((*link_)(t).get( Color()) + Color(random(Smooth(smooth), 0, 0, 0, speed), @@ -169,35 +176,21 @@ ValueNode_Random::get_name()const String ValueNode_Random::get_local_name()const { - return _("Random"); + return _("RandomNoise"); } bool -ValueNode_Random::set_link_vfunc(int i,ValueNode::Handle x) +ValueNode_Random::set_link_vfunc(int i,ValueNode::Handle value) { assert(i>=0 && i=0 && i=0 && i=0 && irandomize_seed(); + return ret; +} + +void +ValueNode_Random::randomize_seed() +{ + int i = get_link_index_from_name("seed"); + ValueNode::Handle link = get_link_vfunc(i); + if(!link->is_exported() && link->get_name() == "constant") + { + int seed = time(NULL) + rand(); + if (seed < 0) seed = -seed; + random.set_seed(seed); + set_link(i, ValueNode_Const::create(seed)); + } +}