projects
/
synfig.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Use the translated version of the type name in the parameter dialog.
[synfig.git]
/
synfig-core
/
trunk
/
src
/
synfig
/
valuenode_scale.cpp
diff --git
a/synfig-core/trunk/src/synfig/valuenode_scale.cpp
b/synfig-core/trunk/src/synfig/valuenode_scale.cpp
index
d6fe03a
..
9c2924a
100644
(file)
--- a/
synfig-core/trunk/src/synfig/valuenode_scale.cpp
+++ b/
synfig-core/trunk/src/synfig/valuenode_scale.cpp
@@
-1,11
+1,12
@@
/* === S Y N F I G ========================================================= */
/*! \file valuenode_scale.cpp
/* === S Y N F I G ========================================================= */
/*! \file valuenode_scale.cpp
-** \brief
Template File
+** \brief
Implementation of the "Scale" valuenode conversion.
**
** $Id$
**
** \legal
** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
**
** $Id$
**
** \legal
** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
+** Copyright (c) 2007 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
**
** This package is free software; you can redistribute it and/or
** modify it under the terms of the GNU General Public License as
@@
-33,11
+34,11
@@
#include "valuenode_scale.h"
#include "valuenode_const.h"
#include <stdexcept>
#include "valuenode_scale.h"
#include "valuenode_const.h"
#include <stdexcept>
-#include <cassert>
#include "color.h"
#include "vector.h"
#include "time.h"
#include "angle.h"
#include "color.h"
#include "vector.h"
#include "time.h"
#include "angle.h"
+#include <ETL/misc>
#endif
#endif
@@
-175,11
+176,7
@@
synfig::ValueNode_Scale::operator()(Time t)const
return ret;
}
else if(get_type()==ValueBase::TYPE_INTEGER)
return ret;
}
else if(get_type()==ValueBase::TYPE_INTEGER)
- {
- Real ret = (*value_node)(t).get(int())*(*scalar)(t).get(Real()) + 0.5f;
- if (ret < 0) return static_cast<int>(ret-1);
- return static_cast<int>(ret);
- }
+ return round_to_int((*value_node)(t).get(int())*(*scalar)(t).get(Real()));
else if(get_type()==ValueBase::TYPE_REAL)
return (*value_node)(t).get(Real())*(*scalar)(t).get(Real());
else if(get_type()==ValueBase::TYPE_TIME)
else if(get_type()==ValueBase::TYPE_REAL)
return (*value_node)(t).get(Real())*(*scalar)(t).get(Real());
else if(get_type()==ValueBase::TYPE_TIME)
@@
-195,8
+192,7
@@
synfig::ValueNode_Scale::operator()(Time t)const
bool
ValueNode_Scale::set_link_vfunc(int i,ValueNode::Handle x)
{
bool
ValueNode_Scale::set_link_vfunc(int i,ValueNode::Handle x)
{
- if(!(i==0 || i==1))
- return false;
+ assert(i>=0 && i<link_count());
if(i==0 && !set_value_node(x))
return false;
if(i==0 && !set_value_node(x))
return false;
@@
-212,7
+208,8
@@
ValueNode_Scale::set_link_vfunc(int i,ValueNode::Handle x)
ValueNode::LooseHandle
ValueNode_Scale::get_link_vfunc(int i)const
{
ValueNode::LooseHandle
ValueNode_Scale::get_link_vfunc(int i)const
{
- assert(i==0 || i==1);
+ assert(i>=0 && i<link_count());
+
if(i==0)
return value_node;
else if(i==1)
if(i==0)
return value_node;
else if(i==1)
@@
-229,7
+226,8
@@
ValueNode_Scale::link_count()const
String
ValueNode_Scale::link_local_name(int i)const
{
String
ValueNode_Scale::link_local_name(int i)const
{
- assert(i==0 || i==1);
+ assert(i>=0 && i<link_count());
+
if(i==0)
return _("Link");
else if(i==1)
if(i==0)
return _("Link");
else if(i==1)
@@
-240,7
+238,8
@@
ValueNode_Scale::link_local_name(int i)const
String
ValueNode_Scale::link_name(int i)const
{
String
ValueNode_Scale::link_name(int i)const
{
- assert(i==0 || i==1);
+ assert(i>=0 && i<link_count());
+
if(i==0)
return "link";
else if(i==1)
if(i==0)
return "link";
else if(i==1)