Difference between revisions of "Introduction to TouchDesigner"

From Interaction Station Wiki
Jump to navigation Jump to search
 
(35 intermediate revisions by the same user not shown)
Line 1: Line 1:
 +
[[File:Touchdesigner.png|500px|thumb|right|Interactive brush in TouchDesigner]]
 
=What is TouchDesigner and what you can do it=
 
=What is TouchDesigner and what you can do it=
 
TouchDesigner is a real-time visual programming software used for creating interactive multimedia and video installations.  
 
TouchDesigner is a real-time visual programming software used for creating interactive multimedia and video installations.  
Line 9: Line 10:
  
 
==Examples==
 
==Examples==
live stuff but also graphics for ads
+
TouchDesigner is used for a variety of applications including: generative art, projection mapping, audio-visual performances, interactive installations, VJing and motion graphics.
 +
Some examples of work that you can do with Arduino:
 +
<div style="font-family:monospace;background-color:lightyellow;">
 +
+ [https://www.behance.net/gallery/132238433/Interactive-Graphics-Arduino-TouchDesigner?locale=en_US TouchDesigner and electronics] <br>
 +
+ [https://www.instagram.com/p/DCnHVAEy1n1/ TouchDesigner and electronics x 2] <br>
 +
+ [https://www.instagram.com/pepepepebrick/ Audio reactive and body tracking, pepepepebrick] <br>
 +
+ [https://www.noragibsonvisualist.com/ Nora Gibson, "Choreographies" in TouchDesigner]<br>
 +
+ [https://vimeo.com/668534771 EINDER, Lumus Instruments] <br>
 +
+ [https://www.collectifscale.com/ Collectif Scale] <br>
 +
+ [https://ars.electronica.art/starts-prize/en/cmd/ CMD: Experiment in Bio Algorithmic Politics, Michael Sedbon]<br>
 +
+ [https://www.instagram.com/p/C9jff4ayGSL/ Illustration and Projection Mapping, Ash Kumar]<br>
 +
+ [https://studiodumbar.com/work Motion Graphics Examples]
 +
</div>
  
 
=Let's get started: TD's Interface=
 
=Let's get started: TD's Interface=
Line 82: Line 95:
 
Connect an <code>out</code> to the image you want to see on perform mode. Click the ^ symbol at the top-left corner to open the perform window. Press <code>esc</code> to close it.
 
Connect an <code>out</code> to the image you want to see on perform mode. Click the ^ symbol at the top-left corner to open the perform window. Press <code>esc</code> to close it.
 
==The Noise TOP==
 
==The Noise TOP==
 +
--> Check the wiki for in-depth explanation of the parameters: https://docs.derivative.ca/Noise_TOP<br>
 
[[File:noise1.png|600px|frameless]] <br><br>
 
[[File:noise1.png|600px|frameless]] <br><br>
 +
Use the python code <code>absTime.seconds*0.5</code>
 +
<br>
 
[[File:noise2.png|600px|frameless]] <br><br>
 
[[File:noise2.png|600px|frameless]] <br><br>
 
[[File:noise3.png|600px|frameless]]
 
[[File:noise3.png|600px|frameless]]
  
=Connecting TOPs and CHOPs=
+
=Connecting TOPs and CHOPs: Making an image react to sound=
  
[[File:Circlecomp1.png|700px|frameless]]<br><br>
+
[[File:audio1.png|700px|frameless]]<br><br>
[[File:Circlecomp2.png|700px|frameless]]<br><br>
+
[[File:audio2.png|700px|frameless]]<br><br>
[[File:Circlecomp3.png|700px|frameless]]<br><br>
+
[[File:audio3.png|700px|frameless]]<br><br>
[[File:Circlecomp4.png|700px|frameless]]<br><br>
+
[[File:audio4.png|700px|frameless]]<br><br>
[[File:Circlecomp5.png|700px|frameless]]<br><br>
+
[[File:audio5.png|700px|frameless]]<br><br>
[[File:Circlecomp6.png|700px|frameless]]<br><br>
+
[[File:audio6.png|700px|frameless]]<br><br>
[[File:Circlecomp7.png|700px|frameless]]<br><br>
+
[[File:audio7.png|700px|frameless]]<br><br>
[[File:Circlecomp8.png|700px|frameless]]<br><br>
+
[[File:audio8.png|700px|frameless]]<br><br>
[[File:Circlecomp9.png|700px|frameless]]<br><br>
+
[[File:audio9.png|700px|frameless]]<br><br>
[[File:Circlecomp10.png|700px|frameless]]<br><br>
+
[[File:audio10.png|700px|frameless]]<br><br>
 +
[[File:audio11.png|700px|frameless]]<br><br>
 +
[[File:audio12.png|700px|frameless]]<br><br>
 +
[[File:audio13.png|700px|frameless]]<br><br>
 +
[[File:audio14.png|700px|frameless]]<br><br>
 
==Exporting images & MP4s==
 
==Exporting images & MP4s==
[[File:Circlecomp11.png|700px|frameless]]
+
[[File:audio15.png|700px|frameless]]<br>
 
*Connect a <code>movie file out</code>
 
*Connect a <code>movie file out</code>
 
*Select the video/image format  
 
*Select the video/image format  
* Turn the record button on to start recording. You will see the file being created when you stop the recording
+
*Turn the record button on to start recording. You will see the file being created when you stop the recording
==Make a TOP reacting to Audio==
+
[[File:audio16.png|700px|frameless]]<br>
[[File:audioTD.png|700px|frameless]]<br><br>
+
Because we are working with an audio track with a beginning and an end we want to make sure to start recording when the track starts.
[[File:audiotd2.png|700px|frameless]]<br><br>
+
*Add a <code>keyboard in</code>
 +
*Export its value to the cue <code>pulse</code> on <code>audio file in</code> menu to restart the sound everytime you hit the key
 +
*Connect the <code>keyboard in</code> with a <code>logic</code> and select the option <code>Channel pre op: Toggle</code>
 +
*Export this last value on the <code>record</code> button on the <code>movie file out</code>
 +
 
 +
[[File:audio17.png|700px|frameless]]<br>
 +
 
 +
=The Feedback l∞p=
 +
[[File:September loop.jpg|400px]]<br>
 +
==What is a feedback loop?==
 +
+ A feedback loop is a process where the output of a system is used as input to refine and improve the system itself.
 +
[[File:Infinitemirror.jpg|300px|thumb]]
 +
A very well know example of this is the camera in front of another camera or a mirror in front of another mirror.
 +
Here's a simple breakdown:<br>
 +
1. First Camera Captures: The first camera captures the scene, which includes the second camera. <br>
 +
2. Second Camera Captures: The second camera captures the output of the first camera.<br>
 +
3. Display Loop: The output from the second camera is fed back into the first camera’s view, creating a continuous loop.<br>
 +
4. Infinite Loop Effect: This setup results in an image within an image within an image, and so on, creating a tunnel-like or infinite loop effect.
 +
 
 +
==How does it work?==
 +
 
 +
--> #Image: You have an initial image.
 +
--> #Process: This image is then processed. Maybe you apply some effects or transformations.
 +
--> #Output: The processed image is displayed.
 +
--> #Feedback: Now, you take that output image and feed it back into the system as a new input.
 +
--> #Repeat: The system captures this new input (which includes the previous output) and the loop continues.
 +
 
 +
==Making an Interactive brush: Feedback loop in TouchDesigner==
 +
[https://www.youtube.com/watch?v=83K3QEK6Iv0 How does it work in TouchDesigner?]
 +
 
 +
[[File:feed1.png|700px|frameless]]<br><br>
 +
[[File:feed2.png|700px|frameless]]<br><br>
 +
[[File:feed3.png|700px|frameless]]<br><br>
 +
[[File:feed4.png|700px|frameless]]<br><br>
 +
[[File:feed5.png|700px|frameless]]<br><br>
 +
[[File:feed6.png|700px|frameless]]<br><br>
 +
[[File:feed7.png|700px|frameless]]<br><br>
 +
[[File:feed8.png|700px|frameless]]<br><br>
 +
[[File:feed9.png|700px|frameless]]<br><br>
 +
[[File:feed10.png|700px|frameless]]<br><br>
 +
[[File:feed11.png|700px|frameless]]<br><br>
 +
[[File:feed12.png|700px|frameless]]<br><br>
 +
 
 +
[[Category:Station Skills]]
 
[[Category:TouchDesigner]]
 
[[Category:TouchDesigner]]

Latest revision as of 11:03, 5 December 2024

Interactive brush in TouchDesigner

What is TouchDesigner and what you can do it

TouchDesigner is a real-time visual programming software used for creating interactive multimedia and video installations. It is used for a variety of applications, from interactive installations, live events, projection mapping and more. The fact that can run in real time makes it ideal for interactive pieces. As well you can use it to create generative graphics, 2D and 3D animations, soundscapes and so on.

TouchDesigner is a flexible tool that makes it easy to bridge connections between different systems. It supports many devices and protocols. This ability to communicate between different kind of software and hardware is what we call interoperability and it is one of the main reasons makers and professionals use this tool.

Examples

TouchDesigner is used for a variety of applications including: generative art, projection mapping, audio-visual performances, interactive installations, VJing and motion graphics. Some examples of work that you can do with Arduino:

+ TouchDesigner and electronics
+ TouchDesigner and electronics x 2
+ Audio reactive and body tracking, pepepepebrick
+ Nora Gibson, "Choreographies" in TouchDesigner
+ EINDER, Lumus Instruments
+ Collectif Scale
+ CMD: Experiment in Bio Algorithmic Politics, Michael Sedbon
+ Illustration and Projection Mapping, Ash Kumar
+ Motion Graphics Examples

Let's get started: TD's Interface

When you open a new TD file you will always see this example showing some capabilities of the software. Let's check what happens here: We have a static image of beans and we have a noise wave. This noise wave is translated into pixel values and applied on the static image to create an animation. The image is then used as a texture for a geometry.

MainpageTD.png

Let's have a look at the main elements of the interface:

Pane : TouchDesigner's work area. If you double click on the pane you will see a menu with the different operators.

Network : a system of operators. The example that we see on the screen is a network.

Operators : the building blocks of your network. You can add a new one by double clicking on the pane. In TouchDesigner, operators are the building blocks for creating visual effects and interactive projects. They can be used to manipulate images, audio, and video, as well as control other operators and perform calculations. Operators can be connected together in a network, where the output of one operator becomes the input for another.
There are different types:

_CHOP_ Channel Operators are used for motion, audio, animation, and control signals.
__DAT__ Data Operators are for ASCII text as plain text, scripts, XML, and tables.
__SOP__ Surface Operators are the native 3D objects of TouchDesigner responsible for 3D points, polygons, and other 3D "primitives"
__MAT__ Material Operators are used for applying materials and shaders to the 3D rendering pipeline.
__TOP__ Texture Operators handle all 2D image operations.
_COMP_ Component Operators represent 3D objects, panel components, and other various operators. These components can house entire networks of other operators.

When you select an operator you will see a menu with its parameters appearing on the left side of your screen.


Timeline : at the bottom of you workspace. You always see it running as TD is constantly working in real-time. Most of the time you will not need to interfere with it. Especially at the beginning of working with TD it can happen that things do not work as expected: a lot of times you just paused the timeline :)

Perform mode : the ^ symbol at the top-left corner. Makes you able to see the content of a out operator in a separate window. This what you are going to project/see on a screen when you finalized your project. To get out of Perform mode press esc on your keyboard. If you close you will close the full project. Be careful.

Palette menu : on the left your screen. Contains special components.

Components : an Operator Family that contains its own Network.

Check here the TD Glossary

Knowing where you are in the project

As many programming systems TD works with nesting functions which means that you can have several networks happening inside each "block". If you check the location bar at the top of the pane you should see the path to your project:

🏠︎/project1/>> 

If you start zooming out you will get out of the project1 view and end up the home space.

🏠︎/>> 

It looks like this:

HomeTD.png

If this happens, do not build your network here but go back inside your project and work there. Zoom inside the project1 block to get back to the previous view.

Working with TOPS

TOPs are texture operators. They handle all sorts of effects and manipulations happening on 2D images.

Tops1.png

You can link them to each other to keep adding effects.

Tops2.png

Connect an out to the image you want to see on perform mode. Click the ^ symbol at the top-left corner to open the perform window. Press esc to close it.

The Noise TOP

--> Check the wiki for in-depth explanation of the parameters: https://docs.derivative.ca/Noise_TOP
Noise1.png

Use the python code absTime.seconds*0.5
Noise2.png

Noise3.png

Connecting TOPs and CHOPs: Making an image react to sound

Audio1.png

Audio2.png

Audio3.png

Audio4.png

Audio5.png

Audio6.png

Audio7.png

Audio8.png

Audio9.png

Audio10.png

Audio11.png

Audio12.png

Audio13.png

Audio14.png

Exporting images & MP4s

Audio15.png

  • Connect a movie file out
  • Select the video/image format
  • Turn the record button on to start recording. You will see the file being created when you stop the recording

Audio16.png
Because we are working with an audio track with a beginning and an end we want to make sure to start recording when the track starts.

  • Add a keyboard in
  • Export its value to the cue pulse on audio file in menu to restart the sound everytime you hit the key
  • Connect the keyboard in with a logic and select the option Channel pre op: Toggle
  • Export this last value on the record button on the movie file out

Audio17.png

The Feedback l∞p

September loop.jpg

What is a feedback loop?

+ A feedback loop is a process where the output of a system is used as input to refine and improve the system itself.
Infinitemirror.jpg

A very well know example of this is the camera in front of another camera or a mirror in front of another mirror. Here's a simple breakdown:
1. First Camera Captures: The first camera captures the scene, which includes the second camera.
2. Second Camera Captures: The second camera captures the output of the first camera.
3. Display Loop: The output from the second camera is fed back into the first camera’s view, creating a continuous loop.
4. Infinite Loop Effect: This setup results in an image within an image within an image, and so on, creating a tunnel-like or infinite loop effect.

How does it work?

--> #Image: You have an initial image. 
--> #Process: This image is then processed. Maybe you apply some effects or transformations.
--> #Output: The processed image is displayed.
--> #Feedback: Now, you take that output image and feed it back into the system as a new input.
--> #Repeat: The system captures this new input (which includes the previous output) and the loop continues.

Making an Interactive brush: Feedback loop in TouchDesigner

How does it work in TouchDesigner?

Feed1.png

Feed2.png

Feed3.png

Feed4.png

Feed5.png

Feed6.png

Feed7.png

Feed8.png

Feed9.png

Feed10.png

Feed11.png

Feed12.png