#include <LookupCurves.h>
Classes | |
struct | SKey |
Represents a point on a curve. More... | |
Public Member Functions | |
LookupCurves (const CurveDescription *t) | |
unsigned | size () const |
const char * | curveName (unsigned index) const |
double | getValue (unsigned index, double x) const |
void | getOuterKeys (unsigned index, SKey &leftKey, SKey &rightKey) const |
bool | hasExpression (unsigned index) const |
bool | isIdentity (unsigned index) const |
bool | isConstant (unsigned index) const |
double | getDerivative (unsigned index, double x) const |
double | getNthDerivative (int n, unsigned index, double x) const |
double | getInverse (unsigned index, double y) const |
double | getInverseGeneral (unsigned index, double y) const |
double | getIntegral (unsigned index, double x1, double x2) const |
void | append (Hash &) const |
Knob * | getKnob () const |
Returns the knob that uses this object, may be null. | |
Friends | |
class | ::LookupCurvesKnob |
Provides user-editable lookup curves to a plugin.
Your plugin must include an instance of this object, and must also call LookupCurves_knob() in the knobs() method. The user will then get a mini curve editor in the control panel where they can edit the lookup curves.
This fairly opaque object replaces the array of "Animation" objects that were in the previous Nuke api. This was done to allow more freedom to reimplement the animation editor, and to allow lookup curves that can vary over time.
Although many plugins call evaluate() directly in their engine() method, it is recommended that for maximum speed you should build your own indexed table during _validate() by calling evaluate() at that time to fill it in. For absolute maximum speed, use the append() method to check if the lookup curves have changed since you last filled in your table. A plugin will always have a better idea about the domain, accuracy, and interpolation it needs, so Nuke does not bother even trying to provide an indexed table.
LookupCurves::LookupCurves | ( | const CurveDescription * | t | ) |
Constructor. T should point to an array of CurveDescriptions; these should be terminated by a sentinel CurveDescriptor with a NULL name pointer.
References DD::Image::CurveDescription::name.
unsigned LookupCurves::size | ( | ) | const |
Return how many curves the user can edit. This is defined by the table passed to the constructor. All functions that take an index number can only be called with a number less than this value.
|
inline |
Return the name of the indexed curve, from the table passed to the constructor.
|
inline |
Return the value of lookup curve index at the location x.
|
inline |
fn const void LookupCurves::getOuterKeys(unsigned index, SKey& leftKey, SKey& rightKey) const Return the first and last keys for the curve
|
inline |
Does the curve have an expression? (expressions may not be safely evaluated on worker threads)
|
inline |
Return true if the curve is the identity: evaluate(index,x)==x for all x.
|
inline |
Return true if the curve is constant: evaluate(index,x)==evaluate(index,0) for all x.
|
inline |
Return the first derivative of the curve at x.
|
inline |
Return the n'th derivative of the curve at x. If n is zero this acts like evaluate()
|
inline |
Return x such that evaluate(index,x)==y. This is fairly slow! This is designed to invert color lookup tables. It only works if the derivative is zero or positive everywhere. If the Newton's approximation fails it will do a binary search but it then assumes the answer is between 0 and 1.
|
inline |
Return x such that evaluate(index,x)==y. This is fairly slow! It is well defined for monotonically increasing/decreasing curves, where the inverse lies within the Root node's frame range.
|
inline |
Integrate the curve between x1 and x2.
void LookupCurves::append | ( | Hash & | hash | ) | const |
Modify the hash to reflect the values of all the lookup curves. This can be used to determine if you need to refill the tables.
References DD::Image::Knob::append().
©2025 The Foundry Visionmongers, Ltd. All Rights Reserved. |