Difference between revisions of "TouchDesigner learning"
Jump to navigation
Jump to search
(→Get Shadertoy shaders working) |
(→Making buttons) |
||
(3 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
+ | =Time= | ||
+ | === Absolute seconds === | ||
+ | <pre> | ||
+ | absTime.seconds | ||
+ | </pre> | ||
+ | |||
+ | === Absolute frames === | ||
+ | <pre> | ||
+ | absTime.frame | ||
+ | </pre> | ||
+ | |||
+ | === Cycle/loop of frames from timeline === | ||
+ | <pre> | ||
+ | me.time.frame | ||
+ | </pre> | ||
+ | |||
=Making custom interface= | =Making custom interface= | ||
=== Making buttons === | === Making buttons === | ||
+ | |||
+ | More informations: https://vimeo.com/jhoepffner | ||
<pre> | <pre> | ||
// Name of the parent node | // Name of the parent node | ||
Line 23: | Line 41: | ||
=== Get Shadertoy shaders working=== | === Get Shadertoy shaders working=== | ||
<pre> | <pre> | ||
+ | More informations: https://nvoid.gitbooks.io/introduction-to-touchdesigner/content/GLSL/12-6-Importing-Shadertoy.html | ||
+ | |||
// Replace in code "void mainImage( bla bla )" by "void main()" | // Replace in code "void mainImage( bla bla )" by "void main()" | ||
// Replace in code "fragCoord" by "gl_FragCoord" | // Replace in code "fragCoord" by "gl_FragCoord" | ||
− | // Carefully add ".xy" when missing ".x" or ".y" after "gl_FragCoord" | + | // Carefully add ".xy" when missing ".x" or ".y" after "gl_FragCoord" in "void main()" part |
// Then add at top of code: | // Then add at top of code: | ||
Line 43: | Line 63: | ||
// For iFrame: | // For iFrame: | ||
absTime.frame | absTime.frame | ||
+ | |||
+ | // In glsl code, declare iChannels (iChannel0, iChannel1...) | ||
+ | // For most of the cases, iChannel0 calls a texture, so: | ||
+ | // Replace iChannel0 by sTD2DInputs[0] | ||
+ | // If iChannel0 calls a cubemap: | ||
+ | // Replace iChannel0 by sTDCubeInputs[0] | ||
+ | // If iChannel0 calls a sound, convert sound to CHOP by a null, then: | ||
+ | // Replace iChannel0 by sTD2DInputs[1] | ||
</pre> | </pre> |
Latest revision as of 17:26, 4 February 2021
Contents
Time
Absolute seconds
absTime.seconds
Absolute frames
absTime.frame
Cycle/loop of frames from timeline
me.time.frame
Making custom interface
Making buttons
More informations: https://vimeo.com/jhoepffner
// Name of the parent node parent().name
Rendering
Get resolution from another node
// Get width and height from render1 node op('render1').width op('render1').height
GLSL
Get Shadertoy shaders working
More informations: https://nvoid.gitbooks.io/introduction-to-touchdesigner/content/GLSL/12-6-Importing-Shadertoy.html // Replace in code "void mainImage( bla bla )" by "void main()" // Replace in code "fragCoord" by "gl_FragCoord" // Carefully add ".xy" when missing ".x" or ".y" after "gl_FragCoord" in "void main()" part // Then add at top of code: layout(location = 0) out vec4 fragColor; uniform vec3 iResolution; uniform float iTime; uniform float iFrame; uniform vec4 iMouse; // In glsl node: // Declare iResolution, iFrame and iTime // For iTime: absTime.seconds // For iFrame: absTime.frame // In glsl code, declare iChannels (iChannel0, iChannel1...) // For most of the cases, iChannel0 calls a texture, so: // Replace iChannel0 by sTD2DInputs[0] // If iChannel0 calls a cubemap: // Replace iChannel0 by sTDCubeInputs[0] // If iChannel0 calls a sound, convert sound to CHOP by a null, then: // Replace iChannel0 by sTD2DInputs[1]