static const char* const CLASS = "AddInputsSol";

static const char* const HELP =
"Add all the inputs together dynamic by solHe"; // Standard plug-in include files. #include "DDImage/NoIop.h"
#include "DDImage/Op.h"
#include "DDImage/NukeWrapper.h"
using namespace DD::Image;
#include "DDImage/Row.h"
#include "DDImage/Tile.h"
#include "DDImage/Knobs.h"
#include "DDImage/ViewerContext.h"
#include <string.h>
#include "stdlib.h" class AddInputsSol : public NoIop
{
int first_frame;
int last_frame;
int _numberKnobs,_numberNewKnobs;
int _change_bool;
char *knoblabel,*newknoblabel,*knobname_f,*newknobname_f,*knobname_l,*newknobname_l;
int _inputsnewnum;
char inputs_s[20];
char *inputs_c;
char temp[20];
char temp_label[20];
int inputsnum; public:
int minimum_inputs() const { return 1; }
int maximum_inputs() const { return 100; } AddInputsSol(Node* node) : NoIop(node),
first_frame(0),
last_frame(99),
_change_bool(0),
knoblabel("Frame Range "),
//newknoblabel("Frame Range"),
knobname_f("fisrt_frame_"),
//newknobname_f("fisrt_frame_"),
knobname_l("last_frame_")
//newknobname_l("last_frame_")
{
_inputsnewnum = inputs();
_numberKnobs = 2;
_numberNewKnobs = _inputsnewnum * 2 - 2;
int inputsnum = 0; } virtual void knobs(Knob_Callback);
//virtual void anyInputHandles(ViewerContext*);
static void addDynamicKnobs(void*, Knob_Callback);
int* get_first_frame() { return &first_frame; }
int* get_last_frame() { return &last_frame; }
char* dynamicName_label(int);
char* dynamicName_first(int);
char* dynamicName_last(int);
void get_real_inputs(); void knobs_replace(void* ); //refresh the set() of knobs.
virtual int knob_changed(Knob* ); //used to get the state that if input number of arrow changed. //void _validate(bool);
const char* Class() const { return CLASS; }
const char* node_help() const { return HELP; }
static const Iop::Description description;
}; /*
void AddInputsSol::_validate(bool for_real)
{
copy_info();
if(_inputsnum != _inputsnewnum)
{
_inputsnum = _inputsnewnum;
knob("lastFrame")->set_value(_inputsnum);
return;
}
input_changed(this->firstOp()); }
*/ void AddInputsSol::knobs(Knob_Callback f)
{
Int_knob(f, &first_frame, "fisrt_frame_1", "Frame Range 1");
//SetFlags(f, Knob::NO_ANIMATION);
Int_knob(f, &last_frame, "last_frame_1", "");
//SetFlags(f, Knob::NO_ANIMATION); SetFlags(f,Knob::KNOB_CHANGED_ALWAYS); //split from here to indicate that the script after here is dynamic. if( !f.makeKnobs() )
{
get_real_inputs();
}
} //compare number of inputs arrows and number of knobs,return a state value.
int AddInputsSol::knob_changed(Knob* k)
{
//caluculate the real sum of inputs() if( _numberKnobs != 2 * inputsnum | inputsnum != inputs() )
{
//refresh the knob list
_change_bool = 1; _numberNewKnobs = replace_knobs(knob("last_frame_1"), _numberNewKnobs, addDynamicKnobs, this->firstOp()); _numberKnobs = 2 + _numberNewKnobs; return 1;
}
else
{ //nothing happen.
_change_bool = 0;
_numberKnobs += 0;
get_real_inputs();
return NoIop::knob_changed(k);
}
} void AddInputsSol::get_real_inputs()
{
int i;
int inputsnum = 0;
for (i = 1;i <= inputs();i++)
{
if( node_input(i,OUTPUT_OP) != NULL )
{
inputsnum += 1;
}
}
} void AddInputsSol::addDynamicKnobs(void* p,Knob_Callback f)
{
if( ( ( AddInputsSol* ) p ) -> _change_bool == 1 )
{
//get the real number of inputs.
( ( AddInputsSol* ) p ) -> get_real_inputs(); //create knobs.
int i,num;
num = ( ( AddInputsSol* ) p ) -> inputsnum - 1; for ( i = 1; i <= ( ( AddInputsSol* ) p ) -> inputs() - 1; i++ )
{
Int_knob(f, ((AddInputsSol*) p) -> get_first_frame(), ((AddInputsSol*) p) -> dynamicName_first(i+1), ((AddInputsSol*) p) -> dynamicName_label(i+1));
Int_knob(f, ((AddInputsSol*) p) -> get_last_frame(), ((AddInputsSol*) p) -> dynamicName_last(i+1), "");
}
}
} char* AddInputsSol::dynamicName_label(int i)
{
char* inputs_c = itoa(i,inputs_s,20);
strcpy(temp_label,knoblabel);
strcat(temp_label,inputs_c);
char* newknoblabel = (LPSTR)temp_label; return newknoblabel;
} char* AddInputsSol::dynamicName_first(int i)
{
char* inputs_c = itoa(i,inputs_s,100);
//char temp[20];
strcpy(temp,knobname_f);
strcat(temp,inputs_c);
char* newknobname_f = (LPSTR)temp; return newknobname_f;
} char* AddInputsSol::dynamicName_last(int i)
{
char* inputs_c = itoa(i,inputs_s,100);
//char temp[20];
strcpy(temp,knobname_l);
strcat(temp,inputs_c);
char* newknobname_l = (LPSTR)temp; return newknobname_l;
} /*! The Iop::Description is how NUKE knows what the name of the operator is,
how to create one, and the menu item to show the user. The menu item may be
0 if you do not want the operator to be visible.
*/ static Iop* AddInputsCreate(Node* node)
{
return new AddInputsSol(node);
}
static Iop* build(Node* node) { return new NukeWrapper(new AddInputsSol(node)); }
const Iop::Description AddInputsSol::description ( CLASS, "AddInputsSol",
AddInputsCreate );

国内正经搞NDK开发的TD不多,相关研究文章也很少,我就放个自己写的源码做参考吧,写的很乱,希望能给看到这篇文章的人一点启发。

放一个Dynamicinputs corresponding to Dynamicknobs的Node源码的更多相关文章

  1. node源码详解(二 )—— 运行机制 、整体流程

    本作品采用知识共享署名 4.0 国际许可协议进行许可.转载保留声明头部与原文链接https://luzeshu.com/blog/nodesource2 本博客同步在https://cnodejs.o ...

  2. mac下编译node源码

    看过一篇win7 64x下面编译node的文章,链接地址:编译nodejs及其源码研究 下面学习一下在mac下面如何编译node源码. 过程也挺简单. 1.下载源码. > mkdir nodes ...

  3. 分享一个与ABP配套使用的代码生成器源码

    点这里进入ABP系列文章总目录 分享一个与ABP配套使用的代码生成器源码 真对不起关注我博客的朋友, 因最近工作很忙, 很久没有更新博客了.以前答应把自用的代码生成器源码共享出来, 也一直没有时间整理 ...

  4. 整合了一个功能强大完善的OA系统源码,php全开源 界面漂亮美观

    整合了一个功能强大完善的OA系统源码,php全开源界面漂亮美观.需要的同学联系Q:930948049

  5. node源码详解(三)—— js代码在node中的位置,process、require、module、exports的由来

    本作品采用知识共享署名 4.0 国际许可协议进行许可.转载保留声明头部与原文链接https://luzeshu.com/blog/nodesource3 本博客同步在https://cnodejs.o ...

  6. node源码详解(三)

    本作品采用知识共享署名 4.0 国际许可协议进行许可.转载保留声明头部与原文链接https://luzeshu.com/blog/nodesource3 本博客同步在https://cnodejs.o ...

  7. node源码详解(四) —— js代码如何调用C++的函数

    本作品采用知识共享署名 4.0 国际许可协议进行许可.转载保留声明头部与原文链接https://luzeshu.com/blog/nodesource4 本博客同步在https://cnodejs.o ...

  8. node源码详解 (一)

    本作品采用知识共享署名 4.0 国际许可协议进行许可.转载保留声明头部与原文链接https://luzeshu.com/blog/nodesource1 本博客同步在https://cnodejs.o ...

  9. 一个Python开源项目-哈勃沙箱源码剖析(下)

    前言 在上一篇中,我们讲解了哈勃沙箱的技术点,详细分析了静态检测和动态检测的流程.本篇接着对动态检测的关键技术点进行分析,包括strace,sysdig,volatility.volatility的介 ...

随机推荐

  1. SQL注入之Sqli-labs系列第二十关(基于头部的cookie POST报错注入)

    开始挑战第十八关(Cookie Injection-Error Based- string) 前言: 通常开发人员在开发过程中会特别注意到防止恶意用户进行恶意的注入操作,因此会对传入的参数进行适当的过 ...

  2. MySQL将DESC等关键字作为列名表名的处理方式

    面试被问到一个问题,假如MySQL中的关键字在查询语句中作为列明或者表名出现,应该怎么处理. 例如 select desc from t; 首先创建一张表,包含两个字段,id和desc 插入了三条数据 ...

  3. Python学习笔记第二十三周(Flask架构)

    目录: 一.变量引用 内容: 备注:PyCharm小技巧,comm+alt+l  自动修改格式,comm+alt+return  向上添加新行 一.变量引用 1.url生成 from flask im ...

  4. Django中HtttpRequest请求

    1.什么是HttpRequest HttpRequest,就是对请求对象的封装,里面封装的是请求过程中的所有信息.在Django中HttpRequest被封装成request对象并封装到视图处理函数中 ...

  5. 编译Thrift支持golang

    本文已经是很久以前的文章了,也不知道新版本thrift如何 Thrift是一个跨语言的服务部署框架,Thrift通过一个中间语言(IDL, 接口定义语言)来定义RPC的接口和数据类型,然后通过一个编译 ...

  6. SQLI DUMB SERIES-5

    less5 (1)输入单引号,回显错误,说明存在注入点.输入的Id被一对单引号所包围,可以闭合单引号 (2)输入正常时:?id=1 说明没有显示位,因此不能使用联合查询了:可以使用报错注入,有两种方式 ...

  7. inner join 与一般笛卡尔积的区别

    inner join 与一般笛卡尔积的区别:inner join是笛卡尔积的特殊形式.如果有表a和表b,表a有m条记录,表b有n条记录,则一般笛卡尔积后得到的记录条数是m*n条,记录之间的组合是随意的 ...

  8. SimpleDateFormat未抛出ParseException

    关于SimpleDateFormat的不严格性[技术探讨]今天一组员写了几段Java代码,发现如下问题:        SimpleDateFormat sdf = new SimpleDateFor ...

  9. Eclipse和Intel idea的常用技巧

    使用Eclipse的几个必须掌握的快捷方式   “工若善其事,必先利其器”,感谢Eclipse,她 使我们阅读一个大工程的代码更加容易,在阅读的过程中,我发现掌握几个Eclipse的快捷键会使阅读体验 ...

  10. DevExpress皮肤样式

    [时间] 2016-02-15 11:41:11 天气晴 没有雾霾难得的好天气!!! [工具] (1)Visual Studio 2015 (2)DevExpress15.2.3 [感言] 一直以来都 ...