KEMBAR78
NukeGettingStarted 6 | PDF | Installation (Computer Programs) | Command Line Interface
0% found this document useful (0 votes)
9K views252 pages

NukeGettingStarted 6

Nuke(tm) is a trademark of The Foundry Visionmongers Ltd. This Getting Started Guide and the Nuke software are subject to an End User License Agreement (the "EULA") The EULA can be read in the Nuke User Guide, Appendix E. The Foundry assumes no responsibility or liability for any errors or inaccuracies.

Uploaded by

josukke
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
9K views252 pages

NukeGettingStarted 6

Nuke(tm) is a trademark of The Foundry Visionmongers Ltd. This Getting Started Guide and the Nuke software are subject to an End User License Agreement (the "EULA") The EULA can be read in the Nuke User Guide, Appendix E. The Foundry assumes no responsibility or liability for any errors or inaccuracies.

Uploaded by

josukke
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 252

GETTING STARTED GUIDE VERSION 6.

3v6

Nuke Getting Started Guide. Copyright 2011 The Foundry Visionmongers Ltd. All Rights Reserved. Use of this Getting Started Guide and the Nuke software is subject to an End User License Agreement (the "EULA"), the terms of which are incorporated herein by reference. This Getting Started Guide and the Nuke software may be used or copied only in accordance with the terms of the EULA. This Getting Started Guide, the Nuke software and all intellectual property rights relating thereto are and shall remain the sole property of The Foundry Visionmongers Ltd. ("The Foundry") and/or The Foundry's licensors. The EULA can be read in the Nuke User Guide, Appendix E. The Foundry assumes no responsibility or liability for any errors or inaccuracies that may appear in this Getting Started Guide and this Getting Started Guide is subject to change without notice. The content of this Getting Started Guide is furnished for informational use only. Except as permitted by the EULA, no part of this Getting Started Guide may be reproduced, stored in a retrieval system or transmitted, in any form or by any means, electronic, mechanical, recording or otherwise, without the prior written permission of The Foundry. To the extent that the EULA authorizes the making of copies of this Getting Started Guide, such copies shall be reproduced with all copyright, trademark and other proprietary rights notices included herein. The EULA expressly prohibits any action that could adversely affect the property rights of The Foundry and/or The Foundry's licensors, including, but not limited to, the removal of the following (or any other copyright, trademark or other proprietary rights notice included herein): Nuke compositing software 2011 The Foundry Visionmongers Ltd. All Rights Reserved. Nuke is a trademark of The Foundry Visionmongers Ltd. Digital Domain is a registered trademark of Digital Domain, Inc. Primatte keyer tool 1997-2011 Photron USA, Inc. All Rights Reserved. Primatte is a trademark of IMAGICA Corp. Primatte patent is held by IMAGICA Corp. In addition to those names set forth on this page, the names of other actual companies and products mentioned in this Getting Started Guide (including, but not limited to, those set forth below) may be the trademarks or service marks, or registered trademarks or service marks, of their respective owners in the United States and/or other countries. No association with any company or product is intended or inferred by the mention of its name in this Getting Started Guide. ACADEMY AWARD is a registered service mark of the Academy of Motion Picture Arts and Sciences. Linux is a registered trademark of Linus Torvalds. Windows is the registered trademark of Microsoft Corporation. Mac, Mac OS, Leopard, Snow Leopard, Shake, Final Cut Pro and QuickTime are trademarks of Apple, Inc., registered in the U.S. and other countries. Adobe and Photoshop are either registered trademarks or trademarks of Adobe Systems Incorporated in the United States and/or other countries. Maya is a registered trademark of Autodesk, Inc., in the USA and other countries. Houdini is a registered trademark of Side Effects Software, Inc. 3D-Equalizer is a trademark of Science.D.Visions. FrameCycler is a registered trademark of Iridas, Inc. OpenGL is a trademark or registered trademark of Silicon Graphics, Inc., in the United States and/or other countries worldwide. Cineon is a trademark of Eastman Kodak Company. Stereoscopic images courtesy of Mr. Henry Chung, HKSC (http://www.stereoscopy.com/henry/). Images illustrating warping and morphing courtesy

The Foundry

Nuke 6.3v6

of Ron Brinkmann (http://www.digitalcompositing.com). Images from The Day After Tomorrow 2004 courtesy of and copyright by 20th Century Fox. Images from "Stealth" courtesy of and copyright by Sony Pictures Inc. Images from "xXx" 2002 courtesy of and copyright by Columbia Pictures Industries. All rights reserved by their respective owners in the United States and/or other countries. Thank you to Diogo Girondi for providing icons for Nuke user interface. The Foundry 6th Floor The Communications Building Leicester Square London WC2H 7LT UK Rev: 10 November 2011

The Foundry

Nuke 6.3v6

Contents
GETTING STARTED
About the Getting Started Section . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9

INSTALLATION AND LICENSING

System Requirements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 Windows and Linux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 Mac OS X. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Licensing Nuke . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Obtaining Licenses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Installing Licenses. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 Further Reading . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 Installing Nuke . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Installation on Windows . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Installation on Linux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 Installation on Mac OS X. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 Launching Nuke. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 Launching the Commercial Version . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Launching the Nuke Personal Learning Edition (PLE) . . . . . . . . . . . . . 19 About the Personal Learning Edition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 PLE Versus the Commercial Version of Nuke . . . . . . . . . . . . . . . . . . . 20 What Is the Nuke Plug-in Installer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 Accessing the Nuke Plug-in Installer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 Getting an Overview of the Plug-ins . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 Viewing Details of Plug-ins . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 Downloading Plug-ins . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 Understanding the Workflow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 The Nuke Window . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 Panes and Panels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 Tabbed Panels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 Toolbar, Menu Bar, and Content Menus . . . . . . . . . . . . . . . . . . . . . . . 26 Using the Toolbar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 Using the Menu Bar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Working with Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Adding Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Selecting Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 Replacing Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34

THE NUKE PLUG-IN INSTALLER

USING THE INTERFACE

CONTENTS

Renaming Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 Editing Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 Cloning Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 Disabling and Deleting Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 Connecting Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 Indicators on Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 Searching for Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 Viewing Information on Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 Customizing the Node Display . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 Creating Node Toolsets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 Navigating Inside the Node Graph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 Panning . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 Zooming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 Fitting Selected Nodes in the Node Graph . . . . . . . . . . . . . . . . . . . . . 46 Fitting the Node Tree in the Node Graph . . . . . . . . . . . . . . . . . . . . . . 46 Cleaning up the Node Graph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 Properties Panels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 Managing the Properties Bin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 Controls That Appear on All Properties Panels . . . . . . . . . . . . . . . . . 48 Displaying Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 Using Input Fields . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 Using Sliders . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 Separating Channels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 Using the Color Picker and Color Controls . . . . . . . . . . . . . . . . . . . . . 52 Using Color Sliders and Color Wheel . . . . . . . . . . . . . . . . . . . . . . . . . 54 Customising a Nodes Defaults with Node Presets . . . . . . . . . . . . . . 58 Animating Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 Working with Animated Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . 59 Animated Parameters in the Dope Sheet and the Curve Editor . . . . . 61 Working with Keyframes in the Dope Sheet . . . . . . . . . . . . . . . . . . . . . . . . 61 Viewing Keyframes in the Dope Sheet . . . . . . . . . . . . . . . . . . . . . . . . 61 Synchronising the Frame Range Between the Dope Sheet and the Curve Editor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 Selecting and Editing Keyframes. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 Repositioning and Trimming Read Nodes . . . . . . . . . . . . . . . . . . . . . . 63 Using the Curve Editor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 Displaying Curves . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 Editing Curves . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 Viewers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 Adding Viewer Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 Connecting Viewer Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 Toggling Views . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 Panning and Zooming the Viewer Window . . . . . . . . . . . . . . . . . . . . . 76

The Foundry

Nuke 6.3v6

CONTENTS

Hiding Floating Viewers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77 Using the Viewer Controls . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 Using the Viewer Composite Display Modes . . . . . . . . . . . . . . . . . . . 96 Hiding and Showing Viewer Toolbars . . . . . . . . . . . . . . . . . . . . . . . . . 98 Locking the Viewer Zoom Level . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98 Viewing Overscan in the Viewer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 Viewing Deep Image Information in the Viewer . . . . . . . . . . . . . . . . . 99 Using the File Browser . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 Undoing and Redoing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103 Progress Bars . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104 Handling Errors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104 Customizing the Interface. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 Interface Layouts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .105

MANAGING SCRIPTS

Working with Multiple Image Formats . . . . . . . . . . . . . . . . . . . . . . . . . . . 109 8-, 16-, and 32-Bit Image Processing . . . . . . . . . . . . . . . . . . . . . . . . . . . 109 Setting Up Your Script . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 Name, Timespan, and Frame Rate. . . . . . . . . . . . . . . . . . . . . . . . . . .110 Setting the Default Project Directory . . . . . . . . . . . . . . . . . . . . . . . . 110 Full-size Formats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 Proxy Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 112 Image Caching. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117 The Cache Directory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117 Defining the Settings for Caching. . . . . . . . . . . . . . . . . . . . . . . . . . .117 Clearing the Disk Cache . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .118 Using the DiskCache Node . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .118 Caching Files Locally for Better Performance . . . . . . . . . . . . . . . . . . 119 Saving Scripts and Recovering Backups . . . . . . . . . . . . . . . . . . . . . . . . . . 120 Saving Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 120 Automatic Backup of Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .121 Recovering Backups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .122 Loading Image Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 122 Loading Images from an External File Browser. . . . . . . . . . . . . . . . . 124 Naming Conventions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125 Changing the Relation Between the Current Frame and the Frame Read In . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125 Reformatting Image Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126 Loading Nuke Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127 Closing Nuke Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127 Defining Frame Ranges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128 File Name Search and Replace . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 129 Displaying Script Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 129
Nuke 6.3v6

The Foundry

CONTENTS

Grouping Nodes in the Node Graph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130 Grouping Nodes with the Backdrop Node. . . . . . . . . . . . . . . . . . . . .130 Grouping Nodes with the Group Node . . . . . . . . . . . . . . . . . . . . . . .132 Adding Notes to the Node Graph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133 Using the Precomp Node . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 134 Creating Precomp Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 135 Using a Precomp Node to Speed-up Rendering . . . . . . . . . . . . . . . .137 Precomp Revisions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .138 Collaborative Workflow Example . . . . . . . . . . . . . . . . . . . . . . . . . . .139 Working with File Metadata . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140 Metadata in Nuke . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140 Viewing Metadata . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140 Comparing Metadata Between Inputs. . . . . . . . . . . . . . . . . . . . . . . . 141 Modifying Metadata . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 142 Copying Metadata from One Input to Another and Filtering Metadata . 144 Adding a Timecode to Metadata. . . . . . . . . . . . . . . . . . . . . . . . . . . . 145 Rendering Metadata . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 145 Accessing Metadata via TCL Expressions. . . . . . . . . . . . . . . . . . . . . 146 Accessing Metadata via Python . . . . . . . . . . . . . . . . . . . . . . . . . . . . 147

TUTORIALS
The Projects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 148 Installing the Project Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 148

TUTORIAL 1: COMPOSITI NG BASICS

Starting Nuke . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 150 Using the Toolbar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152 Using the Menus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152 Customizing Your Layout . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 153 Saving Files and File Backup . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 155 Setting Up the Project . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156 Working with Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 157 Connection Tips . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161 Importing Image Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 164 Navigating Inside the Windows . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166 Working with Viewers. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 168 Reformatting Images . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 172 Using Proxies and Down-res . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 Compositing Images . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 174 Color-Correcting Images. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177 Masking Effects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177

The Foundry

Nuke 6.3v6

CONTENTS

To Create and Apply a Bezier Mask . . . . . . . . . . . . . . . . . . . . . . . . .178 Creating Flipbook Previews. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 178 Rendering Final Output. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179 Epilog . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 182

TUTORIAL 2: TRACKING, STABILISING, AND MATCHMOVING

One-Point, Two-Point, Three-Point, Four . . . . . . . . . . . . . . . . . . . . . . . . 185 Open the Tutorial Project File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 186 Tracking a Single Feature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 186 Tracking Obscured Features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 190 Stabilising Elements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 192 Matchmoving Elements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 195 Epilog . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 198 Open the Tutorial Project File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 199 Keying with Primatte . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201 Image-based Keying . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 206 Rotoscoping . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 211 Keying Video. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 216 Epilog . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 224 The Basic 3D System . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 226 The 3D Viewer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 226 The Geometry or Scene Node . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 227 The Camera Node . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 227 The ScanlineRender Node . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .227 Open the Tutorial Project File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228 Setting Up a 3D System . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 229 Making a Scene . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235 Merging and Constraining Objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 237 Animating a Scene . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 240 Working with Geometry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 244 Lighting and Surface Properties . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 249 Epilog . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 252

TUTORIAL 3: KEYING AND MATTES

TUTORIAL 4: 3D INTEGRATION

The Foundry

Nuke 6.3v6

GETTING STARTED
By now, you are probably itching to dive into and play with Nuke, so lets get you started. This guide provides you with all you need to start compositing with Nuke. For more detailed information on Nuke and its functions, see the Nuke User Guide.

About the Getting Started Section

Before you can start exploring Nukes wonders, you of course need to install Nuke on your machine. For instructions on how to do so and launch either the commercial version of Nuke or the Nuke Personal Learning Edition, refer to Chapter 1: "Installation and Licensing" on page 10. After the installation, youll come across the Nuke Plug-in Installer. With this application, you can easily get information on plug-ins you can use with Nuke and download them. For more information on the Nuke Plug-in Installer, go to Chapter 2: "The Nuke Plug-in Installer", on page 22. Once you have successfully installed and launched Nuke, you can sit back and start familiarizing yourself with the interface. Chapter 3: "Using the Interface" on page 23 is designed to help you understand the workflow, the workspace and the different controls. It also provides you with information on adjusting the interface to suit your preferences. Finally, to learn about scripts and script management, turn to Chapter 4: "Managing Scripts" on page 109. After these chapters, you can sink your teeth into the Tutorials on page 148 and learn the basics of compositing with Nuke.

1 INSTALLATION AND LICENSING


We know the installation and licensing of a new application can be a boring task that you just want to be done with as soon as possible. To help you with that, this chapter guides you to the point where you have an open workspace of Nuke in front of you and are ready to start compositing to your hearts content, whether it be with the commercial version of Nuke or the Nuke Personal Learning Edition (PLE).

System Requirements
Windows and Linux

Before you do anything else, check the system requirements to make sure your computer can run Nuke.

550 MHZ Pentium III or newer processor Windows XP (with Service Pack 2 or later), Windows 7, or Linux RHEL 5.4 5 GB disk space available for caching and temporary files 512 MB RAM (minimum requirement) Workstation-class graphics card, such as NVIDIA Quadro series, ATI FireGL series, R3D Rocket, or newer. Driver support for OpenGL 2.0. To enable optional GPU acceleration of certain effects, you need OpenGL 2.0 with support for floating point textures and GLSL Display with at least 1280 x 1024 pixel resolution and 24-bit color Three-button mouse.

Note

To avoid graphical problems, such as text disappearing in the Viewer and Node Graph, it is important to keep your graphics card drivers up-to-date. Driver updates can be obtained from the web sites of the graphics card manufacturers (for example, www.nvidia.com and www.ati.com). If youre using R3D Rocket graphics card, note that using it in Nuke will most likely only be considerably faster when youre reading in at full resolution. If youre reading in at half resolution for instance, using Nuke without the R3D Rocket card enabled may be faster. This is because the R3D Rocket graphics card is designed to be fast when reading in multiple frames at the same time. This is not how Nuke works internally, and therefore reads with the R3D Rocket card disabled will sometimes be faster when working in lower resolutions (< 4K widths). Note that the R3D Rocket card will always produce better results when downsampling than Nuke will. Also, the R3D Rocket card can only be used by one application at a time, so

Note

INSTALLATION AND LICENSING Licensing Nuke

11

if you are viewing multiple Nuke scripts at once, you will only be able to use the R3D Rocket card in one.

Mac OS X

Intel processor and Mac OS X 10.5 Leopard or 10.6 Snow Leopard A Mac with an Intel Core 2 Duo or later. 5 GB of disk space available for caching and temporary files 512 MB of RAM (minimum requirement) AGP, PCI Express, or R3D Rocket graphics card with at least 32 MB of video memory. Driver support for OpenGL 2.0. Display with at least 1280 x 1024 pixel resolution and 24-bit color Three-button mouse

Licensing Nuke

If you simply want to try out or learn Nuke, you can run the Nuke Personal Learning Edition (PLE) without a license key. The PLE allows you to explore practically all Nukes features, but prevents the commercial use of the application. To use the PLE, you only need to install Nuke on your machine (see Installing Nuke on page 14) and launch it in a special way described in Launching the Nuke Personal Learning Edition (PLE) on page 19. About the Personal Learning Edition on page 20 also provides you with more information on the PLE and how it differs from the commercial version of Nuke. To use the commercial version of Nuke, you need a valid license key. You can obtain one by purchasing Nuke or by requesting a time-limited demo license. The instructions below tell you how to get a license key and what to do with it. Without a valid license key, the commercial version of Nuke will fail to run. Nuke uses FLEXlm encryption in the license keys. Node-locked (uncounted) and floating (counted) licenses are supported. We also supply a suite of tools to manage and monitor floating licenses running on a server across a network of machines. These tools are called Foundry FLEXlm Tools (FFT) and can be downloaded free of charge from our web site at www.thefoundry.co.uk/licensing. The Foundry FLEXlm Tools should be installed on the server.

Obtaining Licenses

You can request licenses by contacting The Foundry Sales Department (sales@thefoundry.co.uk). To generate you a license key, we need to know your System ID. The System ID (sometimes called lmhostid) returns a unique

The Foundry

Nuke 6.3v6

INSTALLATION AND LICENSING Licensing Nuke

12

number for your computer. We lock our license keys to the System ID. To display your System ID, do any of the following: Download the Foundry System ID (FSID) utility from www.thefoundry.co.uk/licensing and run it. Your System ID will be displayed in the window that opens. Install and try to launch the commercial version Nuke without a valid license (see Installing Nuke on page 14 and Launching Nuke on page 17). Your System ID number is displayed in the license error you get. Download the Foundry FLEXlm Tools (FFT) free of charge from our web site and then run the following command in a terminal shell:
/usr/local/foundry/FLEXlmTools5.0/bin/lmutil lmhostid

Just so you know what a System ID number looks like, heres an example: 000ea641d7a1. Once you have provided us with your System ID number and a license key has been generated for you, you will receive the license key in an e-mail or Internet download. The license key is contained in a text file called foundry.lic. Here is an example node-locked (uncounted) license for Nuke that expires on 29 September 2010 for a computer running Nuke with a System ID of 000a957bfde5. Node-locked licenses allow you to run Nuke on one machine only.
INCREMENT nuke_i foundry 2009.0929 29-sep-2010 uncounted \ HOSTID=000a957bfde5 ISSUED=29-sep-2009 \ SIGN="00DA 99A9 E744 217E 8AD3 E7AF E289 C0C6 \ 6B23 2891 AC01 0F50 E64D 8847 8B22 3A40 2BE9 \ A268 B7C2 4BC0 36AF" INCREMENT nuke_r foundry 2009.0929 29-sep-2010 uncounted \ HOSTID=000a957bfde5 ISSUED=29-sep-2009 \ SIGN="03C9 1D0D 5503 EC34 2CAF 37C0 8731 5E57 \ 06E8 C8CB E113 51EA 87C6 3BE8 242B 50AC 35EE \ 6753 B3AB 3AC4 1559"

And heres an example of a permanent floating license for a server whose machine name is red with System ID 000ea641d7a1 communicating on port number 30001 that will enable any version of Nuke built before 31 July 2009 to run on up to 5 machines simultaneously.
SERVER red 000ea641d7a1 30001 VENDOR foundry INCREMENT nuke_i foundry 2009.0731 permanent 5 ISSUED=15jul-2009 SIGN="00DA 99A9 E744 217E 8AD3 E7AF

The Foundry

Nuke 6.3v6

INSTALLATION AND LICENSING Licensing Nuke

13

E289 C0C6 6B23 2891 AC01 0F50 E64D 8847 8B22 3A40 2BE9 A268 B7C2 4BC0 36AF" INCREMENT nuke_r foundry 2009.0731 permanent 5 ISSUED=15jul-2009 START=31-jul-2009 SIGN="03C9 1D0D 5503 EC34 2CAF 37C0 8731 5E57 06E8 C8CB E113 51EA 87C6 3BE8 242B 50AC 35EE 6753 B3AB 3AC4 1559"

For information on what to do with the foundry.lic file, see Installing Licenses below.

Installing Licenses

Once a license has been created for you, you will receive your license key (foundry.lic) in an e-mail or Internet download. You should also receive the Foundry License Installer (FLI) application to help you install the license key. The FLI is also available to download from www.thefoundry.co.uk/licensing. The instructions below tell you what to do with these.

To install a license
1. Make sure you have saved both the license key (foundry.lic) and the Foundry License Installer application in the same directory. You should receive these by e-mail or (if you purchased Nuke online) in a download. 2. Double-click on the Foundry License Installer application to run it. The license key should automatically appear in the FLI window, if the FLI and foundry.lic are in the same directory. If they are not, you can either copy and paste the contents of the license key or drag and drop the file into the FLI window. 3. Click Install. Provided that the license is valid, the license will be installed to the correct directory. If you installed a node-locked license key (a license that allows you to run Nuke on one machine only), youre good to go. Proceed to Launching Nuke on page 17. 4. If you have a floating license, you will be asked whether you want to create a client license file. You should accept this and save the file (client.lic). Copy the client.lic file to each machine that you wish to run Nuke on and use the FLI to install it on them. In order for the floating license to work, you will need to install the Foundry FLEXlm Tools 5.0 (FFT) on the license server machine. For more information on how to install floating licenses, refer to the FFT user guide, which you can download from our web site.

Further Reading

There is a lot to learn about licenses, much of which is beyond the scope of this manual. For more information on licensing Nuke, displaying the System

The Foundry

Nuke 6.3v6

INSTALLATION AND LICENSING Installing Nuke

14

ID number, setting up a floating license server, adding new license keys and managing license usage across a network, you should read the Foundry FLEXlm Tools User Guide, which can be downloaded from our web site, www.thefoundry.co.uk/licensing.

Installing Nuke

Nuke 6.3 will install separately to any previous versions installed. Nuke 6.3 is available to download from our web site at www.thefoundry.co.uk. The downloads are in compressed tar format (tgz) for Linux, exe for Windows, and dmg format for Mac OS X. The installation procedure is the same for both the Nuke Personal Learning Edition (PLE) and the commercial version of Nuke. The installation package for all platforms installs Nuke, NukeX, the Nuke PLE version and the Plug-in Installer and icons for these appear in your installation folder. Straight after youve installed Nuke, the Plug-in Installer opens. For more information about the Plug-in Installer, see The Nuke Plug-in Installer on page 22.

Installation on Windows

To install Nuke on Windows, do the following: 1. Download the correct installation file from our web site. 1. Double-click on the file to install Nuke. 2. Follow the on-screen instructions. By default, Nuke is installed to drive letter:\Program Files\Nuke 6.3v6. 3. Proceed to Launching Nuke on page 17. Note

On Windows, if you install Nuke to a network drive to run from multiple computers, please ensure that the correct Microsoft run time libraries are installed on each machine that will run Nuke. To do this, run "vcredist_x64.exe" on each machine. The appropriate one of these files can be found in the "VCRedist" subdirectory in the folder where Nuke is installed. Running Nuke without installing the libraries on your machine may work correctly, particularly as many systems (such as Windows Vista by default) will already have them. If the libraries are not present, Nuke will still run correctly, but some plug-ins may fail to load with error messages such as "This application has failed to start because the application configuration is incorrect. Reinstalling the application may fix this problem." Please note that these libraries are set up automatically on the machine that runs the Nuke installer, so users installing on their local machine will not need to worry about this issue.

The Foundry

Nuke 6.3v6

INSTALLATION AND LICENSING Installing Nuke

15

Installing Nuke from the command line


To install Nuke from the command line, do the following: 1. Download the correct .exe installation file from our web site at www.thefoundry.co.uk. 2. To open a command prompt window, select Start > All Programs > Accessories > Command Prompt. 3. Use the cd (change directory) command to move to the directory where you saved the installation file. For example, if you saved the installation file in C:\Temp, use the following command and press Return:
cd \Temp

4. To install Nuke, do one of the following: To install Nuke and display the installation dialog, type the name of the install file without the file extension and press Return:
Nuke6.3v6-win-x86-release-64

To install Nuke silently so that the installer does not prompt you for anything but displays a progress bar, enter /silent after the installation command:
Nuke6.3v6-win-x86-release-64 /silent

To install Nuke silently so that nothing is displayed, enter /verysilent after the installation command:
Nuke6.3v6-win-x86-release-64 /verysilent

Note

By running a silent install of Nuke, you agree to the terms of the End User Licensing Agreement. To see this agreement, please refer to Appendix E: End User Licensing Agreement in the Nuke User Guide or run the installer in standard non-silent mode.

Installation on Linux

To install Nuke on Linux, do the following: 1. Download the correct .tgz installation file from our web site at www.thefoundry.co.uk. 2. Extract the installer from the tgz archive with the following terminal command:
tar xvzf Nuke6.3v6-linux-x86-release-64.tgz

This will give you an installer file. 3. Run the installer.


sudo ./Nuke6.3v6-linux-x86-release-64-installer

4. Follow the on-screen instructions. By default, Nuke is installed to /usr/ local/Nuke6.3v6. 5. If you didnt add a license key during the installation, do that now. Proceed to Launching Nuke on page 17.

The Foundry

Nuke 6.3v6

INSTALLATION AND LICENSING Installing Nuke

16

Tip

To install Nuke silently, you can simply unzip the installer file. This creates the properly formed Nuke directory tree in the current directory. By installing Nuke silently, you agree to the terms of the End User Licensing Agreement. To see this agreement, please refer to Appendix E: End User Licensing Agreement in the Nuke User Guide or run the installer in standard non-silent mode.

Installing Nuke remotely from the command line


If you need to install Nuke on render machines using the command line, do the following: 1. Download the correct .tgz installation file from our web site at www.thefoundry.co.uk. 2. Extract the installer from the tgz archive with the following terminal command:
tar xvzf Nuke6.3v6-linux-x86-release-64.tgz

This will give you an installer file. 3. Use the following terminal command to log in to your render machine as root:
ssh root@render_machine

Replace render_machine with the name of your render node. 4. Make a directory to install Nuke to:
mkdir /usr/local/Nuke6.3v6

5. Copy the installer file from the machine that you downloaded it on to your render machine with a command like:
scp root@download_machine:/tmp/Nuke6.3v6-linux-x86release-64-installer root@render_machine:/usr/local/ Nuke6.3v6/

Replace download_machine with the name of the machine you downloaded the installer file to, and render_machine with the name of your render node. 6. Unzip the installer file to unpack its contents into your Nuke directory:
cd /usr/local/Nuke6.3v6 unzip Nuke6.3v6-linux-x86-release-64-installer

7. Repeat steps 3-6 for each render machine.

Installation on Mac OS X

To install Nuke on Mac OS X, do the following: 1. Download the correct .dmg installation file from our web site at www.thefoundry.co.uk. 2. Double-click on the Nuke6.3v6-mac-x86-release-64.dmg archive to extract the pkg installer:

The Foundry

Nuke 6.3v6

INSTALLATION AND LICENSING Launching Nuke

17

A pkg file is created. 3. Double-click on the pkg file. 4. Follow the on-screen instructions to install Nuke. By default, Nuke is installed to /Applications/Nuke6.3v6. 5. Proceed to Launching Nuke on page 17.

Installing Nuke silently from the command line


1. Download the .dmg installation file from our web site at www.thefoundry.co.uk. 2. Launch a Terminal window. 3. To mount the dmg installation file, use the hdiutil attach command with the directory where you saved the installation file. For example, if you saved the installation file in Builds/Nuke, use the following command:
hdiutil attach /Builds/Nuke/Nuke6.3v6-mac-x86-release64.dmg

4. Enter the following command:


pushd /Volumes/Nuke6.3v6/

This stores the directory path in memory, so it can be returned to later. 5. To install Nuke, use the following command:
sudo installer -pkg Nuke6.3v6-mac-x86-release-64.pkg target "/"

You are prompted for a password. 6. Enter the following command:


popd

This changes to the directory stored by the pushd command. 7. Finally, use the following command to eject the mounted disk image:
hdiutil detach /Volumes/Nuke6.3v6

Note

By running a silent install of Nuke, you agree to the terms of the End User Licensing Agreement. To see this agreement, please refer to Appendix E: End User Licensing Agreement in the Nuke User Guide or run the installer in standard non-silent mode.

Launching Nuke

With the installation and licensing out of the way, youre ready to start compositing with Nuke. Depending on whether you want to use the Nuke Personal Learning Edition or the commercial version of Nuke, the procedure for launching Nuke is slightly different. Both are described below, beginning with the procedure for the commercial version.

The Foundry

Nuke 6.3v6

INSTALLATION AND LICENSING Launching Nuke

18

Launching the Commercial Version

To launch the commercial version of Nuke, do one of the following:

On Windows
Double-click the Nuke icon on the Desktop. Select Nuke6.3v6 from Start > All Programs > The Foundry > Nuke6.3v6.

Using a command prompt, navigate to the Nuke application directory (by default, \Program Files\Nuke6.3v6) and enter nuke6.3. The Nuke graphical interface appears, and a command line window opens.

On Mac OS X
Click the Nuke dock icon. Open the Nuke application directory (by default, /Applications/ Nuke6.3v6/), and double-click the Nuke icon (or list item).

The Foundry

Nuke 6.3v6

INSTALLATION AND LICENSING Launching Nuke

19

Open a terminal, navigate to /Applications/Nuke6.3v6/ Nuke6.3v6.app/ and enter ./Nuke6.3v6. The Nuke graphical interface displays.

On Linux
Double-click the Nuke icon on the Desktop. Open the Nuke application directory (by default, /usr/local/Nuke6.3v6/) and double-click the Nuke icon (or list item).

Open a terminal, navigate to the Nuke application directory (by default, /usr/local/Nuke), and enter ./Nuke6.3. The Nuke graphical interface displays.

Launching the Nuke Personal Learning Edition (PLE)

You launch the PLE from a terminal (a window where you can enter commands directly rather than making selections through a user interface).

To launch the PLE


On Windows: Select the Personal learning Edition from Start > All Programs > The Foundry > Nuke6.3v6.

The Foundry

Nuke 6.3v6

INSTALLATION AND LICENSING About the Personal Learning Edition

20

OR Using a command prompt, navigate to the Nuke application directory (by default, /Program Files/Nuke6.3v6), and enter nuke6.3 --ple. On Linux: Open a terminal, navigate to the Nuke application directory (by default, /usr/local/Nuke), and enter ./Nuke6.3 --ple. On Mac OS X: Click the Nuke PLE dock icon. OR Open the Nuke application directory (by default, /Applications/ Nuke6.3v6/), and double-click the Nuke6.3v6 PLE icon (or list item). OR Open a terminal, navigate to /Applications/Nuke6.3v6/Nuke6.3v6.app/ Contents/MacOS, and enter ./Nuke6.3 --ple. Note

On Mac OS X, you shouldnt move the Nuke PLE bundle from its original installation folder as this will prevent it from working correctly.

About the Personal Learning Edition

The Nuke Personal Learning Edition is a special version of Nuke that you can run without a license. The Personal Learning Edition is meant for personal, educational, and other non-commercial use. It is aimed at students, industry professionals, and others interested in Nuke. It includes all the features of the commercial version of Nuke, offering you a chance to explore and learn the application fully while using it from the comfort of your own home.

PLE Versus the Commercial Version of Nuke

The PLE is a fully functional version of Nuke, but, being aimed for noncommercial use only, it does differ from the commercial version in some aspects. Here are the main differences: Watermark. The PLE displays a watermark (shown below) on any images in the Viewer as well as images rendered out to files. This is to prevent the commercial use of the images.

The Foundry

Nuke 6.3v6

INSTALLATION AND LICENSING About the Personal Learning Edition

21

External data storage. All external data storage is encrypted in the PLE, including Nuke scripts (these are saved with the extension .nkple), gizmos (saved with the extension .gzple), and copying to the clipboard. Among other things, this means the PLE saves files in an encrypted format, unlike the commercial version of Nuke, which saves scripts unencrypted as plain text. The commercial version of Nuke cannot load files created with the PLE. The PLE, however, can load scripts and gizmos created with the commercial version. Scripting. In PLE mode, Nuke restricts the amount of nodes that can be retrieved at a time by scripting. Functions such as "nuke.allNodes()" in Python will return only the first 10 nodes available rather than all of them at once, and scripts written to iterate through the Node Graph will not be able to retrieve any more nodes beyond a set point. The commercial version of Nuke can retrieve any and all nodes at any time as the command names would suggest. WriteGeo. The WriteGeo node is disabled in the PLE. Primatte. The Primatte keyer node is disabled in the PLE. Ultimatte. The Ultimatte keyer node is disabled in the PLE. FrameCycler. FrameCycler is disabled in the PLE. Monitor output. There is no video monitor output support in the PLE. Plug-ins. Only plug-ins that are shipped with Nuke, such as OFlow, can be used in the PLE. OFX plug-ins (such as The Foundry's Furnace) and custom plug-ins compiled with the NDK can only be used in the commercial version of Nuke. Command line rendering. It is not possible to render a PLE script with -x from the command line. In other respects, the PLE contains all the functionality of the commercial version of Nuke.

The Foundry

Nuke 6.3v6

2 THE NUKE PLUG-IN INSTALLER


This chapter gives you an overview of The Nuke Plug-in Installer application.

What Is the Nuke Plug-in Installer

The Nuke Plug-in Installer is an application in Nuke that gives you easy access to a large selection of useful plug-ins to use with Nuke.

Accessing the Nuke Plug-in Installer

The Nuke Plug-in Installer application is installed with Nuke, so you dont have to download or install it separately. The application will open up after you have installed Nuke.

Getting an Overview of the Plug-ins

On the Plug-ins tab of the Nuke Plug-in Installer, you can have a look at the selection of plug-ins available through the application.

Viewing Details of Plug-ins

To have a closer look at any of the plug-ins, just double-click on the icon and move on to the Details tab. Youll see a HTML page with more detailed information on the plug-in. At the bottom of the Details tab, you can select your operating system and download the plug-in software by clicking the Download selected platform button.

Downloading Plugins

When youve chosen a plug-in you want to download, do the following: 1. Double-click it on the Plug-ins tab. This will open the Plug-in information in the Details tab. 2. Select the operating system(s) you require using the checkboxes at the bottom of the window. 3. Click the Download selected platforms button. Nuke Plug-in Installer will prompt you to choose a download destination for the plug-in and then automatically start downloading it for you. 4. Youll see a notification when the download is finished, and after that you can install your plug-in by clicking the Install button in the Plug-in Installer.

3 USING THE INTERFACE


This chapter is designed to help you understand Nukes workflow, learn how to use the interface, and customize the interface to suit your preferences.

Understanding the Workflow

Nuke utilizes a node-based work flow, where you connect a series of nodes to read, process, and manipulate images. Each node in the projectan image keyer, a color-correction, or a blur filter, for exampleperforms an operation and contributes to the output.

Figure 3.1: A Nuke project consists of a network of linked operators called nodes. Saved projects are called script files. You can open a Nuke project file in a text editor, and you will see a series of sequential commands which are interpreted and executed when you render the output.

Read nodes

Effect nodes

Output node

Viewer node

Figure 3.2: A simple Nuke script. In Figure 3.2, you see an example of a very simple Nuke script. Two Read nodes reference image sequences on disk. Effect nodes extract a matte and

USING THE INTERFACE The Nuke Window

24

blur an image. A merge node (named over) composites the foreground image over the background. Finally, a Write node renders and outputs the completed composite to disk. Youll also see a Viewer node, which displays the output of any node in the script.

The Nuke Window

The Nuke interface is constructed using interchangeable panes, panels, and tabbed panels so that you can customize your workspace to suit your particular needs.

Panes and Panels

Nukes main window is divided into three panes: the Node Graph/Curve Editor pane, the Properties/Script Editor pane, and the Viewer pane.

Viewer pane

Properties/Script Editor pane

Node Graph/Curve Editor pane

Figure 3.3: Empty main window. You can add panels onto these panes, for example: Toolbars for selecting nodes Node Graphs (also known as DAGs) for building node trees Curve Editors for editing animation curves Properties Bins for adjusting the nodes controls Viewers for previewing the output Progress panels for displaying progress bars Script Editors for executing Python commands.

The Foundry

Nuke 6.3v6

USING THE INTERFACE The Nuke Window

25

By default, there is a Node Graph panel in the lower left corner, a Viewer panel in the top left corner, and a Properties Bin on the right, as shown in Figure 3.4.

Viewer

Node Graph with a node tree

Properties Bin with properties panels

Figure 3.4: Main window with a Node Graph, Viewer, and Properties Bin. The Node Graph is where you add nodes and build your node tree. When you add a node to the panel, its properties panel appears in the Properties Bin on the right. This is where you can adjust the node to produce the effect youre after. To check the result, you can view the output in a Viewer. You can open more panels using the content menus described in Toolbar, Menu Bar, and Content Menus below. You can add several panels on the same pane and switch between them by using the tabbed pages on top of the pane.

Tabbed Panels

Panes are divided into tabbed panels on the top of the pane. To go to a different tab, simply click on the tab name.

Figure 3.5: Moving from the Properties tab to the Script Editor tab. To cycle through tabs, press Ctrl/Cmd+T.

The Foundry

Nuke 6.3v6

USING THE INTERFACE The Nuke Window

26

Toolbar, Menu Bar, and Content Menus

The Toolbar is located on the left-hand side of the Nuke window. It consists of a number of menu icons. The different nodes are grouped under these icons based on their functions. You use the Toolbar to add nodes to the Node Graph. The menu bar is located on top of the Nuke window. Its menus, such as the File or Edit menu, let you perform more general actions related to the whole script, the Viewers, or editing, rather than certain individual nodes.

Figure 3.6: The vertical Toolbar and the horizontal menu bar. In addition to the Toolbar and the menu bar, you should also familiarize yourself with the content menus. They are the gray checkered boxes in the top left corner of each pane. If you click on the box, a pop-up menu opens. You can use the options in the pop-up menu to customize the window layout.

The Foundry

Nuke 6.3v6

USING THE INTERFACE The Nuke Window

27

Figure 3.7: Using the content menus. Finally, to work faster, you can right-click on the different panels to display a pop-up menu with options related to that particular panel.

Figure 3.8: A right-click menu in the Node Graph.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Toolbar

28

Using the Toolbar

Nukes Toolbar includes the following icons:


Icon Image Draw Functions Image read and write nodes, built-in Nuke elements, and Viewer nodes. Roto shapes, paint tools, film grain, fills, lens flares, sparkles, other vector-based image tools. Retiming image sequences.

Time

Channel

Channel management.

Color

Applying color correction effects.

Filter

Applying convolve filters, such as blur, sharpen, edge detect, and erode. Extracting procedural mattes.

Keyer

Merge

Layering background and foreground elements.

Transform Translating, scaling, tracking, and stabilizing elements.

3D

3D compositing nodes and tools.

Particles

Creating, spawning and editing particles.

Deep

Creating, merging and editing deep images.

Views

Nodes for working with views and stereoscopic or multi-view material. Viewing, editing, and comparing image metadata.

Metadata

Toolsets

Creating, deleting and managing toolsets.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Toolbar

29

Icon Other

Functions Additional operators for script and Viewer management.

Any installed plug-ins and custom menus that do not have their own icon.

To display a tool tip that explains the icons function, move your mouse pointer over the icon.

To make selections from the Toolbar, click on an icon and select an option from the menu that appears.

Figure 3.9: Selecting a node from the Toolbar. To quickly browse through the menus in the Toolbar, click and drag over the icons. Nuke opens and closes the menus as you drag over them, making it easy to search for a particular node or find out what the available menus contain.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Menu Bar

30

Using the Menu Bar

The Nuke menu bar includes these functions:


Menu File Edit Layout Viewer Render Cache Help Functions Commands for disk operations, including loading, saving, and importing scripts. Editing functions, preferences, and project settings. Restoring and saving layouts. Adding and connecting Viewers. Rendering the output. Caching files, clearing the disk cache, and clearing buffers. Accessing a list of hotkeys, user documentation, release notes, training resources, tutorial files, Nukepedia, Plug-in Installer, and Nuke-related e-mail lists.

To quickly browse through the available menus and see what they contain, click on a menu and move the mouse pointer over other menus. Nuke opens and closes the menus as you go.

Working with Nodes

Nodes are the basic building blocks of any composite. To create a new compositing script, you insert and connect nodes to form a network of the operations you want to perform to layer and manipulate your images.

Adding Nodes

You add nodes using the Toolbar, the Tab menu, or the right-click menu. When you add a node, Nuke automatically connects it to the last selected node.

To add a node using the Toolbar


1. To select the existing node that you want the new node to follow, click on the node once. 2. Click an icon on the Toolbar and select a node from the menu that appears. For example, if you want to add a Blur node, click the Filter icon and select Blur. Tip

You can press the middle mouse button on a menu icon to repeat the last item used from that menu. For example, if you first select a Blur node from the Filter menu, you can then add another Blur node by simply pressing the middle mouse button on the Filter icon.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

31

To add a node using the Tab menu


1. To select the existing node that you want the new node to follow, click on the node once. 2. Press the Tab key and start typing the name of the node you want to create. This opens a prompt displaying a list of matches. 3. To select the node you want to add from the list, either: click on it, or scroll to it with the Up and Down arrow keys and press Return. To add the last node created using this method, simply press Tab and then Return.

To add a node using the right-click menu


1. Right-click on the existing node that you want the new node to follow. 2. From the menu that opens, select the node you want to add. Tip

You can also add nodes using keyboard shortcuts. Most menus in the Toolbar include a note of the relevant hotkey next to the item in question.

To add a node in a new branch of the node tree


1. To select the existing node that you want the new node to follow, click on the node once.

2. Hold down Shift and create the node using the Toolbar, Tab menu, or right-click menu. To add a node in a new branch with the Tab menu, press the Tab key first, then hold down Shift when selecting the new node.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

32

The node is added after the selected node in a new branch of the node tree.

Selecting Nodes

Nuke offers a number of options for selecting nodes. Selected nodes display in a highlight color defined in your preferences. The default highlight color is light yellow.

To select a single node


Click once on the node.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

33

To select multiple nodes


Press Shift while clicking on each node you want to select. OR Drag on the workspace to draw a marquee. Nuke selects all nodes inscribed by the marquee.

Figure 3.10: Selecting multiple nodes with a marquee.

To select all upstream nodes


Press Ctrl (Mac users press Cmd) while dragging a node. Nuke selects all nodes that feed data to the selected node. You can also Ctrl/Cmd + Shift + click to select more nodes without clearing the current selection.

To select all nodes in a node tree


Click on a node in the Node Graph and select Edit > Select Connected Nodes (or press Ctrl/Cmd+Alt+A). This selects all nodes in the node tree, whether they are upstream or downstream from the current node. Nodes in any other node trees are not selected.

To select all nodes in a script


Select Edit > Select all (or press Ctrl/Cmd+A).

To select nodes by name


1. Choose Edit > Search, or press the forward slash (/). A dialog appears.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

34

2. Type an alphanumeric string that is included in the names of the nodes you wish to select. Click OK. Tip

When typing the above alphanumeric search string, you can use asterisks (*) and question marks (?) as wild cards. An asterisk stands for multiple alphanumeric characters. A question mark represents just one character.

To invert a selection
Select Edit > Invert Selection.

Replacing Nodes

To replace one node with another


1. In the Node Graph, select the node you want to replace. 2. Hold down Ctrl (Cmd on a Mac) and create a new node using the Toolbar, a right-click menu, or the Tab menu. To replace a node with the Tab menu, press the Tab key first, then hold down Ctrl/Cmd when selecting the new node. The new node replaces the selected node in the Node Graph. Note

Note that you cannot replace nodes in this manner if you are using a hotkey (such as B for the Blur node) to create the new node.

Renaming Nodes

To rename a node
1. Double-click on the node to open its properties panel. 2. In the title field on top of the properties panel, you should see the current name of the node. Delete that name and enter a new name in its place,

OR 1. Click on the node in the Node Graph to select it. 2. Press N.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

35

3. Enter a new name for the node in the rename field that appears on top of the node.

Editing Nodes

To copy, paste, and perform other editing functions in the compositing tree, you can use the standard editing keys (for example, Ctrl/Cmd+C to copy, and Ctrl/Cmd+V to paste). You can copy nodes to files or memory. Copied nodes inherit the values of their parent, but these values, unlike those in cloned nodes (see below), are not actively linkedthat is, you can assign different values to the original and the copy. When you paste nodes, Nuke automatically connects them to the node that is selected before the paste operation. If you dont want to connect anything, click on a blank area of the workspace to deselect any selected nodes before pasting.

To copy nodes to memory


1. Select the node or nodes you want to copy. 2. Choose Edit > Copy (or press Ctrl/Cmd+C).

To copy nodes to files


1. 2. 3. 4. Select the node or nodes you want to copy. Choose File > Export nodes as script. Navigate to the directory where you want to store the node as a file. Type a name for the node(s) at the end of the pathway, followed by the extension .nk.

To cut nodes
1. Select the node or nodes you want to cut. 2. Choose Edit > Cut (or press Ctrl/Cmd+X). Nuke removes the node(s) from the script and writes the node(s) to memory.
The Foundry Nuke 6.3v6

USING THE INTERFACE Working with Nodes

36

To paste nodes from memory


1. Select the node that you want the pasted node to follow. 2. Choose Edit > Paste (or press Ctrl/Cmd+V). Nuke adds the nodes to the script, connecting them to the node you selected in step 1.

To paste nodes from files


1. 2. 3. 4. Select the node that you want the pasted node to follow. Choose File > Import script. Navigate to the directory that stores the node file. Select the node file, and click Import. Nuke adds the nodes described by the file to the node you selected in step 1.

Cloning Nodes

You can clone nodes in preparation for pasting them elsewhere in a script. Cloned nodes inherit the values of their parent, but unlike copied nodes, they also maintain an active link with their parents values. If you alter the values of one, the other automatically inherits these changes. Clones are helpful for maintaining consistent setups across multiple elements. For example, you might use clones to apply an identical film grain setup to a series of elements shot on the same stock. Should you need later to make changes to the setup, these changes would automatically ripple throughout the script. Note

You cannot clone gizmos. This applies to both gizmos created in your facility and the nodes in the Nuke default Toolbar that are in fact gizmos, such as the LightWrap node, the Grain node, and the IBK nodes. For more information on gizmos, see the Configuring Nuke chapter in the Nuke User Guide.

To clone nodes
1. Select the node or nodes you want to clone. 2. Choose Edit > Clone or (press Alt+K). Nuke clones the node(s), whilst maintaining an active link to the parental node(s). The clone status is indicated with an orange line that connects the clone to its parent node. The nodes also share the same name.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

37

To declone nodes
1. Select the node or nodes you want to declone. 2. Choose Edit > Declone (or press Alt+Shift+K). Nuke removes the clone status of the selected nodes.

Disabling and Deleting Nodes

To disable nodes
1. Select the node or nodes you want to disable. 2. Select Edit > Node > Disable\Enable (or press D). Nuke cancels the node(s)s effect on the data stream.

To re-enable nodes
1. Select the node or nodes you want to re-enable. 2. Select Edit > Node > Disable\Enable (or press D).

To delete nodes
1. Select the node or nodes you want to delete. 2. Select Edit > Erase (or press Delete). Nuke removes the node(s) from the script.

Connecting Nodes

As discussed, when you add or paste nodes into a script, Nuke automatically generates pipes between the currently selected node and the new nodes. As you build up a script, youll need to move these pipes, or run new pipes between nodes. In Nuke, you make such modifications by dragging on the back end of the pipe (the end without the arrowhead).

To disconnect a node
Drag the head or tail of the connecting arrow to an empty area of the workspace. OR Select the lower node in the tree and press Ctrl+D (Mac users press Cmd+D).

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

38

Figure 3.11: Disconnecting a pipe.

To reconnect a node
Drag on the head or tail of the connecting arrow and drop it over the center of the node to which you want to connect.

Figure 3.12: Reconnecting a pipe. Note

Nuke distinguishes the dual inputs that may run into a merge node with the labels A and B. A refers to the foreground element, and B to the background element. Nuke always copies from the A input to the B. This means that if
Nuke 6.3v6

The Foundry

USING THE INTERFACE Working with Nodes

39

you later decide to disable the node associated with an A input, the data stream will keep flowing, because it will, by default, use the B input.

To duplicate a connecting arrow


Shift+drag the connecting arrow on top of the node you want to create a connection to. Nuke duplicates the connecting arrow, leaving the original connection untouched.

To add a node between two connected nodes


Drag the node into the space between the already connected nodes. As you do so you will see the link between these two nodes become active. When that happens, simply release the node you are dragging and it will automatically wire itself into the network between the two nodes.

To bend connecting arrows


1. Select the node before the connector you want to bend. 2. From the Toolbar, select Other > Dot. A dot appears after the selected node, causing a bend in the connector. 3. Drag the dot as necessary to reposition the bend. Tip

You can also add a dot to an existing connection by pressing Ctrl (Cmd on a Mac) and clicking on the yellow dot that appears on the connecting arrow.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

40

Indicators on Nodes

There are several indicators that can appear on the nodes in the Node Graph, depending on what you are doing. The following table describes what each indicator means.
Indicator Where it appears What it means The wide rectangles indicate the channels the node processes. The thin rectangles indicate the channels that are passed through the node untouched. The nodes effect is limited by a mask from either the nodes primary input or output.

The node has been disabled by pressing D or clicking the Disable button.

The node has been disabled using an expression.

The node has been cloned. The indicator appears on both the parent and the child node.

One or more of the node parameters are animated over time.

One or more of the node parameters are being driven by an expression.

You are working with a multiview project and have split off one or more views in the nodes controls.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

41

Indicator

Where it appears

What it means You are working with a multiview project and have split off one or more views in the nodes controls, dots also appear on the node to indicate which views have been split off. For example, if you are using red for the left view and split off that view, a red dot appears on the node. The full effect of the node is not in use, because you have adjusted the mix slider in the nodes controls.

Searching for Nodes

Nukes Search feature allows you to search for nodes in your script and select any matches found. As a search string, you can enter all or part of a node name. For example, you can search for all Blur nodes in your script by entering bl as the search string. Using regular expressions, you can also do more complex searches, such as searching for all the Read and Write nodes in a script.

To search for nodes


1. Select Edit > Search (or press /) to bring up the search dialog. 2. In the search field, enter the string you want to search for. If you want to search for all nodes in the script, enter * (an asterisk). If you want to search for all Read nodes in the script, enter Read. If you want to search for all the Read and Write nodes, enter the following expression: (*Read*|*Write*) 3. Click OK. Nuke searches for the nodes in the script and selects all matches it finds and focuses the Node Graph the first of them. If you perform the same search again, the Node Graph view focuses on the next node in order. For instance, if you have a ColorBars node, a ColorWheel node and a ColorCorrect node in your Node Graph, searching for "Color" three times in a row will select all of these nodes and focus on each of them in alphabetical order. Note

When you enter expressions in the search dialog, remember that the search field only takes regular expressions. Any characters that have specific

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

42

meanings in regular expressions, such as [ and ], need to be preceded by the \ character.

Viewing Information on Nodes

You can obtain more detailed information from any node by selecting that node and then pressing the i key. This will display an information window associated with that node, particularly useful when troubleshooting.

Customizing the Node Display

You can modify the color, name, and notes that a particular node displays. Doing so can make it easier for other artists to decipher the intent of your script. For example, you might color all nodes green that relate to keying.

Figure 3.13: Nodes can be color-coded according to function.

To modify a nodes display characteristics


1. Double-click on the node to display its properties panel. 2. Click the Node tab at the top of the dialog. Its attributes appear. 3. Do any of the following: Enter a new name for the node on top of the old name. Click on the left color button to change the color of the node. To copy a color of one node to another, drag and drop the color button from the node whose color you want to copy on top of the color button in the node whose color you want to change. Type any comments regarding the node in the label field. These will appear on the surface of the node. From the font pulldown menu, select the font type for any text on the node. Use the buttons on the right to bold or emphasize the text. Enter the font size in the font size field. Click color to choose a new font color.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Nodes

43

The Select color dialog appears, allowing you to select the desired color. Tip

You can also have Nuke automatically color-code nodes for you based on their function. Select Edit > Preferences (or press Shift+S) to open the Preferences dialog. Click on the Node Colors tab, and check the autocolor option. Thereafter, every time you add a node to a script, the node will take on the color appropriate to its function. You can edit these colors as necessary on the Node Colors tab of the Preferences dialog.
Check hide input to conceal the nodes incoming pipe. This can enhance the readability of large scripts. Check postage stamp to display a thumbnail render of the nodes output on its surface.

Creating Node Toolsets

If you find yourself creating the same set of nodes repeatedly, you might want to make that set of nodes into a toolset in the Nuke toolbar. A toolset is any set of nodes you want to easily create by selecting it in the Toolset menu, rather than creating each node separately. Like Gizmos, toolsets can be shared between artists if they are using a centralised .nuke folder. This needs to be accessed through a NUKE_PATH environment variable that you can set up (for more information on environment variables, see the Configuring Nuke chapter in the Nuke User Guide). To create a toolset do the following: 1. In the Node Graph, select any number of nodes (or just one node). The nodes dont have to be connected to each other. 2. Click ToolSets on the toolbar and select Create. You can also right-click on the Node Graph and select ToolSets > Create. The Create ToolSet dialog appears. You can also access your toolsets by pressing Tab and searching for them in the search field. 3. In the ToolSets menu dropdown, select the menu where youd like to place your new toolset. Then give it a name in the Menu item field and click Create. By default, your new toolset goes under the Toolset menu, but if youd like to create a subfolder for the toolset, you can do that by specifying the folder name before the toolset name, separated by a forward slash, in the Menu item field. For example, entering Roto/BasicRoto would create a subfolder called Roto in the Toolset menu, and place a new toolset by the name of BasicRoto in it. There are some toolsets for creating particles, for instance, that are readily built in to Nuke. These can also be found in the Toolsets menu.
Nuke 6.3v6

The Foundry

USING THE INTERFACE Navigating Inside the Node Graph

44

To prevent confusion between built-in toolsets and toolsets that youve created, if you happen to create a toolset folder with the same name as a built-in one, Nuke will add [user] in front of the folder name for clarity. 4. To delete a toolset youve created, you can click ToolSets > Delete in the toolbar and select the toolset you want to remove.

Navigating Inside the Node Graph

As scripts grow in complexity, you need to be able to pan to a particular cluster of nodes quickly. The Node Graph offers a couple of methods for doing so.

Panning

Panning with the mouse


To pan with the mouse, press the middle mouse button and drag the mouse pointer over the workspace (you can also use Alt+drag). The script moves with your pointer. Note

On Linux, Alt+drag may not work as expected. This is due to the default window functionality on Gnome. To get around it, you can use the Windows key instead of Alt when panning. Alternatively, you can change your window preferences on Gnome to fix the problem: 1. Select Applications > Preferences > Windows to open the Window Preferences dialog. 2. Under Movement Key, select Super (or Windows logo). You should now be able to pan with Alt+drag.

Panning with the map


If your script spills over the edges of the workspace, a navigator map automatically appears in the bottom-right corner.

Figure 3.14: Panning with the map.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Navigating Inside the Node Graph

45

The map shows you a miniature view of the entire script and the pink rectangle shows the portion of the script that you see within the workspace borders. To pan with the map, drag the pink rectangle to pan to a different view of the script. When you pan or resize the window, the map automatically appears when the workspace does not show the entire script. When the whole script is contained within the window border, then the map automatically disappears. Tip

The navigation map is resizeable. Drag on its upper left corner to make it as large or small as you like.

Zooming

You can zoom in on or out from the script in a couple of ways.

To zoom in
Move your mouse pointer over the area you want to zoom in on, and press the plus key (+) repeatedly until the workspace displays the script at the desired scale. OR Press Alt and drag right while holding down the middle mouse button.

To zoom out
Move your mouse pointer over the area you want to zoom out from, and press the minus key (-) repeatedly until the workspace displays the script at the desired scale. OR Press Alt and drag left while holding down the middle mouse button. Note

On Linux, Alt+middle drag may zoom the entire Nuke window instead of the Node Graph. This is default functionality on Gnome. To get around it, you can use the Windows key instead of Alt when zooming. Alternatively, you can change your window preferences on Gnome to fix the problem: 1. Select Applications > Preferences > Windows to open the Window Preferences dialog. 2. Under Movement Key, select Super (or Windows logo).

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

46

You should now be able to zoom in and out of the Node Graph with Alt+middle drag.

Fitting Selected Nodes in the Node Graph

To fit selected nodes in the Node Graph, click the middle mouse button or press F.

Fitting the Node Tree in the Node Graph

To fit the entire node tree in the Node Graph, click on the Node Graph to make sure no nodes are selected and click the middle mouse button or press F.

Cleaning up the Node Graph

Sometimes you may find that your node tree becomes a bit disorganized as youre creating and removing nodes. Theres a quick fix you can use to tidy up your tree: 1. Select all the nodes you want to rearrange in the Node Graph. 2. Click Edit > Node > Autoplace. Alternatively, press L. The Autoplace function automatically arranges the selected nodes in a neat tree formation. It takes the node or nodes that you've selected, and progresses through the tree, repositioning connected nodes. It determines a sensible position for the nodes by making sure they don't overlap with other nodes and by keeping the input connections horizontal.

Properties Panels

When you insert a node, its properties panel appears in the Properties Bin with options to define the nodes output. You can also open the properties panel later by doing any of the following: Double-click on the node in the Node Graph. Ctrl/Cmd+click on the node in the Node Graph. Select the node in the Node Graph and press Return.

Tip

To open a properties panel in a floating window, Ctrl/Cmd+Alt+click on the node.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

47

Controls that appear on all nodes.

Figure 3.15: The Read node and its properties panel.

Managing the Properties Bin

You can limit the number of properties panels that can be open in the Properties Bin. To do so, enter the maximum number of properties panels in the field on the Properties Bin.

To lock the Properties Bin and have all new properties panels appear in floating windows, click the lock button on the Properties Bin.

To empty the Properties Bin and close all the properties panels in it, click the remove all panels button.

Tip

You can also close all the properties panels in the Properties Bin by Alt+clicking on the close (X) button of one of the panels.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

48

Controls That Appear on All Properties Panels

These are the standard controls of every properties panel:


Control Function Hide or show the nodes tabbed pages. Centers the node in the Node Graph.

Centers one of the nodes inputs in the Node Graph. Select the input from the pulldown menu that appears. You can save, load and manage node presets here. See Customising a Nodes Defaults with Node Presets on page 58. name field You can enter a new name for the node here. (for example, Blur1) (left) Changes the color of the node. You can drag and drop this button on top of another color button to copy the color. To revert to the default color defined in your Preferences, right-click on the button and select Set color to default. An X on the button indicates the color is unset, and the color defined in the Preferences is used. (right) Changes the color used for the nodes controls in the Viewer. You can drag and drop this button on top of another color button to copy the color. To revert to the default color defined in your Preferences, right-click on the button and select Set color to default. An X on the button indicates the color is unset, and the color defined in the Preferences is used. Undoes the last change made to the node. Redoes the last change undone. Reverts any changes made after the properties panel was opened. Displays a pop-up help related to the node and its controls.

Floats the properties panel. Clicking this button again docks the properties panel back in the Properties Bin if the Bin exists. Closes the properties panel. Alt+click this to close all the properties panels in the Properties Bin. Ctrl/Cmd+click to close all properties panels except the one clicked on.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

49

Floating control panels also include the following buttons:


Control Function Reverts any changes made after the properties panel was opened. Reverts any changes made after the properties panel was opened and closes the properties panel. Hitting this button right after a node was created also deletes the node from the Node Graph. Closes the properties panel.

Many properties panels also contain several tabbed pages.

tabbed pages

Figure 3.16: The Read nodes properties panel and the Node tab.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

50

On the Node tab, you can usually adjust the following controls:
Control label Function Lets you add comments to the node. The comments are displayed on the nodes surface. If you like, you can use HTML in the label field. For example, to have your comments appear in bold, you can enter <b>My Comment</b>. To add an icon called

MyIcon.png to the node, you can use <img src="MyIcon.png"/>. Save


the icon in your plug-in path directory. (For more information on plugin path directories, see Loading Gizmos, NDK Plug-ins, and TCL scripts in the Configuring Nuke chapter of the Nuke User Guide.) Most common image formats will work, but we recommend using .png. Note that the HTML has been changed to a slightly non-standard form where newlines are significant. If there is a newline character in your data, a new line will be displayed in the label. font Lets you change the font for any text displayed on the node. Bolds any text displayed on the node. Emphasizes any text displayed on the node. Lets you change the font size of any text displayed on the node. Lets you change the color of any text displayed on the node.

hide input cached

Check this to hide the nodes incoming pipe. This control does not appear on all nodes. Check this to keep the data upstream from the node in memory, so that it can be read quickly. When this is checked, a yellow line displays under the node in the Node Graph. Check this to display a thumbnail render of the nodes output on its surface. Check this to disable the node. Uncheck to re-enable. (You can also disable or re-enable a node by selecting it in the Node Graph and pressing D.)

postage stamp disable

Displaying Parameters

To display a nodes parameters


Double-click the node. Its properties panel appears. Figure 3.17 shows the controls available for editing parameters. Note that the presence of each control will vary according to the parameters function.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

51

slider

input field

sample color from Viewer color picker

animation button

switch between slider and channel values

Figure 3.17: Parameter controls.

Using Input Fields

You can key values directly into a field, or use the arrow keys to increment and decrement values.

To key in field values


1. Click in the field to select the value you wish to replace: Double-click to the left of the value to select only the whole number digits. Double-click the right of the value to select only decimal digits. Press Return or double-click on the decimal itself to select all digits. 2. Type the value you want to replace the selection. Tip

You can also enter expressions (programmatic instructions for generating values) into fields. You always start an expression by typing =. See the Expressions chapter in the Nuke User Guide for information about how to format expressions. Nuke also allows you to enter formulas into fields, making it easy to do quick calculations. For example, if you wanted to halve a value of 378, you could simply type 378/2 into a field and press Enter to get 189.
You can increment or decrement field values by hundreds, tens, tenths, hundredths, and so on. The magnitude of change depends on the initial position of your cursor. For example if you wanted to increment the initial value of 20.51 by ones, you would insert your cursor before the 0.

Tip

To increment and decrement a field value


1. Click to insert the cursor just prior to the digit you want to increment or decrement.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

52

2. Press the up arrow to increment by unit, or the down arrow to decrement by one unit. Tip

You can also increment and decrement values using the mouse wheel (if available) or by pressing Alt while dragging on the value. The latter method is particularly useful for tablet users.

Using Sliders

To set a value with a slider


Drag the knob to the desired value. OR Click the desired value on the graduated scale beneath the slider.

To reset a slider to its default value


Ctrl+click (Mac users Cmd+click) on the slider.

Separating Channels

By default, many parameters in Nuke automatically gang channels for you. For example, if you drag on the Gain slider in the ColorCorrect node, you simultaneously affect the R, G, and B channels (assuming youre processing the RGB channel set). You can, however, use the parameters channel chooser button to reveal and edit the values assigned to individual channels.

To edit an individual channels value


1. Click the parameters channel chooser button. The number on its surface lets you know how many channels are available for editing. A series of input fieldsone for each individual channelappears.

2. Edit the values in any of the revealed input fields as necessary. You can also use a color slider for editing individual channels. See Using Color Sliders and Color Wheel on page 54.

Using the Color Picker and Color Controls

Nuke offers a color picker for inputting values. Color pickers are especially useful for setting white or black points, or for color matching tasks, such as sampling values in a background plate to color-correct a foreground image.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

53

To use the color picker and color controls


Click the color picker button to display and make color selections. The color picker window opens. To activate the eye dropper and sample colors from the Viewer (see below), click the color swatch button. To copy a color from one color swatch to another, drag and drop the color swatch with the desired color on top of the swatch whose color you want to change. To toggle between using the slider and manually entering values for each of the channels, click the channel chooser button (which displays the number of available channels).

color swatch color picker 3-channel

Figure 3.18: Options for color selection.

To sample a color from the Viewer


1. In the parameters, click the color swatch to activate the eye dropper. 2. Move your mouse pointer over the Viewer from which you wish to copy color values. 3. Zoom and pan as necessary until the region from which you want to sample is clearly visible. 4. Ctrl/Cmd+click to sample a color value from the Viewer, or Ctrl/ Cmd+Alt+click to sample a color from the nodes input while viewing its output. To sample a region rather than a single pixels color value, also press Shift. The input fields associated with the color picker update to reflect the color values of the sampled pixels. In the case of a sampled region, Nuke inserts the average color values of all inlying pixels. 5. If you didnt manage to sample just the right pixel or quite the right region, Ctrl/Cmd+click, Ctrl+Alt+click, Ctrl/Cmd+Shift+click, or Ctrl/ Cmd+Alt+Shift+click again. A new overlay appears and the old one disappears. 6. When youve captured the right values, click the color picker button again. The color swatch reappears displaying the color or color average you sampled.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

54

Using Color Sliders and Color Wheel

Some parameters offer color sliders and a color wheel for inputting values. These offer an intuitive and precise means for assigning just the right color value to a parameter.

To display the color sliders and color wheel


Click the parameters color picker button. The color sliders and wheel appear.
currently selected color last selected color original color the available slider sets show/hide the color wheel show/hide the color swatches use dynamic colors for slider backgrounds

left/right-click the slider label to nudge the value by 0.01

drag here to adjust saturation drag here to adjust the hue

To customize the color sliders and wheel window


From the TMI, HSV, and RGB buttons, select which slider set you want to display. The available slider sets are described below. To make the sliders horizontal rather than vertical, resize the color sliders window. When the window is wide enough, the sliders become horizontal.

If you want the background of the sliders show what the value of the color would be if the sliders were set to the current position, click the Dyn button.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

55

Click the color wheel button to cycle through three states: the color wheel, the color square, and hide color wheel/square.

To hide or show the color swatches, toggle the color swatches button.

To use the color wheel


To adjust the hue, drag the marker on the edge of the color wheel/on the circle.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

56

To adjust the saturation, drag the marker inside the wheel/square.

Tip

You can also Ctrl/Cmd+click on the color wheel to only affect the hue of the selected color, and Shift+click to only affect the saturation.
To zoom in and out of the color wheel, press Alt and drag right or left with the middle mouse button. To pan in the color wheel, press Alt and drag the mouse pointer over the color wheel. To reset the zoom and/or pan, middle-click on the color wheel.

To use the color sliders


To increment the value by 0.01, right-click on the slider label (e.g. R or A). To decrement the value by 0.01, left-click on the label. Use Shift+click for 0.1, and Alt+click for 0.001. You can also click and drag right or left on a label to scrub the value up or down. Use Shift+drag to scrub faster, and Alt+drag to scrub slower.

These are the functions of the TMI sliders: The temperature slider (T) lets you control apparent color temperature by inversely affecting red and blue values (assuming your are processing the RGBA channel set). To cool (that is, increase the blue channels value, while decreasing the red channels), drag up. To heat (increase the red channels value, while decreasing the blue channels), drag down. The magenta/green slider (M) lets you control the mix of green and magenta hues. To add more magenta (increase the red and blue channels values, while decreasing the green channels), drag up. To add more green (increase

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

57

the green channels value while decreasing the red and blue channels), drag down. The intensity slider (I) lets you simultaneously control the red, green, and blue channel values. To increase the value of all channels by the same amount, drag up. To decrease the value of all channels by the same amount, drag down. To increase the channels value, drag up. To decrease it, drag down.

These are the functions of the HSV sliders: The hue slider (H) lets you control the colors location on the traditional color wheel (for example, whether the color is red, yellow, or violet). The saturation slider (S) lets you control the intensity or purity of the color. The value slider (V) lets you control the brightness of the color (the maximum of red, green, and blue values).

These are the functions of the RGB sliders: The red slider (R) lets you control the red channels value (or the first channel in a channel set if you are processing another set besides RBGA). To increase the channels value, drag up. To decrease it, drag down. The green slider (G) lets you control the green channels value (or the second channel in a channel set if you are processing another set besides RBGA). To increase the channels value, drag up. To decrease it, drag down. The blue slider (B) lets you control the blue channels value (or the third channel in a channel set if you are processing another set besides RBGA). To increase the channels value, drag up. To decrease it, drag down.

The alpha slider is included in all three slider sets: The alpha slider (A) lets you control the alpha channels value (or the fourth channel in a channel set if you are processing another set besides RBGA). To increase the channels value, drag up. To decrease it, drag down.

To use the color swatches


When you have found a good color, you may want to save it in one of the color swatches for further use. To do so, adjust the color wheel or sliders until you are happy with the color, and right-click on the color swatch where

The Foundry

Nuke 6.3v6

USING THE INTERFACE Properties Panels

58

you want to save it. You can also drag and drop a color into a color swatch from any other color button or swatch.

To open another color picker window


To open another color picker window while keeping the first window open, Ctrl/Cmd+click on another parameters color picker button.

To switch between the current and previous or original color


The rectangle above the sliders shows the original color (on the right) next to the currently selected color (on the left). When you drag the markers to adjust the color, the last selected color is shown in between these. To switch between the currently selected color and the original color, click on the rectangle.

Customising a Nodes Defaults with Node Presets

Sometimes the default control values on a node arent the ones you use most often. If you find yourself frequently adjusting many controls defaults, you may want to save your customised default values as a node preset.

To create a node preset: 1. Set the controls in a nodes control panel to the values you want. 2. Click the Load Node Presets button on the control panel title bar and select Save as Preset. 3. Give your preset a name and click Create. Your new preset now appears as an option when you click the Load Node Presets button and select Apply Preset.

To load and delete a preset: 1. To load a preset on a node, you can click the Load Node Presets button and select your preset under Apply Preset. User presets are your own personal presets, and shared presets can also be used by other users.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Animating Parameters

59

2. To delete a preset you need to click the Load Node Presets button and select Delete Preset. In the dialog that displays, select the preset you want to delete from the dropdown menu, and click Delete.

Animating Parameters

Animating a parameter refers to changing its value over time. You do so by setting keyframes (frames at which you explicitly define a value) and allowing Nuke to interpolate the values in between. You can animate most of Nukes parameters in this manner.

Working with Animated Parameters

The Animation menu lets you set key frames, delete keys, and perform other editing operations on the curves for animated parameters.

Figure 3.19: The animation menu.

To set key frames


1. Use a Viewer to cue to a frame where you want to place a key. 2. Click the animation button next to the parameter you want to animate. 3. Select Set key from the drop down menu. The parameters input field turns blue, indicating that a keyframe has been inserted. Nuke enters the autokey mode: when you change the parameters value at another frame, it will automatically create a keyframe for you. You can also set a key for all the controls in a node. To do so, select Set key on all knobs from the properties panel right-click menu. 4. Cue to the next frame where you want to place a key.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Animating Parameters

60

5. Edit the parameters value using the input field, regular slider, or color slider. The moment you change the value, Nuke creates a keyframe. 6. Continue adding key frames as necessary. 7. Use the Viewers scrubber to preview the result.

To delete a single keyframe


1. Use the Viewers next keyframe and previous keyframe buttons to cue to the keyframe that you want to remove. Notice that the scrub bar indicates key frames with a blue mark. 2. Click the animation button. 3. Select Delete key from the drop down menu. Nuke removes the keyframe.

To delete all key frames from a parameter


1. Click the animation button. 2. Select No animation from the drop down menu. A confirmation dialog appears. Select Yes. Nuke removes all key frames from the parameter, and sets the static value to match that of the current frame.

To link animated parameters with a Tracker node


You can link any controls with others by using expressions (see the Expressions chapter in the Nuke User Guide), but linking with the Tracker node is even easier than that if you use the Link to option in the Animation menu. For example to link the translate control of the RotoPaint node with a Tracker node, do the following: 1. Create the Tracker node you want to link to. 2. On the Transform tab of the RotoPaint nodes control panel, click on the translate animation menu. 3. Select Link to > Tracker linking dialog 4. Select the Tracker node you want to use in the tracker node dropdown and in the link to dropdown, select whether you want to link to the position of the track or the translate values of it. 5. Select which tracks you want to use by checking the track boxes. The Expression field updates with the appropriate expression syntax. Then click OK, and your linking is done. Your Bezier shapes translate value now changes when the Tracker value is changed.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Keyframes in the Dope Sheet

61

Animated Parameters in the Dope Sheet and the Curve Editor

As you add key frames to a parameter, Nuke automatically both adds markers to the Dope Sheet for them and plots a curve on its Curve Editor panel, where each value (the y axis) is plotted as it changes over time (the x axis). You can add key frames, delete key frames, and even adjust the interpolation between key frames without ever looking at this curve. However, as the animation grows more complex, you may find it easier to edit the animation by manipulating this curve and the keyframes directly. For more information on how to do so, see Working with Keyframes in the Dope Sheet on page 61 and Using the Curve Editor on page 64.

Working with Keyframes in the Dope Sheet


Viewing Keyframes in the Dope Sheet

The Dope Sheet gives you access to all the keyframes youve created, and provides an easy way of editing them. You can also use it to reposition Read nodes and trim them.

To use the Dope Sheet for editing your script, you need to create some Read nodes or keyframes first. The Dope Sheet displays all your Read nodes that have their control panels open, and any nodes youve used to create keyframes. To open the Dope Sheet do the following: 1. Click the Dope Sheet tab to open it and view your Read nodes and keyframes. If you cant see the tab, right-click the Node Graph title bar and select Dope Sheet. 2. Click through the hierarchy on the left to see your nodes and a hierarchical list of animated controls. If you cant see a node in the list, try opening its control panel. You can also force the node to always display in the Dope Sheet by checking the always in dope sheet box on the nodes control panel or by pressing Alt+D. Your keyframes display on the right view as gray lines in the keyframe grid. If you go down to the lowest level of hierarchy, you can also view the keyframes set for different views in stereoscopic projects. You can also open a nodes control panel by clicking the node in the hierarchy view. 3. If you want to view an AudioRead node under your keyframes, you can display it by right-clicking and selecting View > Audio > Draw Style > Below. For more information on the Audio options, see the Audio in Nuke chapter in the Nuke User Guide.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Keyframes in the Dope Sheet

62

Keyframe markers

Read node trim handles

Synchronising the Frame Range Between the Dope Sheet and the Curve Editor

You can synchronize the frame range of your project between the Dope Sheet and the Curve Editor. This is useful when youre using both of them to edit your animation curves and keyframes at the same time. To synchronize the frame range: 1. Right-click anywhere on the Dope Sheet. 2. Select Edit > Synchronise frame range. Any changes you make in the Dope Sheet are now applied in the Curve Editor too, and vice versa. Zooming in and out in either also zooms the other view. You can also do this by clicking the Synchronise Frame Range button at the bottom of the Dope Sheet.

Selecting and Editing Keyframes

To select keyframes
To select multiple keyframes, drag a marquee over your keyframes in the keyframe view. To select a single keyframe, click it in the keyframe view. Its parent keyframe and all other keyframes depending on it are selected too. The frame number of the frame displays next to the frame marker line.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Working with Keyframes in the Dope Sheet

63

To select all keyframes in one node, click the node name in the hierarchy view. All the child keyframes under that node are selected.

To move and rescale keyframes


After youve selected keyframes, you can move and rescale them: To move your keyframes, drag the selection around in the keyframe view. To nudge the selected keyframes right or left, use the keypad arrow keys. To edit the frame number of your keyframe directly, double-click on the frame number next to the keyframe and adjust it in the x field box that pops up. You can also move your keyframes with the move control at the bottom of the Dope Sheet: enter the number of frames by which you want to move the selected keyframes, and click Move. You can enter negative values to move the keyframes backwards. To rescale, grab the right or the left side of your marquee selection box and drag it. The opposite side of the box stays put and the keyframes are proportionately rescaled according to how you adjust the box.

To delete and add keyframes in the Dope Sheet


You can remove keyframes in the Dope Sheet. To delete a keyframe, just select it and press Delete/Backspace button or right-click on the keyframe and select Edit > Erase. You can also add keyframes in the Dope Sheet to add animation where there isnt any at the moment. Add keyframes by Ctrl/Cmd+Alt+clicking on an empty spot in the Dope sheet. A new keyframe is created and you can adjust it as necessary.

Repositioning and Trimming Read Nodes

You can reposition and trim your Read nodes in the Dope Sheet using the Read node handles.

To view all your Read nodes in the Dope Sheet: By default, only the Read nodes that have control panels open show up on the Dope Sheet. If you click the Show All Reads button, all Read nodes on your script are added in the hierarchy view. If you click the button again, the default view is restored. You can also open a nodes control panel by clicking the node in the hierarchy view.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

64

To position your Read node: 1. Select the Read node you want to move in the hierarchy view. The lines signifying the frame range of that Read node are selected. 2. Drag the Read node lines right or left depending on where you want to position it.

To trim a Read node: 1. Select the Read node you want to move in the hierarchy view. The lines signifying the frame range of that Read node are selected. 2. Move the Read node handles in the keyframe view to adjust the frame range of your Read node. The frame range control in the Read node control panel is adjusted automatically. 3. If you want, you can change how the sequence displays outside of the frame range youve defined. Adjust the before and after dropdown lists next to the frame range control in the Read node control panel to change what happens before and after the frame range limits correspondingly: hold - select to show a still picture of the first/last frame of the frame range. loop - select to start over and keep looping the span of the frame range outside the first/last frame of the frame range. bounce - select to play the span of the frame range backwards and forwards between the frame range limits. black - select to display a black frame outside of the first/last frame. Tip

You can also define which frame range you want to use from a specific clip using the original range control in the Read nodes control panel. For example, if you set the original range to be from frame 40 to 50, then the Read node indicator in the Dope Sheet will only show that clip as ten frames long. This is for visual reference, rather than a change in what is read in, and it may make it easier to work with many Read nodes in the Dope Sheet.

Using the Curve Editor

The Curve Editor enables you to edit curves without physically entering information in the Properties Bin.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

65

Displaying Curves

To reveal an animation curve


1. Click the animation button next to the parameter whose curve you wish to view. 2. Select Curve Editor. The Curve Editor panel appears with a focus on the selected parameters curve. The vertical, or y axis, denotes the value of the parameter. The horizontal, or x axis, denotes time (in frame units).
key frames parameter tree selected curve

selected keyframe current frame indicator

expression field

Figure 3.20: Nukes Curve Editor panel.

To display curves in the Editor


1. In the parameter tree on the left, click the + and - signs to expand and collapse the hierarchy as necessary. 2. Click a parameters name to make its curve the focus of the editor. To focus on multiple curves at the same time, Shift+click on the names in the parameter tree. 3. To display separate curves for each channel, separate the channels for the relevant control in the nodes properties panel. The parameter tree on the left lets you focus on any curve in the script. Tip

If you want to view an AudioRead node under your animation curves, you can display it by right-clicking and selecting View > Audio > Draw Style > Below. For more information on the Audio options, see the Audio in Nuke chapter in the Nuke User Guide.

To remove a curve from the Editor


1. In the parameter tree on the left, click the + and - signs to expand and collapse the hierarchy as necessary.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

66

2. Select a curve in the parameter tree, and press Delete.

To zoom in or out in the Editor


1. Click on the area you want to zoom in on or out of. 2. Press the + button to zoom in, or the - button to zoom out, OR Scroll up with the mouse wheel to zoom in, or down to zoom out. Tip

To zoom to a custom area in the Curve Editor, middle-click on the Editor and drag to select an area with a marquee. When you release the mouse button, the Editor will zoom to fit the selected area in the Editor.

To pan in the Editor


Hold the middle mouse button and drag over the Editor. You can also use Alt+drag.

To reset zoom and panning


1. Right-click on the Curve Editor. 2. From the menu that opens, select View > Frame All. OR Press A on the Editor. OR Click the middle mouse button. Nuke centers the curve in the Editor, resetting the zoom.

To center a portion of the curve in the editor


1. Select the points you want to center in the editor. 2. Right-click on the Editor, and select View > Frame Selected (or press F on the Editor). Nuke centers the selected portion of the curve in the editor. If no points are selected, Nuke centers the selected curve, or all curves.

Editing Curves

You edit curves by moving the points on the curve to new locations. If necessary, you can add more points to the curve. You can also sketch curves freely, use the usual editing functions such as copy and paste, smooth curves with filtering, interpolate curves, loop, reverse or negate curves, and use expressions to modify curves.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

67

To add points to a curve


1. Click on the curve you want to edit. The curve turns yellow to indicate its selected. 2. Ctrl+Alt+click (Mac users Cmd+Alt+click) on the part of the Curve Editor you want to add a point to. You can add points both on the curve and outside the curve, OR 1. Right-click on the Editor and select Edit > Generate. The Generate keys dialog opens. 2. In the Start at field, enter the first frame you want to use as a keyframe. 3. In the End at field, enter the last frame you want to use as a keyframe. 4. In the Increment field, enter the frame increment you want to use between the first and the last keyframe. For example, if you want every tenth frame to be a keyframe, enter 10. 5. In the last field, enter the value you want to use for y. If you do not enter a value here, the key frames are added to the current curve without modifying the curve shape. 6. Click OK.

To select points on a curve


To select individual points, click on the point you want to select. To select multiple points, Shift+click on the points, or drag a marquee around them. A box is drawn around the points, and the points turn white to indicate they have been selected. To select all points, press Ctrl+A (Mac users press Cmd+A). A box is drawn around the points, and the points turn white to indicate they have been selected.

To move points on a curve


To move a point along either the x or y axis only, drag the point to a new location. To move a point in any direction, Ctrl+drag (Mac users Cmd+drag) the point to a new location. You can also nudge points using the numeric keypad arrows. To adjust the values of a point numerically, select the point and doubleclick on the x or y value that appears next to it.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

68

By default, when you move a point, its position on the x axis is rounded to the nearest integer. To disable this, you can right-click on the Curve Editor and select Edit > Frame Snap. You can also momentarily disable the snapping by pressing Shift while moving a point. To move several points at the same time, select them and drag the selection box to a new location.

To add or remove points to or from the selection box, Shift+click on the points. To resize and scale the selection box, drag its edges. If the selection box is very narrow, you can press Ctrl/Cmd when resizing it. This allows you to resize the box in one dimension only. For example, if you have a box thats wide on the x axis but flat on the y axis, you can resize it in this way along the x axis. To avoid accidentally moving a point inside the selection box, press Ctrl/ Cmd+Shift when dragging the box to hide the points inside the box.

To adjust the slope around the points


1. Select a point on the curve. Red tangent handles appear on both sides of the point.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

69

2. Drag the tangent handles to a new location. The curve follows the handles.

To sketch a curve freely


Press Alt+Ctrl+Shift (Mac users press Alt+Cmd+Shift) while drawing a curve on the editor. Nuke sketches a curve that follows your mouse movements.

Alt+Ctrl/Cmd+Shift

To cut, copy, and paste selected points, expressions, or curves


1. Right-click on the Curve Editor. 2. From the menu that opens, select Edit and the editing function you want to use on the entire curve, for example: Edit > Copy > Copy Selected Keys to only copy the points you have currently selected. Edit > Copy > Copy Curves to copy an entire curve. Edit > Copy > Copy Expressions to copy the expression that creates the curve. Edit > Copy > Copy Links to copy a curve and keep its values linked to the original curve, so that if you change the original, your changes also affect the copied curve.

To move selected points on the curve by a fixed value


1. Select all the points you want to move. 2. Right-click on the editor and select Edit > Move. The Move Animation Keys dialog opens.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

70

3. In the x and y fields, define how you want to move the points along the x and y axes. For example, to shift the selected points to the right by a value of 10, enter x+10 in the x field.

4. In the slope and left slope fields, define how you want to move the points tangent handles.

To smooth the curve with filtering


1. Select the portion of the curve that needs smoothing. 2. Right-click on the editor and select Edit > Filter. The Filter Multiple dialog opens. 3. In the No. of times to filter field, specify how many times you want to filter the curve. Filtering sets new values on each point based on the average values of their neighbouring points. The more filtering, the smoother the curve.

before filtering

after filtering

To interpolate parts of a curve


1. Select the point(s) between or around which you want to interpolate the curve. 2. Right-click on the Editor. Select Interpolation and the type of interpolation you want to use. Select Constant to force a constant value after each selected point.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

71

Linear to use linear interpolation. This produces sharp changes at key frames and straight lines between them.

Smooth to set the tangents slopes equal to the slope between the keyframe to the left and the keyframe to the right if the selected point is between these two key frames along the y axis. If the selected point is not between these key frames and has a larger or smaller value than both key frames, the tangents slopes are made horizontal. This ensures the resulting curve never exceeds the keyframe value.
between the previous and next keyframe on y

not between the previous and next keyframe on y

Catmull-Rom to set the tangents slope equal to the slope between the keyframe to the left and the keyframe to the right regardless of where the selected point is located. The resulting curve can exceed the keyframe values.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

72

Cubic to set the slope so that the second derivative is continuous. This smoothens the curve.

Horizontal to make the tangents horizontal, setting the slope around the selected points to zero.

Break to adjust the two tangents of a selected point independent of each other.

Before > Constant or Linear to interpolate the parts of the curve that are on the left side of the first point. This option only works if you have selected the first point on the curve.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

73

constant

linear

After > Constant or Linear to only interpolate the parts of the curve that are on the right side of the last point. This option only works if you have selected the last point on the curve.

constant

linear

To repeat a portion of the curve throughout the curve


1. Right-click on the editor and select Predefined > Loop. The Loop dialogue opens. 2. In the First frame of loop field, enter first frame of the portion you want to repeat throughout the curve. 3. In the Last frame of loop field, enter the last frame of the portion you want to repeat. 4. Click OK. The shape of the curve between these frames is repeated throughout the rest of the curve. The solid line represents the actual curve, and the dotted line the original curve with the key frames.
the portion to loop

To reverse a curve
Right-click on the editor and select Predefined > Reverse.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the Curve Editor

74

This makes the curve go backward in time. Both the new curve and the original curve are displayed. The solid line represents the actual curve, and the dotted line contains the key frames that you can modify.

before reverse

after reverse

To negate a curve
Right-click on the editor and select Predefined > Negate. The curve becomes the negative of the key frames. For example, a value of 5 turns into -5. Both the new curve and the original curve are displayed. The solid line represents the actual curve, and the dotted line contains the key frames that you can modify.

before negate

after negate

To use an expression to modify a curve


Enter the expression in the expression field at the bottom of the Curve Editor,

OR 1. Right-click on the Editor, and select Edit > Edit expression. 2. In the dialog that opens, type the expression you want to use for the curve, for example, sin(x)/x.
The Foundry Nuke 6.3v6

USING THE INTERFACE Viewers

75

3. Click OK.

Viewers

Viewer nodes, unlike process nodes, dont alter data in any way; rather, they act as windows on it. Each Viewer node displays the render output of any connected process nodes in the Viewer panel. Viewer nodes are essential for quickly assigning the right values to parameters because they allow you to edit in contextthat is, edit a given nodes parameters upstream in a script while viewing the effect of those changes downstream. You can place as many Viewer nodes in a script as you wish, which allows you to simultaneously view multiple outputs. You can also pipe the output from up to ten process nodes into single Viewer node, and then cycle through the various displays. This allows you to easily compare an image before and after processing by a given effect. Note

The maximum image size the Viewer can display is 64k x 64k (or the equivalent number of total pixels at other resolutions). Make sure though, that you have sufficient RAM memory available if you want to use the maximum image size.
Viewers have corresponding nodes that appear in the Node Graph. These nodes do not produce output for rendering; they generate display data only. You can connect Viewer nodes as described in Working with Nodes on page 30. In practice, youll work faster by using the Viewer hotkeys described below.

Adding Viewer Nodes

To add a Viewer node


1. Select the node whose output you wish to view. 2. Do one of the following: Using the menu bar, choose Viewer > Create New Viewer. Using the Toolbar, choose Image > Viewer. Using a keyboard shortcut, press Ctrl+I (Mac users press Cmd+I). Nuke connects a Viewer node to the node you selected in step 1, and displays the output of the node in the Viewer panel. You can also insert

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

76

a Viewer node and set up its first connection by simply pressing 1 over the Node Graph.

Connecting Viewer Nodes

Once you add a Viewer node to the script, you can quickly pipe any process nodes output to it simply by selecting the process node then pressing any number key. Doing so pipes the output to one of the ten input ports available on every Viewer node (the 0 key represents the tenth slot).

Figure 3.21: A Viewer node with multiple inputs.


.

Toggling Views

If a Viewer node has multiple inputs, like the one depicted above, you can press the up or down arrow keys to quickly cycle through the views (your cursor needs to be in the Viewer window). To view a particular node press the number key (1, 2, 3... 0) corresponding to the pipe number whose contents you wish to view.

Panning and Zooming the Viewer Window


Note

To pan the frame


Hold the middle mouse button and drag on the display (you can also use Alt+drag). The frame follows the mouse pointer.

On Linux, Alt+drag may not work as expected. This is due to the default window functionality on Gnome. To get around it, you can use the Windows key instead of Alt when panning. Alternatively, you can change your window preferences on Gnome to fix the problem:

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

77

1. Select Applications > Preferences > Windows to open the Window Preferences dialog. 2. Under Movement Key, select Super (or Windows logo). You should now be able to pan with Alt+drag.

To recenter the frame


Click the middle mouse button or press F.

To zoom in on the frame


1. Move your pointer over the area of the display on which you want to zoom. 2. Drag the mouse while pressing the middle mouse button and the left mouse button. OR Press the plus button (+) repeatedly until the frame attains the desired scale. OR Select zoom in from the zoom pulldown menu in the top right corner.

To zoom out from the frame


1. Move your pointer over the area of the display from which you want to zoom. 2. Drag the mouse while pressing the middle mouse button and the left mouse button. OR Press the minus button (-) repeatedly until the frame displays at the desired scale. OR Select zoom out from the zoom pulldown menu in the top right corner.

To restore the zoom to 100%


Press Ctrl+1 (Mac users press Cmd+1).

Hiding Floating Viewers

To hide a floating Viewer


Press (the accent key).

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

78

To show a hidden floating Viewer


Press (the accent key) again.

Using the Viewer Controls

A Viewers on-screen controls let you navigate the timeline, display channels, zoom, choose cameras (3D mode), and create display wipes and composites.

Timeline controls
Drag the orange marker along the timeline to quickly cue to a specific frame. The number of the current frame appears in the Current field above the timeline. You can also cue to a frame by typing its number directly into this field.
current frame frame increment playback buttons

frame range source

time marker

Figure 3.22: Timeline controls. By default, Nuke automatically adjusts the timeline of every Viewer window to show the frame range defined in your Project Settings. If no frame range is defined, the frame range of the first image you read in is used as the global frame range. Viewer timeline controls also have a frame range source pulldown menu that you can use to define where the timeline gets its frame range from. You can set this menu to Global, Input, or Custom. Global is the default setting described above. To have the Viewer adjust the timeline to show the in and out frames of the current input clip, select Input from the frame range source menu. The number of the first frame in the clip is shown in the left end of the timeline and the number of the last frame in the right end. If you change the input of the Viewer, the frame range on the timeline is adjusted accordingly. To manually adjust the frame range for the current Viewer window, pan and zoom on the timeline until you see the desired frame range and Custom becomes selected in the frame range source menu. Alt+drag to pan, and MMB+drag to zoom in. You can also zoom in on or out of the timeline using

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

79

the mouse wheel. To reset the zoom, press the middle mouse button over the timeline. To adjust the playback range for the current Viewer window, Ctrl+drag (Mac users Cmd+drag) the red playback range marker on the timeline to a new in and out frames as shown in Figure 3.23, or click on the frame range lock button and enter a new playback range in the playback range field.

Figure 3.23: Adjusting the frame range for the current Viewer. To toggle between the new playback range and the visible timeline range, click the button next to the playback range field.

Figure 3.24: Playback is locked to the range defined in the playback range field.

Figure 3.25: The entire visible timeline range is used.

The fps field (frames-per-second) initially displays the projects playback speed. Nuke will attempt to maintain this speed throughout playback, although this adjusts depending on the resolution of the imagery and your hardware configuration. The Frame Increment field lets you specify the number of frames by which the Previous increment/Next increment buttons cue the sequence. The following table lists the functions of the playback buttons:
Buttons Functions

The First frame and Last frame buttons cue the sequence to the first and last frame. The Previous keyframe and Next keyframe buttons cue the sequence to the scripts previous or next keyframe.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

80

Buttons

Functions

The Play backward and Play forward buttons play the sequence backward or forward at the scripts frame rate. The Back 1 Frame and Forward 1 Frame buttons cue the sequence to the previous or next frame. The Stop button halts playback. The Previous increment and Next increment buttons cue forward or back by 10 frames by default. These are useful for heavy keyframing tasks. You can adjust the increment value as necessary.

The Playback Mode button lets you control how many times and in what direction the Viewer plays back the sequence. Click the button to toggle between the following modes:
Button Function

Repeatedly play the sequence (loop). Play the sequence once from the current frame to the head or tail (stop). Repeatedly play the image back and forth from head to tail.

Jumping to a specific frame


You can move quickly to a specific frame on the timeline by choosing File > Go to frame (or by pressing Alt+G), entering a frame number in the dialog that appears, and clicking OK.

Synchronizing Viewer playback


The Lock/Unlock button lets you toggle synchronized playback of Viewer windows. By default, all Viewers are lockedthat is, if you cue to a frame in one Viewer, all other Viewers follow suit.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

81

Figure 3.26: Synchronizing Viewers. When the lock icon changes from a closed lock to an open lock, that Viewers playback becomes independent of other Viewers, and not cued to the other Viewers.

Pausing the display


The Pause button stops the Viewer from updating and holds the last frame rendered. To reactivate display rendering for all frames, press the button again.

Click to manually update when Pause is active.

Click to stop Viewer update.

Figure 3.27: Pausing the display update of a Viewer. You can click the render update button next to Pause (or press U) to manually update the display while keeping Pause active.

Displaying a single channel


You can press the R, G, B, and A keys on your keyboard to display the red, green, blue, and alpha channels respectively. Or, you can also select a channel from the RGB pulldown menu in the top left corner.

Figure 3.28: Displaying a single channel. Press one of the channel keys again to toggle back and display all channels.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

82

Tip

If you press Shift while selecting the channel, your selection only affects the currently active input of the Viewer node. This way, you can display different channels from the Viewers different inputs. For example, when keying it can be useful to view the RBG channels from one input and the alpha channel from another, and toggle between the two. To achieve this, do the following: 1. Create a Viewer with several inputs. See Connecting Viewer Nodes on page 76. 2. Activate one of the inputs by pressing its number (for example 1) on the Viewer. 3. Press Shift and select RGB from the channel menu. 4. Activate another input (for example, input 2) by pressing its number on the Viewer. 5. Press Shift and select A from the channel menu. 6. Toggle between the inputs by pressing their numbers or the up and down arrow keys.

Channel Set and Channel Display Lists


The channel set list lets you choose a set of color channels to display in the Viewer. By default, this is set to display the rgba set, but you can choose any channel set in the data stream.

Figure 3.29: The channel set and channel display lists. The Channel list controls which channel appears when you view the alpha channel. The default setting actually does display the alpha channel when you press the A key; however, you can change this by selecting any channel in the data stream.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

83

Figure 3.30: Selecting the channel to display when A is pressed.

Superimposing an images alpha channel over its RGB channels


When youve read in an image that has an alpha channel, you can display the alpha channel as a red overlay on top of the images red, green, and blue channels.

To display an images alpha channel on its RGB channels: 1. Select Image > Read to read in an image. 2. Connect a Viewer node to the Read node. By default, Nuke displays the red, green, and blue channels in the Viewer.

3. Click on the Viewer to make sure its the currently active panel. 4. Press M. Nuke displays the images alpha channel as a red overlay on top of the RGB channels.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

84

5. To return to the RGB display, press M again.

Image format labels


The Pixel Value indicator displays information about the pixel underlying the pointer or about a sampled pixel or region of pixels. (You can sample a single pixel from the Viewer by pressing Ctrl/Cmd while clicking, a region from the Viewer by pressing Ctrl/Cmd+Shift while dragging, a single pixel from the nodes input by pressing Ctrl/Cmd+Alt while clicking, and a region from the nodes input by pressing Ctrl/Cmd+Alt+Shift while dragging.) From left to right, the indicator displays the following about the current pixel or sample: its x and y position; its Red, Green, Blue, and Alpha values; and other values depending on the color type you have selected from the color type menu on the right. The Format indicator displays the image resolution and the size of the bounding box.

Using the Zoom list


The Zoom list lets you select the magnification factor by which the current image is displayed. This list also shows the hotkeys to press to quickly switch between the different zoom settings.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

85

Figure 3.31: Selecting a display zoom.

Proxy mode
Nuke can generate low-res proxies for displayed frames as needed when you press Ctrl/Cmd+P or click the proxy mode toggle button on the Viewer to activate the proxy display mode.

Figure 3.32: Proxy mode toggle. For more information, Proxy Mode on page 112.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

86

Full resolution

Figure 3.33: High-res display.

Proxy

Figure 3.34: Proxy display. The global proxy resolution and/or scale are determined by the project settings, which you can open by selecting Edit > Project Settings (or pressing S).

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

87

Figure 3.35: Proxy display resolution defined on the Project Settings properties panel. You can also read in rendered proxies using the Read nodes controls. The proxy file does not need to match the proxy resolution in use. Depending on your settings, either the full-res or proxy file will be scaled to the required proxy size. For more information, see Read nodes and proxy files on page 114.

Figure 3.36: Reading in proxy versions of images.

Lowering the display resolution of individual Viewers


Viewers also have a pulldown menu that allows you to easily switch to lower display resolutions, regardless of whether you have activated proxy mode or not. Using this multiplier setting, you can, for example, change the display resolution of an individual Viewer to 50% of the current (be it fullsize or proxy) resolution. This is useful if you want to have Nuke display your images more quickly without having to touch the project settings. It also comes in handy if you have just a few very large plates in your script, as you can choose to use lower resolutions when viewing just these plates.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

88

To lower the display resolution of individual Viewers: From the Viewers down-rez menu, choose the factor by which you want to lower the display resolution. Select: 1 to display 1/1 of the currently active resolution. 2 to display 1/2 of the currently active resolution. 4 to display 1/4 of the currently active resolution. 8 to display 1/8 of the currently active resolution. 16 to display 1/16 of the currently active resolution. 32 to display 1/32 of the currently active resolution.

For example, if you have a 4K plate and are using a proxy scale of 0.5, your plate will still be 2K even in the proxy mode. Setting the down-rez factor to 2 in the Viewer will scale the plate down further to 50% of the proxy resolution, that is to 1K. This gives you much faster (but less accurate) feedback.

Pixel aspect ratio


The pixel aspect ratio determines whether your images are displayed using square or rectangular pixels. By default, the Viewer uses the pixel aspect ratio defined in your project settings. To see the current setting, select Edit > Project Settings (or press S). For example, a pixel aspect ratio of 2 accurately displays anamorphic footage the way it will be projected, as shown in Figure 3.37:

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

89

Figure 3.37: The Viewer uses the pixel aspect ratio defined for the script. If you want to ignore the pixel aspect ratio, you can toggle it by pressing Ctrl/Cmd+Shift+P over the Viewer window.

Figure 3.38: Press Ctrl/Cmd+Shift+P over the Viewer window to ignore the pixel aspect ratio.

Region of interest (ROI)


The ROI button lets you enable rendering only through a region of interesta portion of the image you explicitly select. This is useful for quickly viewing render results in a process-heavy script. To define a region of interest: 1. Click on the ROI button in the Viewer controls. The ROI overlay appears.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

90

ROI button

2. Drag to resize and move the ROI overlay as necessary. OR 1. Over the Viewer, press Alt+W once (do not hold the keys down). The ROI button turns red, but the ROI overlay does not appear. This allows you to freely draw your own ROI rather than adjust the default overlay. 2. Drag a marquee to draw the region of interest where you need it.

To clear a region of interest: 1. After youve set a region of interest, you can clear it by pressing Alt+W over the Viewer. You can then drag a new marquee to define a new region of interest. 2. To turn off the feature and update the whole Viewer with the recent changes, click the ROI button again (or press Shift+W).

Adjust display gain and gamma


The gain and gamma sliders let you adjust the displayed image, without affecting your final output. These controls are useful for tasks like spotting holes in mattes. You can boost or reduce gain by entering a multiplier (exposure value), dragging on the slider, or using the F-Stop arrows. Boost or reduce gamma by entering a gamma level or dragging the gamma slider.

gain toggle

display gain slider

gamma toggle

display gamma slider

Figure 3.39: Display gain and gamma controls. The gain and gamma toggle buttons let you switch between the default
The Foundry Nuke 6.3v6

USING THE INTERFACE Viewers

91

values of 1 (no change) and the last gain and gamma adjustments you made in the Viewer.

zebra stripe button

Figure 3.40: The Zebra Stripe button. Press the Zebra Stripe button to apply stripes to all pixels outside the range 0.0 to 1.0.

Input Process and Viewer Process controls Input Process and Viewer Process operations can be used to modify the
image from the viewed node before it is displayed on your monitor. Both only affect the Viewer in which they are activated and do not affect your rendered output. Input Process is a legacy system which uses a node instantiated in the Node Graph to process the image. This is handy for script-specific, temporary, or experimental use, but can be error prone due to the node accidentally being deleted or changed and is limited to a single node. The Viewer Process system was added in Nuke 5.2 and allows a gizmo (or compiled node) to be registered from the Python programming language at start-up. The registered item appears in a menu in the Viewer and the node is instantiated internally within the Viewer when the item is selected so there is no danger of accidental deletion or modification. This also enables multiple Viewer Processes to be registered at different points of start-up (as Nuke works through the NUKE_PATH menu.py files). The Viewer settings contain an option for the Input Process to be applied before or after the Viewer Process, so the two may be used in conjunction, for instance, with the Input Process applying a projection mask after the Viewer Process applies a film look profile. While you could combine the two into a single Viewer Process node, it can be advantageous to keep operations separated. Having both the Viewer Process and Input Process available provides a great deal of flexibility. You can create an Input Process by creating a node in the Node Graph and naming it as an Input Process using Nukes Edit menu. Once an Input Process has been named, the IP button appears in the Viewer controls. When the IP button is activated, any image you view is passed through the Input Process. Unlike Input Processes, Viewer Processes are registered using Python. They can be session independent and always appear in the Viewers Viewer

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

92

Process menu. There are two predefined Viewer Processes, sRGB and rec709, but you can also build and add your own. When a Viewer Process is selected from the Viewer Process menu, any image you view is passed through that Viewer Process. Whenever possible, the Input Process and Viewer Process are executed on the GPU. 1D LUT and 3D LUT (Vectorfield) have GPU implementations, so the built-in Viewer Processes will run on the GPU (unless gl buffer depth has been set to byte in the Viewer settings, in which case all processing is done on the CPU). To get the GPU'd versions of the nodes for use in a custom Viewer Process gizmo, press x over the Node Graph, enter ViewerGain, ViewerGamma, or ViewerClipTest in the command entry window, and press Return. The following table lists the differences between an Input Process and a Viewer Process.
Input Process Viewer Process

Set by selecting the node in the Node Graph Registered using Python. and choosing Edit > Node > Use as Input Process. Activated using the IP button in the Viewer controls. Requires that the node exists in the Node Graph. Can quickly and easily be modified by artists. Can also be accidentally deleted, disabling the effect. Activated using the Viewer Process menu in the Viewer controls. Is defined in a text file called menu.py that is run at start-up. Accessible for artists, but not likely to be accidentally modified or deleted.

Script dependent. Unless your Input Process Session independent. The Viewer Processes node is saved in the template.nk file that is registered in menu.py will always be available loaded at start-up, the Input Process is lost in each new session of Nuke. when you restart Nuke. There can only be one Input Process at a time. Setting a new Input Process overrides any previously used Input Process. There can be an unlimited number of Viewer Processes available in the Viewer Process menu. For example, it is possible to register Viewer Processes in any menu.py file at start-up, so Viewer Processes can be added at any directory in your NUKE_PATH.

Useful for temporary or non-critical viewing Useful for viewing options that you often options that you want in the current shot for need or that should not be modified by artconvenience, or for testing Viewer Processes ists on a shot-by-shot basis. before registering them. Can also be used for other things, such as field charts or masks that may be switched on or off and changed around in the shot.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

93

Note

Note that Input Processes and Viewer Processes are part of a built-in, fixed pipeline of nodes that are applied to images before they are displayed in the Viewer. This pipeline is either: gain > Input Process > Viewer Process > gamma > dither > channels > cliptest (if viewer input order has been set to before viewer process in the Viewer settings) OR gain > Viewer Process > Input Process > gamma > dither > channels > cliptest (if viewer input order has been set to after viewer process in the Viewer settings). However, depending on what the Input Process and Viewer Process are doing, the order in the built-in pipeline may not be the correct order. Therefore, if your Input Process or Viewer Process have controls that also exist for the Viewer, such as float controls named gain, gamma, or cliptest, then the Viewer will drive them from the corresponding Viewer controls and not do that image processing itself. This allows you to implement these controls in your Input Process or Viewer Process node/gizmo using whatever nodes and order you want. If your Input Process and Viewer Process do not have these controls, then the Viewer will apply the effects in its normal way according to the built-in pipeline. In the built-in pipeline, dither is applied to diffuse round-off errors in conversion of floating point data to the actual display bit depth. Although the cliptest is drawn at the end, it is computed on the image as input to the Viewer.

Note

By default, the predefined Viewer Processes, sRGB and rec709, affect all channels. However, if you want them to only affect the red, green, and blue channels, you can activate apply LUT to color channels only in the individual Viewer Settings or on the Viewers tab of the preferences.
Input Process controls To activate or deactivate the effect of an Input Process, click the IP button in the Viewer controls. Note that the IP button only appears if the input process field in the Viewer settings is not empty. The button is also only enabled when a node in the Node Graph is set as an Input Process.

Click here to activate / deactivate the effect of an Input Process.

Figure 3.41: Toggling the use of the Input Process.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

94

To open the Viewer settings, press S on the Viewer, or select Viewer Settings from the Viewers right-click menu. By default, input process is set to VIEWER_INPUT. If a node called VIEWER_INPUT exists in the Node Graph, it will automatically be used as the input process for the Viewer. This ensures backwards compatibility with pre-5.2 scripts. However, the Input Process node does not have to be named VIEWER_INPUT. You can use any node as an Input Process. Do the following: 1. Select the node in the Node Graph and choose Edit > Node > Use as Input Process. Alternatively, you can press S on the Viewer to open the Viewer settings and enter the name of the node in the input process field. 2. In the Viewer settings, you can also define whether the Input Process will be applied before or after the Viewer Process currently in use. To do so, set viewer input order either to before viewer process or after viewer process. The Input Process node should not be connected to other nodes in the Node Graph. If you attempt to connect it, an error will be displayed on the Viewer. If you delete the Input Process node from the Node Graph, the effect of the Input Process will be disabled.

Viewer Process controls To activate a Viewer Process, select it from the Viewer Process menu in the top right corner of the Viewer. Any images you now view using this Viewer are passed through the selected Viewer Process.

Figure 3.42: Selecting the Viewer Process to apply to images before they are displayed in the Viewer.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

95

Nuke includes the following predefined Viewer Process gizmos: sRGB and rec709. By default, sRGB is used because it is a best-guess default for a typical computer monitor. In addition to using the predefined Viewer Processes, you can also add your own by registering a node or gizmo as a Viewer Process. You can register as many Viewer Processes with custom Viewer LUTs as you like. For more information on creating and registering custom Viewer Processes, see Creating Custom Viewer Processes in the Configuring Nuke chapter in the Nuke User Guide. All available Viewer Processes (both predefined and custom ones) appear in the Viewer Process menu in the Viewer controls. To disable the use of a Viewer Process, select None from the Viewer Process menu. To open the properties panel of the currently active Viewer Process, select show panel from the Viewer Process menu. Note that if the control you want to adjust has the same name as any of the Viewer controls (for example, gain or gamma), you should adjust the control on the Viewer. This drives the control in the following: the Input Process controls if an Input Process is in use in the Viewer Process controls if no Input Process is in use. Tip

If you want to render out a file with the Viewer Process effect baked in, you can select Edit > Node > Copy Viewer Process to Node Graph to create an instance of the Viewer Process node in the Node Graph.

Monitor output toggle


The monitor output button lets you preview the current Viewer image on an external broadcast video monitor. You can select the external device and the display mode to use in the Viewer settings. To open the Viewer settings, press S on the Viewer. Note that this option is only available in Windows and Mac OS X versions of Nuke, and requires additional hardware, such as a monitor output card or a FireWire port. For more information, see Previewing on an External Broadcast Video Monitor in the Previews and Rendering chapter of the Nuke User Guide.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

96

2D / 3D Toggle and Camera Controls


The 2D / 3D list lets you toggle between 2D and 3D display modes in the current Viewer. This list also lets you choose between different orthographic (non-perspective) views when working in the 3D mode.

Figure 3.43: The 2D / 3D views and camera controls. The camera list on the right lets you choose which camera to look through when multiple cameras exist in your 3D scene. For more information on these controls, see the 3D Compositing chapter in the Nuke User Guide.

Using the Viewer Composite Display Modes

The wipe control provides an option for displaying a split-screen of two images, which can help you compare before and after versions for color correction, filtering, and other image manipulation. This control also includes display compositing options to overlay different images.

To display a comparison wipe


1. Select a node in your script and press 1 to display its output in the Viewer. 2. Select the node you want to compare and press 2. The 2 keystroke connects the image to the Viewer (assigning the next available connection, number 2). 3. From the A and B lists on top of the Viewer, select the images you want to compare. The lists include the last four nodes connected to the Viewer. 4. From the Viewer composite list in the middle, select wipe.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

97

The two images are displayed split-screen in the Viewer. You can view their details in the A and B information bars at the bottom of the Viewer.

Drag this handle to cross-dissolve.

Drag the crosshair to position the split line.

Drag this handle to rotate the split. View the information of your two images here.

5. Drag the handles of the crosshair to adjust the wipe: Drag the crosshair center to change its position. Drag the long handle (on the right) to rotate the wipe. Drag the arc handle to cross-dissolve the second image. 6. When finished with the split-screen, select none (-) from the Viewer composite list. Tip

If you press Shift while selecting a channel, your selection only affects the currently active input of the Viewer node. This way, you can display different channels from the Viewers different inputs. For example, when keying it can be useful to view the RBG channels from one input and the alpha channel from another, and toggle between the two.
The display composite optionsover, under, and minuscan also be selected to overlay two images. When the two images are 2D, this allows you to create a quick comp. When one image is 2D and the other is a 3D node, you can use under to line

The Foundry

Nuke 6.3v6

USING THE INTERFACE Viewers

98

up the wireframe preview with the 2D reference, and see how the 3D matches prior to a full render. One example of this is when you want to preview a wireframe 3D scene with a background plate that you are trying to match, as shown below.

3D node input

under selected

background plate

Figure 3.44: Comparing a 3D scene over a 2D image. For more information, see the 3D Compositing chapter in the Nuke User Guide.

Hiding and Showing Viewer Toolbars

To hide or show the top toolbar, press {. To hide or show the bottom toolbar, press }.

Locking the Viewer Zoom Level

You can choose to lock the Viewer zoom level, so that it doesnt change when you switch between inputs of different sizes. Right-click on the Viewer, and select Prevent Auto Zoom to toggle between maintaining the same zoom level for all inputs (on) and changing it according to on-screen image dimensions (off). Alternatively, you can also press Alt+Z on Viewer, or toggle prevent auto zoom in the Viewer settings.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the File Browser

99

Viewing Overscan in the Viewer

If you want the Viewer to show overscan, that is any pixels extending beyond the left/right or top/bottom of the frame, you can check the show overscan box the Viewer settings, press Alt+O or check the option in the Viewer right-click menu. Viewing pixels beyond the edges of the frame can be useful if some of your nodes need to have access outside the frame. You can also control the amount of overscan shown by specifying the pixel amount in the overscan field.

Tip

If you want the zoom level to remain constant after you enable the show overscan option, try enabling directly in the Viewer by selecting it in the right-click menu.

Viewing Deep Image Information in the Viewer

If youre working with deep images (such as DTEX), you can sample their depth information in the Viewer and view them in the Deep Graph in the bottom Viewer toolbar. For more information on how to use the Deep Graph, see Deep Compositing on page 376.

Click here to open or minimize the Deep Graph Deep Graph

Using the File Browser

Whenever you load or save files in Nuke, youll see a browser similar to the one shown in Figure 3.45. The directory navigation buttons let you create or access the directory from which you wish to read or write data.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the File Browser

100

navigation controls

pathname field

filter menu

Figure 3.45: Nukes file browser. The navigation controls let you move through the directory structure, bookmark favorite directories, and create new directory folders. Windows only: You can show/hide the drives that Windows auto creates by right-clicking the required drive, selecting Show Defaults, and checking or unchecking the drive.

To use the navigation controls


Click the Create New Directory button to create a new directory at your current position in the file hierarchy. Click Up one directory to go up one directory closer to the root. Click Previous directory to go back one directory.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the File Browser

101

Click Next directory to go forward one directory. Click Home to access the directory defined as your local working directory. Click Root to ascend to the very top of your local drive or servers file hierarchy. Click Nuke to access the directory you (or your system administrator) defined as your network working directory. Click the + button to add a directory bookmark. Click the edit button to edit the name or pathname to a bookmark. Click the - button to remove a directory bookmark.

Pathname field
The pathname field displays the current directory path, lets you navigate to a new path, and also enter a filename for scripts and rendered images.

Figure 3.46: Pathname field.

To use the pathname field: 1. To navigate to a directory, type the pathname in the field. 2. To enter a script name, browse to a directory path and enter the file name after the displayed path. To limit the file list to specific file types, use the filter pulldown menu and Sequences checkbox.

To use the filter pulldown menu and Sequences checkbox


Select *.nk to display only Nuke script files. Select * to display all files (except hidden files), regardless of whether theyre associated with Nuke. Select .* * to display all files, including hidden files. Select */ to display directory names, but not their contents. Check Sequences to display image sequences as single titles, as in fgelement.####.cin 1-50 rather than fgelement.0001.cin, fgelement.0002.cin, fgelement. 0003.cin, and so on. You can also split incomplete sequences in to separate Read nodes using the Split Incomplete Sequence checkbox.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Using the File Browser

102

To use the Split Incomplete Sequence checkbox


Locate an incomplete sequence. Check Split Incomplete Sequence and select all the resultant files. Click Open to open the sequence in separate Read nodes. Figure 3.47 shows the same file sequence with Split Incomplete Sequence enabled and disabled.

Figure 3.47: Using Split Incomplete Sequence.

To preview files in the file browser


1. Click the black arrow in the top right corner of the file browser.

Click here

The file browser expands to include a small viewer. 2. Select the file you want to preview. Nuke displays the file in the file browser.

To select multiple files with the file browser


1. Browse to the folder where the files are located.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Undoing and Redoing

103

2. Ctrl+click on all the files you want to open to select them (Mac users Cmd+click). 3. You can open files from multiple directories by clicking Next and browsing to the next file location. Tip

As you browse around, files that you have previously selected will appear highlighted in the color selected in the Preferences > Appearance tab.
4. Click Open. Nuke opens all the files you selected.

To customize file browser colors


1. In the Preferences > Appearance tab, select the required File Browser Colors for the Queued Item Color and Focus Color entries. 2. Either: Click Save Prefs to retain your settings when you relaunch Nuke, or Click Close to use the new settings for this script only.

Undoing and Redoing

Nuke generally gives you an undo history that extends back to the first action of the applications current session.

To undo an action in the workspace


Select Edit > Undo (or press Ctrl/Cmd+Z). Repeat as necessary.

To redo an action in the workspace


Select Edit > Redo (or press Ctrl/Cmd+Y). Repeat as necessary.

To undo an change in a properties panel


Click the Undo arrow button in the properties panel.

To redo an change in a properties panel


Click the Redo arrow button in the properties panel.

To undo all changes made after the properties panel was opened
Click the Revert button. OR Right-click on the properties panel and select Revert knobs from the menu that opens.
The Foundry Nuke 6.3v6

USING THE INTERFACE Progress Bars

104

To set all controls back to their default values


Right-click on the properties panel and select Set knobs to default from the menu that opens.

Progress Bars

Nuke displays a progress bar for each active task it performs. By default, progress bars appear in a pop-up dialog, but you can also display them in the Progress panel. To do so, click on a content menu button and select Progress Bars. This opens a Progress panel. The next time you get a progress bar, it will appear in the panel. If you delete the panel, progress bars will appear in a pop-up dialog again.

Figure 3.48: Progress panel. If you want to have the Progress panel appear in the same position in the future, you can save it as part of a layout. For more information, see Interface Layouts on page 105.

Handling Errors

Sometimes things may not go as you planned and you might face an error message in Nuke. When this happens, an error alert displays in the Viewer and on the node that has a problem in the Node Graph. The error message itself prints in the Error Console tab next to the Properties Bin. If you have an error in a Read or a Write node, or you are missing a plug-in, the error message also displays in a pop-up window. If you see an error alert on your node or in the Viewer, you can click the Error Console tab to open it and view the error message. If you cant see the Error Console, click the content menu button and select Error Console to display it. In the Error Console error list, you can double-click on a message and, if possible, Nuke will take you to the control panel of the node thats in error. This isnt always possible because of the nature of the error. You can also click the clear output button on the Error Console to clear all error messages on the tab.

Note

If you have a node in your Node Graph that is producing an error, but its not connected to the node tree, Nuke wont show a pop-up error message

The Foundry

Nuke 6.3v6

USING THE INTERFACE Customizing the Interface

105

for the node and you can still view the resulting image in the Viewer, if you have one connected. This enables working without having to stop to close error messages in the event that you have erroring nodes in the script that arent connected to your node tree.

Customizing the Interface

You may be used to a certain way of working, or simply disagree with some of Nukes default settings. If this is the case, youll be happy to know that you can customize Nukes interface to find just the layouts and settings that work for you. You can then save your preferred settings, layouts, and template scripts for future use.

Interface Layouts

When your scripts grow, you may not be able to fit all the different elements on your display at the same time. Luckily, you can customize the windows and panes, so that accessing the elements you often need becomes as quick and easy as possible.

Customizing panes
You can resize and split panes to make more room for different elements on the screen.

To resize a pane: Drag the divider line of the pane into a new location.

Figure 3.49: Resizing a pane.

To split a pane: 1. Click on the content menu button in the top left corner of the pane. 2. Select Split Vertical or Split Horizontal from the menu that opens.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Customizing the Interface

106

Moving the Toolbar


You can move the Toolbar into a new position by adding a new panel for it, hiding the panel name and controls, and resizing the panel. For more information on how to do this, see Adding tabbed panels and Hiding tab names and controls below.

Adding tabbed panels


When you cant fit more elements to your display, you can use tabs to save space. You can also use tabs to move the Toolbar into a new location.

To add tabs: 1. Click on the content menu button in the top left corner of the pane. 2. Select the type of tab you want to add, for example, Node Toolbar, Node Graph, New Viewer, or Script Editor. The new tab is added on top of the existing tabs.

To move tabs: Click on the name of the tab and drag the tab to a new position inside the same pane or in another pane.

To close tabs: 1. Make sure you are viewing the tab you want to close. 2. Click the x button in the top right corner of the current tab.

Tabs and floating windows


You can turn tabs and panes into floating windows and vice versa.

To turn a tab or pane into a floating window: 1. Make sure you are viewing the tab or pane you want to float. 2. From the content menu, select Float Tab or Float Pane.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Customizing the Interface

107

Alternatively, in the case of tabs, you can also do one of the following: Click the float button in the top right corner of the current tab,

OR Ctrl+click on the tab name (Mac users Cmd+click), OR Right-click on the tab name and select Float Tab.

To turn a floating window into a tab or pane: Click on the tab name or pane in the floating window and drag it to where you want it to dock.

To close floating windows: Click the x button in the top right corner of the tab or pane.

Customizing windows
To make a pane expand to the size of the window: 1. With your cursor in the pane. 2. Press spacebar quickly. (Pressing and holding the spacebar brings up a context sensitive menu for that pane.)

To make a window fullscreen: 1. Make sure the window you want to make fullscreen is active. This could be the main application window or a floating Viewer. Making it fullscreen removes the window borders. 2. Press Alt+S.

Hiding tab names and controls


You can hide the names and control buttons of tabs, as you may not need them with all panels, such as the Toolbar panel.

The Foundry

Nuke 6.3v6

USING THE INTERFACE Customizing the Interface

108

To hide the names and controls on tabs: From the content menu, disable Show Tabs.

To show the names and controls on tabs: 1. Move your mouse pointer over the very top of the pane area until the top edge of the pane brightens up. 2. Right-click to open the content menu. 3. From the content menu, enable Show Tabs.

Saving layouts
You can save up to six favorite layouts and retrieve them as necessary. You can also use these features to setup the Nuke interface for dual monitors.

To save a layout: 1. Open and arrange the Nuke panes, panels, and tabs as desired. 2. Select Layout > Save layout 1 (startup default) (or press Ctrl/ Cmd+F1) to save the default layout. Select Yes in the confirmation dialog that appears. This step shows F1 as the keystroke, but it can be any key between F1 and F6.

To retrieve a layout: Select Layout > Restore layout 1(startup default) (or press Shift+F1) to retrieve the default layout. F1 is used here, but if you saved a layout to a different function keyany key between F1 and F6then you can press Shift followed by the key to retrieve the layout.

To use window layout 1 as the default when loading scripts: 1. Select Edit > Preferences to open the preferences dialog. 2. Go to the Windows tab. 3. Check use window layout 1 when loading scripts. This is usually checked by default.

The Foundry

Nuke 6.3v6

4 MANAGING SCRIPTS
In this chapter, you learn about Nukes project files called scripts. The topics covered include setting up, saving, and loading scripts. Youll also learn about managing your node tree in the Node Graph, using Precomp nodes, and working with file metadata.

Working with Multiple Image Formats

Nuke supports multiple file formats, such as Cineon, TIFF, OpenEXR, HDRI, and RAW camera data (via the dcraw command-line program), and allows you to mix them all within the same composite. By default, Nuke converts all imported sequences to its native 32-bit linear RGB colorspace. You can, however, use the Colorspace node to force one of several color models, including sRGB, Cineon, rec709, gamma 1.80/2.20, HSV, or HSL. The Log2Lin node lets you convert between logarithmic and linear colorspace (and vice-versa). There are no restrictions on image resolutionyou can freely mix elements of any resolution within the same script. You can, for example, use a 2k film plate as the background for video shot in PAL format, and then output the result in HD1080i. Nuke automatically adjusts its Viewer to accommodate the image youre viewing.

8-, 16-, and 32-Bit Image Processing

Some digital compositing systems, especially those geared for video work, are optimized for processing exclusively 8-bit elements (that is, images with 256 intensity values per channel). Other systems allow for the mixing of 8, 16, and 32-bit elements. For Nuke, which began as a film effects tool, image quality is paramount. Thus, it supports the processing of exclusively 32-bit-per channel elements (Elements with lower bit depths are upconverted to 32 bits per channel upon import.) Thirty-two bit support allows for a much richer palette of colors and floating point precision in all script calculations. In practice, this means that Nuke carries out every operationfrom an increase in gamma to a transformwith much greater accuracy than a lower-bit-depth system. You might expect that this boost in image quality would result in big sacrifice in speed. This is not the case for a couple of reasons. First, Nuke can process scripts with great efficiency because they are uniformly in a 32-bit colorspace. Moreover, hardware manufacturers now routinely design their CPUs for 32-bit processing, making them a efficient match for 32-bitper-channel images.

MANAGING SCRIPTS Setting Up Your Script

110

Setting Up Your Script

When you start working on a script, you should first define the settings for it. This involves assigning the script a name, frame range, frame rate, and default full and proxy resolution format.

Name, Timespan, and Frame Rate

1. Select Edit > Project Settings, or simply press S over a blank portion of the workspace. The Project settings properties panel appears.

2. On the Root tab, type a name for the script (say, firstcomp.nk) in the name field. Nukes scripts always have the extension .nk. 3. Type the numbers of the first and last frames in the frame range fields to define length of time for your shot. 4. In the fps field, enter the rate in frames per second (fps) at which you want your scripts Viewers to play back footage. For film-based elements, 24 fps is appropriate.

Setting the Default Project Directory

In the Project Settings (Edit > Project Settings) you can define your default project directory. You can then refer to it with ./ in your file paths, for example ./test.jpg for an image called "test" in your default project directory. You can also click the Script Directory button to create an expression that will set your project directory to be the directory where your current script is saved.

Full-size Formats

When you start a new project in Nuke, you need to set up a full-size format for the project. The full-size format determines the size of the "black" image that you get from any disconnected node inputs. It also sets the default size
Nuke 6.3v6

The Foundry

MANAGING SCRIPTS Setting Up Your Script

111

of any script-generated elements, such as Constants, Colorbars, Bezier and B-spline shapes. Note

The full-size format does not affect the format of the elements you read into your script. Nuke is resolution-independent, which means it will respect and keep the resolution of your images. It wont automatically crop or pad elements to match the project settings. If you want elements you read in to conform to the project settings, you can do this manually using the Reformat node. For more information, see Reformatting Image Sequences on page 126.
The full-size format is also used to calculate proxy scaling if a proxy format is used. For more information on the proxy mode and proxy formats, see Proxy Mode on page 112.

To set up a full-size format


1. If its not already open, select Edit > Project Settings (or press S) to display the Project settings dialog. 2. From the full size format pulldown menu, select the resolution for the final output of rendered images. If the format you want to use is not in the list, select new. The New format dialog appears.

In the name field, enter a name for the new format. In the file size fields, define the width and height of the format. If you like, you can also define additional information, such as offsets and pixel aspect ratio. Click OK to save the format. It now appears in the pulldown menu where you can select it.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Setting Up Your Script

112

Proxy Mode

When compositing with Nuke, you can work in two different modes: the fullsize mode or proxy mode. In the full-size mode, images are read in exactly as they are on the disk, and all positions are in actual pixels in these images. This is the mode you want to use for accurate feedback and when rendering the final output. In the proxy mode, instead, a proxy scale factor is used. All images and all x/y positions are scaled by this factor. This will produce the same (or at least very similar) composite at a different scale. For example, you can use a fraction of the full output resolution to speed up rendering and display calculation. In addition to the above, a separate proxy file can also be read in place of a full-size image, provided you have specified one in the relevant Read node. This can further speed up the preview, by using a smaller image that reads faster and also saves time by not needing to be scaled. For more information, see Read nodes and proxy files on page 114. The proxy settings you define in the project settings affect both the proxies Nuke generates using the proxy scale factor and proxies read from files. Below, we discuss setting a proxy format and/or a proxy scale, and defining how Read nodes use proxy files. Note

Note that proxy versions of images are only used if you have activated the proxy mode (see Toggling in and out of Proxy mode on page 116). When the proxy mode is off, Nuke will always use the full-res files.

Proxy format and proxy scale


In the Project settings dialog, you have the option of defining a proxy format and/or a proxy scale that you use in the proxy mode. For the proxy format, you can define the image resolution as well as additional information about offsets and pixel aspect ratio. When using the proxy format, the scaling is proportionate to the full-size/proxy format relationship (not scaled to the proxy format). For the proxy scale, you only define a simple scale factor by which your images are scaled down whenever the proxy mode is activated. For example, you can use the scale factor of 0.5 to scale your images down to half the size. If you like, you can define both a proxy format and a proxy scale, and then choose which one to use in proxy mode. A proxy scale is easier to set up, but a proxy format gives you more control over the low-res versions of your

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Setting Up Your Script

113

images. Below, we first describe how to set up proxy formats and then how to define a proxy scale.

To set up proxy formats: 1. If its not already open, select Edit > Project Settings (or press S) to display the Project settings properties panel. 2. If you want to use a proxy format (rather than a proxy scale) whenever the proxy mode is activated, select format from the pulldown menu on the right. 3. From the proxy format menu, select the resolution to use while working to speed things up. Notice that your images are not scaled to this resolution, but the scaling is proportionate to the full-size/proxy format relationship. Nuke divides the proxy format width by the full-size width and uses the result as the scale factor. If the proxy format you want to use is not in the list, select new.The New format dialog appears.

In the name field, enter a name for the new format. In the file size fields, define the width and height of the format. Tip

You can type formulas in numeric fields to do quick calculations. For example, if your full-size format width is 4096 and you want your proxy format width to be 1/2 of that, you can enter 4096/2 in the New format dialogs file size w field and press Enter. Nuke then calculates the new width for you.
Click OK to save the format. It now appears in the pulldown menu where you can select it. 4. To activate the proxy mode and use the low-res format for calculations and display, check proxy mode.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Setting Up Your Script

114

Alternatively, you can use the proxy toggle in the Viewer controls, or press Ctrl+P (Cmd+P on a Mac). For more information, see Toggling in and out of Proxy mode on page 116.

To setup a proxy scale: 1. If its not already open, select Edit > Project Settings (or press S) to display the Project Settings properties panel. 2. Select scale from the pulldown menu in the Project Settings dialog. 3. Using the proxy scale input field or slider, specify the factor by which you want to scale the width and height of your images. For example, if you want to scale them down by 50%, use the value of 0.5. 4. To activate the proxy mode and use the low-res format for calculations and display, check proxy mode.

Alternatively, you can use the proxy toggle in the Viewer controls, or press Ctrl+P (Cmd+P on a Mac). For more information, see Toggling in and out of Proxy mode on page 116.

Read nodes and proxy files


As an alternative to letting Nuke generate proxies on the fly, proxy files can be specified using a second filename in the Read nodes (for how to do this, see Loading Image Sequences on page 122). If you dont have a proxy file, you can create one by activating the proxy mode and rendering your fullsize images using a Write node (see Rendering Output in the Previews and Rendering chapter in the Nuke User Guide). The proxy file does not need to match the proxy resolution in use. Depending on your project settings, either the full-res or proxy file will be scaled to the required proxy size (that is, the size calculated by taking the

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Setting Up Your Script

115

full-size format and scaling it by the current proxy settings). However, if your proxy images match your typical proxy settings, you can save this time.

To define which file (full-res or proxy) is used in the proxy mode: 1. If its not already open, select Edit > Project Settings (or press S) to display the Project Settings properties panel. 2. From read proxy files, select when to use the proxy file (rather than the full-res file) in a Read node: never - Never use the proxy file in the proxy mode. Instead, scale the full-size file as necessary. if larger - Use the smaller of the two images if it is larger or equal to the desired size, scaling down as needed. Otherwise, use the larger one, scaling down or up as needed. This is the default option. if nearest - Use the image that is closest to the desired size, scaling up or down as needed. always - Always use the proxy image in the proxy mode, scaling it up or down as necessary. The option you choose affects all Read nodes in your script, provided that a proxy file is named and the proxy mode is on.

Write nodes and proxy files


It is worth mentioning here that when a script is rendered in proxy mode, processing will be done at the proxy scale and image output will go to the file name in the Write nodes proxy field. If you do not specify a proxy file name, the render will fail with an error. It never resizes the proxy image, and it will not write the proxy image over the full-size one. For more information, see Rendering Output in the Previews and Rendering chapter in the Nuke User Guide.

Using Proxy mode to enlarge a script


If you find it necessary to render a comp at higher than the original resolution it was intended for, you can also use the proxy resolution to scale up from the root full size format. For example, you could use a 2K composite to produce 4K or higher images in the proxy mode. The reason you'd probably want to do this is because the comp you did needs to be re-run at higher resolution for a different output target and possibly with some new higher resolution elements. For example, you may need to re-render with new CG elements at print resolution rather than for
The Foundry Nuke 6.3v6

MANAGING SCRIPTS Setting Up Your Script

116

film out, but you dont want to go through your script and modify everything that has an x/y position. When scaling up the output of a script in the proxy mode, image generator nodes will render at the larger size, larger images can be specified in the proxy field, and as with scaling down, all x/y positions will be scaled to the proxy output resolution.

Using small proxy files If you have previously set up your script to use small proxy files, you do not have to remove these. Make sure read proxy files in Project Settings is set to anything other than always, and Nuke will read the larger original files and scale them up.

Using large proxy files If you actually have larger proxy files, you should enter them into the Read nodes proxy field, and set read proxy files to anything other than never. Nuke will then use these larger files in the proxy mode. For maximum quality, these should be at exactly the desired proxy size so that no scaling is done to them. For example, if the required proxy size (defined by the project settings) is 4K, then the proxy image should be exactly 4K. Otherwise, Nuke will scale it to match the project settings, which will reduce the quality.

Rendering the scaled-up output To render the larger output of a scaled-up script, you need to activate the proxy mode and enter a file name in the proxy field of the Write nodes. The larger images will then be written to these files.

Toggling in and out of Proxy mode


Its usually smart to work in proxy mode because most operations work quickly and more efficiently under the low-res display. You can switch between low- and high-resolution when you need greater precision (for example, when pulling a key or tracking), or when youre ready for final rendering.

To toggle between full resolution and Proxy mode: 1. Click on an empty area of the Nuke window. 2. Press Ctrl+P to toggle the display mode (Cmd+P on a Mac).
The Foundry Nuke 6.3v6

MANAGING SCRIPTS Image Caching

117

Nuke automatically scales script elementsBezier shapes, B-spline shapes, paint curves, garbage masks, tracking curves, and so onto keep the original placement on the image.

Image Caching

To ensure fast playback, the Nuke Viewer saves a version of every frame it displays to disk. When you play through sequences in the Viewer, it reads, where possible, from this cache of prerendered images. This way, Nuke can quickly display the results without recalculating the parts of the script that have not changed. Provided the caching preferences (see Defining the Settings for Caching on page 117) have been set, Nuke automatically caches any output displayed in a Viewer. However, you can also use the DiskCache node (see Using the DiskCache Node on page 118) to cache other parts of the node tree.

The Cache Directory

Both the automatic caching and the DiskCache node use the same cache directory defined using the Preferences dialog. In the Preferences, you can also set the maximum size you allow the disk cache to consume. For more information on the caching preferences, see Defining the Settings for Caching below. Note that the cached images have unique names reflecting their point of output location in the script. This means that you can cache images from multiple nodes in the script without overwriting previously cached images.

Defining the Settings for Caching

You can define the settings for both the automatic caching and the DiskCache node in the Preferences.

To define the settings for caching


1. Select Edit > Preferences (or press Shift+S). The Preferences dialog opens. 2. Under disk cache, specify where you want Nuke to cache out data to disk. Pick a local disk (for example, c:/temp), preferably with the fastest access time available. The environment variable NUKE_DISK_CACHE can be used to override this setting. For more information, see Environment Variables in the Configuring Nuke chapter in the Nuke User Guide. 3. Using the disk cache size control, pick the maximum size the disk cache can reach. Ensure there is enough space on the disk for this to be

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Image Caching

118

reached. The default value is 10GB, but a larger value, such as 50GB, can often be used. The environment variable NUKE_DISK_CACHE_GB can be used to override this setting. For more information, see Environment Variables in the Configuring Nuke chapter in the Nuke User Guide. 4. Click the Save Prefs button to update preferences and then restart Nuke. Once these settings are defined, the automatic caching of images is enabled. The Viewer will cache each frame it displays in the directory specified. If you add a DiskCache node into your script, it will also use the same directory. The disk cache is preserved when you quit Nuke so it can be used again later. However, when the cache becomes full, old items are automatically deleted to make room for newer items.

Clearing the Disk Cache

When the disk cache becomes full, old items are automatically deleted. If necessary, you can also empty the disk cache manually. You may want to do this if, for some reason, wrong images are displayed in the Viewer.

To empty the disk cache


From the menu bar, select Cache > Clear Disk Cache.

Using the DiskCache Node

The DiskCache node caches to disk scanlines from its input as they are requested by its output. This can be useful, for example, if: you are working on a large, complex node tree. Using the DiskCache node, you can break the node tree into smaller sections and cache any branches that you are no longer working on. you are reading in images from a network. If you insert a DiskCache node after a Read node, the image will be cached locally and displayed faster. you are painting or rotoscoping. If you insert a DiskCache node before a RotoPaint node, flipping frames becomes faster. The cached images are saved in the same directory as the images the Nuke Viewer caches automatically. You can set the location and size of this directory in the Preferences. For more information, see Defining the Settings for Caching on page 117.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Image Caching

119

Note

Even though the DiskCache node and the automatic Viewer caching use the same cache directory, they do not share the same cache files. Therefore, using a DiskCache node does not create cache files for the Viewer and does not necessarily speed up playback. Instead, if placed at strategic, expensive parts of a node tree, it can speed up calculations, as Nuke can reference the cached data rather than recalculate it. Unlike the images in the Viewer cache, the images created by the DiskCache node affect your rendered output and are always saved as full floating point images.
If you make a change in the nodes upstream, the affected cached images are discarded and automatically recalculated.

Note

When executing a script on the command line, the DiskCache nodes are NOT automatically executed.

To cache images upstream


1. Set the zoom level in the Viewer. By default, only the lines displayed in the Viewer will be cached. 2. Select Other > DiskCache to insert a DiskCache node after the last node in the section of the node tree that you want to cache. 3. From the channels menu, select which channels to cache. Nuke caches the selected channels of the current frame at the current zoom level. From this point on, Nuke references the cached data instead of constantly recalculating the output of the preceding nodes. As you pan and zoom around, new parts of the image are cached. 4. If you want to cache more than the current frame and zoom level, click the Precache button in the DiskCache properties and enter a frame range in the dialog that opens. This forces Nuke to cache all frames specified. All lines will be cached regardless of what is shown in the Viewer. Where the required images are partly cached already, Nuke only calculates what is missing.

Caching Files Locally for Better Performance

You may find that sometimes loading files from a remote server slows down your processing. In such a case you can tell Nuke to bring down the files youre frequently working with and store them on a local drive for speedier processing. 1. You can set the location for your cached files, and specify any files you want automatically cached, using the Local File Cache controls in the Preferences:

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Saving Scripts and Recovering Backups

120

local file cache path - enter the location for storing your cached files. local file auto-cache path - enter the location of the files you need automatically localized, unless otherwise specified. Commonly this would be your remote working folder. If you leave this field blank, automatic local file caching wont take place. 2. For every node with a file control you also have a cache locally dropdown that you can use to set a caching rule for that file. Choose: always - to always cache this file, even if other files arent cached. auto - to cache this file along with other files youre caching (default). never - to never cache this file. 3. Click the Cache menu next to the Help menu. 4. Click Local File Cache > Update All to update caching on all files that are set to be cached. Choose Update Selected to update caching on files youve selected in the Node Graph.

Saving Scripts and Recovering Backups


Saving Scripts

You know the mantra: save and save often. Nuke provides three ways to save your scripts, plus an automatic timed backup.

There are three ways of saving scripts: To save a new script, select File > Save as (or press Shift+Ctrl/Cmd+S). To update changes to a script already saved, File > Save (or press Ctrl/ Cmd+S). To save and upgrade to the next version, File > Save new version (or press Alt+Shift+S).

To save a script
1. Select File > Save as. The Save script as dialog opens. 2. Browse to the directory where you want to store the script. For instructions on using the file browser, see Using the File Browser on page 99. 3. In the field in the bottom of the dialog, enter a name for the script after the folder path, for example firstscript_v01.nk. 4. Click Save.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Saving Scripts and Recovering Backups

121

Tip

The _v01 string in the end of a script name allows you to use the Save new version feature. Selecting File > Save new version saves the current version of your script and increments its name (that is, saves the different versions under different names using _v01, _v02, _v03, and so on, in the end of file names). This only works when the file name includes a number that can be incremented.

Automatic Backup of Scripts

You can define where and how often Nuke makes automatic backups your files, or turn off the autosave function.

To define autosave options for a script


1. Select Edit > Preferences. The Preferences dialog opens. 2. Edit the following settings: autosave filename to define where and under what name Nuke saves your automatic backup files. By default, the files are saved in the same folder as your project files with the extension .autosave. To change this, enter a full directory pathname in the autosave filename field. autosave after idle for to define how long (in seconds) Nuke waits before performing an automatic backup after you have left the system idle. force autosave after to define how long (in seconds) Nuke waits before performing an automatic backup regardless of whether the system is idle. 3. Click Save. Note

If you close the Preferences dialog without clicking Save Prefs, your changes will only affect the current session of Nuke. For the automatic backup to work, you must save your script first so that the autosave can reference the file. Wed hate for you to lose your work, so please do this early on in the process!

Note

To turn off automatic backup


1. Select Edit > Preferences. The Preferences dialog opens. 2. Set the autosave after idle for and force autosave after fields to 0. From now on, Nuke will not perform any automatic backups, and you are more likely to lose your work in the case of a system or power failure.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Loading Image Sequences

122

Recovering Backups

After experiencing a system or power failure, you are likely to want to recover the backup files created by Nukes autosave function.

To recover backups
1. Relaunch Nuke. A dialog opens that asks you if you want to recover the autosave file. 2. Click OK. Nuke opens the backup file for your use. There may be times when you dont want to load the autosave file and rather need to load the last saved version. For example, consider a situation where you modified a script, but decided not to commit the changes and so exited Nuke without saving. In all likelihood Nuke autosaved some or all of your changes, in which case if you open the autosaved file you will not be working on the original script, as intended. If you accidentally open an autosaved script, then simply close it and reload the last saved version.

Loading Image Sequences

When you are ready to start compositing, you may want to begin by importing a background or foreground image sequence. Typically, you would read in both full- and proxy-resolution versions of the sequence. You can read in several image sequences in one go.

To import an image sequence


1. Select Image > Read (or press R over the Nuke window). A Read node is inserted in the Node Graph.

2. Browse to the image sequence you want to import. For instructions on using the file browser, see Using the File Browser on page 99. Select the file you want to open. If you want to open several files at the same time, Ctrl+click (Mac users Cmd+click) on the files. Click Open.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Loading Image Sequences

123

Nuke imports the image sequence and displays it as a thumbnail on the Read node. Generally, the Read node does not reformat or resize the sequence in any way, and the nodes properties panel is updated to display the native resolution and the frame range for the sequence. Note that the format and proxy format fields in the controls indicate the format of the images, they do not cause the images read from files to be resized to this format. 3. If your sequence has a red, green and blue channel but no alpha channel, check the auto alpha box in the Read node control panel to set the alpha channel to 1. This prevents possible problems from occurring if Nuke tries to read the alpha channel and one doesnt exist. The auto alpha box is unchecked by default. Note

Nuke reads images from their native format, but the Read node outputs the result using a linear colorspace. If necessary, you can change the Colorspace option in the Read nodes properties panel, or insert a Color > Colorspace node to select the color scheme you want to output or calculate. The maximum image size the Nuke Viewer can display is 2^28 = 268,435,456 pixels. This is the same as 16k x 16k, 32k x 8k, 64k x 4k, or 128k x 2k. If your image is larger than this, it will be resized and you will get the following warning: "Viewer image is clipped to <size> x <size>!" For example, if your image resolution is 60,000 x 4473, Nuke is able to display the image because the number of pixels is less than 2^28. However, if the resolution is 60,000 x 4474 (more than 2^28 pixels), the image will be resized to 59998 x 4474. In addition to the Viewer, this limit is also applied to the bounding box of the images being passed between each node.
4. If you have a proxy version of the image sequence, click the proxy fields folder icon and navigate to the proxy version. Select Open. If you dont have a proxy version, dont worry: Nuke will create one on the fly according to the proxy scale or proxy format settings you specified in the project settings. The proxy file does not need to match the proxy resolution in use. Depending on your settings, either the full-res or proxy file will be scaled to the required proxy size. For more information, see Read nodes and proxy files on page 114.

Note

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Loading Image Sequences

124

Note

QuickTime .mov files may appear different in Nuke relative to Apples Final Cut Pro, because Final Cut Pro introduces a gamma compensation based on assumptions about the content of the files and the viewing environment. QuickTime is only supported by default on Windows and Mac OS X. To load QuickTime files on Linux, you need to use the prefix ffmpeg: before the file path and file name, for example, ffmpeg:/users/john/job/FILM/MG/ final_comp_v01.####.mov. This way, Nuke will use its reader that is based on the FFmpeg open source library to decode QuickTime files. Note that we are using this open source library to encode the output images, so image data may be subject to colorspace and transform shifts dependant on the codec employed.

Note

Note

AVI files can be supported by default or only via Nukes reader that is based on the FFmpeg open source library. If you get an error when using AVI files in Read nodes, you may need to use the prefix ffmpeg: before the file path and file name, for example, ffmpeg:\z:\job\FILM\IMG\final_comp_v01.####.avi. The EXR file format allows the display window to have the lower left corner in any position. Unfortunately, Nuke needs all formats to have a lower left corner coordinate of 0,0. In the Read node control panel, under exr Options, you can check the offset negative display window box to tell Nuke to offset the image so that the display window left side x coordinate is 0. If you uncheck the box, Nuke will shrink the format from both sides the amount that its negative in the x coordinate, in other words treat the area as overscan. On Linux, the Nuke EXR reader uses a memory-mapping function to improve performance reading PIZ-compressed EXR files. However, some customers have experienced hanging when reading large (frame size and number of channels) PIZ-compressed EXR files across an NFS network. If you experience this problem, you can tell Nuke not to use the mmap function by enabling this option. You can set it on a case by case basis or use a knobDefault in your init.py to always have it disabled. For more information on knobDefault, see the Nuke Python documentation (Help > Documentation).

Note

Note

Loading Images from an External File Browser

To load an image, you can also drag and drop the image into the Node Graph from an external file browser (such as Windows Explorer or Mac OS X Finder). To load an entire image sequence this way, drag and drop the directory that contains the images into the Node Graph.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Loading Image Sequences

125

Naming Conventions

The file names of image sequences generally end in a number before the extension, for example image0001.rgb, image0002.rgb, image0003.rgb, and so on. When browsing for files like this, you may notice that the sequence appears as image####.rgb. Here, #### is Nukes way of indicating that the number is in a 4-digit incremental format. For a 3-digit format, such as image001.rgb, the frame number variable would be ###. Nukes File Browser also understands unpadded file names, such as image1.rgb, image2.rgb, image3.rgb, and so on. They appear as image#.rgb.

Changing the Relation Between the Current Frame and the Frame Read In

By default, Nuke assumes an exact relation between the current frame processed, and the frame read in. For example, at frame 15, Nuke reads in image.0015.rgb. However, you can change this behavior using the frame parameter on the Read node. For instance, if you have a sequence that runs from image.0500.rgb to image.1000.rgb, you may want to read in image.0500.rgb at frame 1. Nuke lets you do this via expressions, specified start frames, and constant offsets. Each method is described below.

Using expressions
1. Select Image > Read to import an image sequence. 2. In the Read node controls, set the frame pulldown menu to expression. Enter an expression in the field on the right. The expression changes the relation between the current frame and the frame read in.

For example, if your clip begins from image.0500.rgb and you want to place this first frame at frame 1 rather than frame 500, you can use the expression frame+499. This way, 499 frames are added to the current frame to get the number of the frame thats read in. At frame 1,
The Foundry Nuke 6.3v6

MANAGING SCRIPTS Reformatting Image Sequences

126

image.0500.rgb is read in; at frame 2, image.0501.rgb is read in; and so on. Another example of an expression is frame*2. This expression multiplies the current frame by two to get the number of the frame thats read in. This way, only every other frame in the clip is used. At frame 1, image.0002.rgb is read in; at frame 2, image.0004.rgb is read in; at frame 3, image.0006.rgb is read in; and so on.

Specifying a start frame for a clip


1. Select Image > Read to import an image sequence. 2. In the Read node controls, set the frame pulldown menu to start at. Enter a start frame number in the field on the right. This specifies the frame where the first frame in the sequence is read in. In other words, all frames are offset so that the clip starts at the specified frame. For example, if your sequence begins from image.0500.rgb and you enter 1 in the field, image0500.rgb is read in at frame 1. Similarly, if you enter 100 in the field, image0500.rgb is read in at frame 100.

Offsetting all frames by a constant value


1. Select Image > Read to import an image sequence. 2. In the Read node controls, set the frame pulldown menu to offset. Enter a constant offset in the field on the right. This constant value is added to the current frame to get the number of the frame thats read in. For example, if your clip begins from image.0500.rgb and you want to place this first frame at frame 1 rather than frame 500, you can use 499 as the constant offset. This way, 499 is added to the current frame to get the frame thats read in. At frame 1, image.0500.rgb is read in; at frame 2, image.0501 is read in, and so on. You can also use negative values as the constant offset. For example, if you use the value -10, Nuke will subtract ten from the current frame to get the frame thats read in. At frame 20, image.0010.rgb is read in; at frame 21, image.0011.rgb is read in; and so on.

Reformatting Image Sequences

When you import image sequences, Nuke stores their format settings and makes them available to the Reformat node. You can then use the Reformat node to resize and reposition your image sequences to a different format. Reformat nodes also allow you to use plates of varying image resolution on a single script without running into issues when combining them.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Loading Nuke Scripts

127

To insert a Reformat node: 1. Make sure the Read node you added is currently selected. 2. Select Transform > Reformat. The Reformat node is inserted in the script, and its properties panel opens.

3. From the output format pulldown menu, select the format to which you want to output the sequence. If the format does not yet exist, you can select new to create a new format from scratch. The default setting, [root.format], resizes the image to the format indicated on the Project Settings dialog box. 4. You can now use the same Reformat node for any other Read nodes in the script. Simply select the Reformat node and Edit > Copy. Select another Read node in the script and Edit > Paste.

Loading Nuke Scripts

When you have built a script and saved it and want to come back to it later, you need to load in an entire script file. You recognize Nukes script files from the extension .nk (for example firstscript.nk).

To load a script
1. Select File > Open (or press Ctrl/Cmd+O). The Script to open dialog appears. 2. Browse to the script you want to open. For instructions on using the file browser, see Using the File Browser on page 99. 3. Click Open.

Closing Nuke Scripts

To close a script
1. Select File > Close (or press Ctrl/Cmd+W). 2. If you have made any unsaved changes to the script, Nuke prompts you to select whether to save them. Click Yes to save your changes or No to ignore them.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Defining Frame Ranges

128

Nuke is quit and relaunched, as though you ran it again. It does everything it does at start-up, apart from displaying the splash screen. Therefore, you can use Ctrl/Cmd+W as a quick way to clear memory, reread plug-in paths, and reload the init.py and menu.py files. (The init.py and menu.py files are files that Nuke runs at start-up and can be used for configuring Nuke. You may want to reload these files if you have made any changes to them.)

Defining Frame Ranges

Several dialogs in Nuke, such as the Frames to render and Frames to flipbook dialogs, prompt you for a frame range. To define one, you need to enter a starting frame and an ending frame, separated by a dash. For example, to restrict an action to frames 1, 2, 3, 4, and 5, you would use 15 as the frame range. The following table gives you more examples of frame ranges you can define.
Frame Range 3 -3 1348 1-10 -3-4 -8--5 1-102 (frame range from 1 to 10 in steps of 2) 1-103 (frame range from 1 to 10 in steps of 3) 1-41 8-101 12-141 (multiple ranges separated by spaces) 1, 2, 3, 4, 8, 9, 10, 12, 13, 14 1, 4, 7, 10 Expands To 3 -3 1, 3, 4, 8 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 -3, -2, -1, 0, 1, 2, 3, 4 -8, -7, -6, -5 1, 3, 5, 7, 9

You can use the above ways of defining a frame range everywhere in Nuke. In addition to dialogs, they can be used on the command line (where any frame ranges should be preceded by the -F switch) and in Python statements. For more information, see Command Line Operations in the Configuring Nuke chapter in the Nuke User Guide and the Nuke Python documentation (Help > Documentation).

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS File Name Search and Replace

129

File Name Search and Replace

With the Search and Replace function, you can quickly replace all or part of file names or file paths in any node with file or proxy controls (for example in Read and Write nodes).

To search for a file name or file path and replace it


1. Select the node(s) where you want to replace all or part of a file name or file path. 2. Select Edit > Node > Filename > Search and Replace. OR Press Ctrl+Shift+/ (Mac users press Cmd+Shift+/). 3. In the dialog that opens, enter the string you want to search for and the string you want to replace it with. Click OK. Nuke searches for the string in the selected nodes and replaces it with the new string. Note

You can also enter expressions into the Search and Replace dialog. Just remember that the search field in the dialog only takes regular expressions. Any characters that have specific meanings in regular expressions, such as [ and ], need to be preceded by the \ character. For example, [getenv HOME] would need to be entered as \[getenv HOME\]. You can also pass flags alongside the expression itself to control how the expression behaves. For example, to perform case-insensitive searches, you can enter (?i) in the beginning of the expression or after one or more whitespace characters.

Displaying Script Information

To display script information, such as the node count, channel count, cache usage, and whether the script is in full-resolution or proxy mode, do the following: 1. Select File > Script Info (or press Alt+I). The script information window opens.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Grouping Nodes in the Node Graph

130

2. If you make changes to your script while the window is open, click update to update the information. 3. To close the information window, click close.

Grouping Nodes in the Node Graph

You can group nodes in the Node Graph using the Backdrop node or the Group node. The Backdrop node adds a background box behind the nodes, separating the nodes visually from the rest of the node tree. A Group node, instead, combines a set of nodes into a single node, acting as a nesting container for those nodes.

Grouping Nodes with the Backdrop Node

You can use the Backdrop node to visually group nodes in the Node Graph. Inserting a Backdrop node creates a box behind the nodes. When you move the box, all the nodes that overlap the box are moved, too. By inserting several backdrop nodes, you can group the nodes in your node tree onto boxes of different colors and titles. This makes it easier to find a particular node in a large node tree, for example.

Figure 4.1: Nodes grouped in the Node Graph with Backdrop nodes.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Grouping Nodes in the Node Graph

131

To group nodes with a Backdrop node


1. Select Other > Backdrop. A Backdrop node box appears in the Node Graph.

2. Drag the triangle in the lower right corner of the box to resize the box as necessary. 3. Click on the box title bar and drag it to move the box behind the nodes you want to group together. If there are any nodes on the box, they move together with the box.

Drag here to move the box and the nodes inside it.

Drag here to resize the box.

4. To change the color of the box, open the Backdrop nodes controls by double-clicking on the title bar, then click the left color button and pick a new color with the color picker that appears.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Grouping Nodes in the Node Graph

132

5. To change the title of the box, enter a new name for the Backdrop node in the nodes controls.

6. If you later want to remove both the box and the nodes inside it, click on the title bar and press Delete. Ctrl/Cmd+clicking on the title bar and pressing Delete only removes the box and leaves the nodes untouched. To remove the nodes and leave the box untouched, click on the triangle in the lower right corner of the box and press Delete.

Grouping Nodes with the Group Node

You can use the Group node to nest multiple nodes inside a single node.

To group nodes with a Group node


1. Select all the nodes you want to nest inside the Group node. 2. If you want to replace the original nodes with the Group node, select Edit > Node > Group > Collapse To Group (or press Ctrl/Cmd+G on the Node Graph). If you want to keep the original nodes in the layout in addition to the Group node, select Edit > Node > Group > Copy Nodes To Group (or press Ctrl/Cmd+Alt+Shift+G on the Node Graph).

Edit > Node > Group > Collapse To Group

Edit > Node > Group > Copy Nodes To Group

Ctrl/Cmd+G

Ctrl/Cmd+ Alt+Shift+G

The selected nodes are nested into a group. The internal structure of the Group node is shown on a separate tab that opens. Tip

As an alternative to Edit > Node > Group > Collapse to Group, you can also select Other > Group from the Toolbar or the Node Graph right-click menu.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Adding Notes to the Node Graph

133

To view the nodes nested inside a Group node


In the Group nodes controls, click the S button (short for Show) in the top right corner.

A new tab that contains the nested nodes opens.

To ungroup nodes
1. Select the Group node in the Node Graph. 2. Select Edit > Node > Group > Expand Group (or press Ctrl/ Cmd+Alt+G). The Group node is replaced with the nodes that were nested inside it. OR 1. In the Group nodes controls, click the S button in the top right corner.

A new tab that contains the nested nodes opens. 2. Copy the nodes from the new tab into your script. If you want to lock the connections between the grouped nodes so that they cannot be accidentally disconnected during the copy-paste operation, check lock all connections in the Group nodes controls. 3. Delete the unnecessary Group node from your script.

Adding Notes to the Node Graph

Using the StickyNote node, you can add notes to the Node Graph. The notes can be any text or HTML mark-up. Usually, they are made as annotations to the elements in the node tree.

To add a note to the Node Graph


1. Click on the part of the Node Graph where you want to add a note. 2. Select Other > StickyNote. A note box appears in the Node Graph.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Using the Precomp Node

134

3. In the StickyNote controls, enter your note in the label field. If you like, you can use HTML mark-up. For example, to have a note appear in bold, you can use <b>my note</b>. This would appear as my note. to have a note appear in italics, you can use <i>my note</i>. This would appear as my note. to add an icon to your note, you can use <img src="Colorwheel.png"/>. This adds the Nuke color wheel icon. You can also use your own icons in the same way as long as you save them in your plug-in path directory. Most common image formats will work, but we recommend using PNG files.

Using the Precomp Node

The Precomp node is like a Group node, but its content is stored in an independent .nk file. This allows you to save a subset of the node tree as a separate .nk script, render the output of this saved script, and read the rendered output back into the main comp as a single image input. Precomp nodes can be useful in at least two ways. Firstly, they can be used to reduce portions of the node tree to pre-rendered image inputs. This speeds up render time, as Nuke only has to process the single image input instead of all the nodes that were used to create it. Because the original nodes are saved in a separate .nk script, you also maintain access to them and can adjust them later if necessary. Secondly, Precomp nodes enable a collaborative workflow. While one artist works on the main comp, others can work on the sections that have been exported using the Precomp node. These sections can be edited, versioned, and managed independent of the main comp. For example, say you have a comp that involves a complex, multi-layered CG render. A 3D artist can produce this as a separate script that the compositor finishing the shot

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Using the Precomp Node

135

then reads in using a Precomp node. This way, the 3D artist can modify and re-render the CG element portion of the comp without having to share the main comp with the compositor.

Creating Precomp Nodes

Whether you want to use the Precomp node to speed up rendering or to enable a collaborative workflow, the process of creating the Precomp is the same.

To create a Precomp node


1. Select the nodes you want to include in the separate precomp script. If you select a Group node, the nodes nested inside it will be copied into the precomp script. 2. Select Other > Precomp (or press Ctrl/Cmd+Shift+P on the Node Graph). The Precomp Nodes dialog opens.

Note

If you don't select any nodes when you create a Precomp node, the Precomp Nodes dialog is not displayed and the node is left blank. Using the file parameter in the Precomp controls, you can then browse to an existing script to load into the Precomp node. If you have several Write nodes in the existing script and want to control which of them is used for the output of the Precomp node, you can select Other > Output to insert an Output node after the Write node you want to use. If the Precomp node cannot find an Output node in the script, it looks for a Write node and sets Output node in the Precomp controls to the name of that node. The Output node field can also be used later to override what is set as the Output node in the precomped script. To do so, make sure you check enable. This check box allows you to toggle between the output node chosen by default and the output node you specified in the Output node field.
3. Click the file browser icon next to Precomp script path, and browse to the directory where you want to save the precomp .nk

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Using the Precomp Node

136

script. After the directory path, enter a name for the precomp script, for example Precomp1_v01.nk. By default, the precomp script is saved next to the main script. If the main script has not been saved, the precomp script is saved in the current directory. 4. Click the file browser icon next to Precomp render path, and browse to the directory where you want to save the rendered output of the precomped nodes. After the directory path, enter a name for the rendered image, for example Precomp1_####.exr. If you like, you can also use version numbers in the name, for example Precomp1_v01_####.exr. Important

We recommend rendering the image as an exr because that way Nuke will write the hash value of the incoming node tree into the rendered file. If the precomp script changes so that the hashes wont match, Nuke will then notify you, and you can update the resulting image. If you use a file format other than exr, you will not get this notification and the rendered file is likely to become out of date. The hash value is a unique number (for example, b1c9c0aff2012a8) calculated from a node and the entire tree of nodes connected to its input. The class of the node and all the current control settings contribute to the hash value. You can display the hash value at any point in the node tree by selecting a node in the Node Graph and pressing I. The hash will be different at different points in the tree.
5. From the Channels pulldown menu, select the channels you want to include in the rendered output of the precomped nodes. If you later need to adjust this selection, you can do so by setting the channels on the appropriate Write node (by default, Write1) in the precomp .nk script. 6. From the Original nodes pulldown menu, select: add backdrop to create a backdrop behind the precomped nodes in the Node Graph. delete to delete the precomped nodes. no change to do nothing to the precomped nodes. 7. Click OK. Nuke saves the selected nodes in the .nk script specified. This script will also include input and output nodes, a Write node, and the current project settings. In the Node Graph, the selected nodes are replaced with the Precomp node. Nuke opens the properties of the Precomp node.

Wh at is the ha sh v al ue ?

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Using the Precomp Node

137

Precomp nodes and Project Settings


When you create a Precomp node, the precomp .nk script gets its project settings from the main script. The main scripts project settings are also used whenever the precomp script is loaded into the main script. Therefore, if you open the precomp script in a separate instance of Nuke and change its project settings so that they no longer match the main scripts settings, your changes do NOT have an effect when the precomp script is loaded into the main script. If you want to change the project settings, you should always do so in the main script rather than the precomp script.

Using a Precomp Node to Speed-up Rendering

If you want to use a Precomp node to speed up rendering, you need to have the Precomp node read in the output of the precomp script.

To render a Precomp node


1. Create a Precomp node. For more information on how to do this, see Creating Precomp Nodes on page 135. 2. In the Precomp node controls, click Render. Enter a frame range (for example, 1-100) in the dialog that opens and click OK. Nuke renders the output of the precomp script and saves the resulting image in the Precomp render path directory you specified when you created the Precomp node. If you have activated the proxy mode and have specified a proxy filename in the output node, the rendered image is a proxy image. 3. If the render finishes successfully, read file for output is automatically turned on in the Precomp properties. When this is checked, the Precomp node turns green and reads in the rendered precomp image rather than calculates the output of the precomp script. The word (Read) and the name of the image read in are also displayed on the Precomp node in the Node Graph to indicate this. 4. In case there is an error opening the rendered output of the precomped nodes, select what to do from the missing frames menu in the Precomp properties: error - display an error message on any missing frames. black - replace any missing frames with black. checkerboard - replace any missing frames with a checkerboard image. read input - display the result of the input tree rather than the rendered file on any missing frames. When several Precomp nodes are used like this to replace sections in a

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Using the Precomp Node

138

large, complex node tree, the render times may become significantly faster. Note

When rendering the output of the precomp script, Nuke automatically selects the Write node to use by first looking for an Output node. If it can't find any Output nodes, it tries to find a Write node, and sets Output node in the Precomp node controls to the name of the Write node. If it can't find any Output or Write nodes, it produces an error. At any point, the Precomp node properties can be used to override what is set as the Output node in the precomped script. To do so, open the Precomp properties and the advanced controls. In the Output node field, enter the name of the Write node whose output youd like to use. Make sure you also check enable. This check box allows you to toggle between the output node chosen by default and the output node you specified in the Output node field.

Tip

You can also use Write nodes in a similar manner and have their output read in from the rendered file rather than calculated using the nodes upstream. For more information, see Using a Write Node to Read in the Rendered Image in the Previews and Rendering chapter in the Nuke User Guide.

Precomp Revisions

The following describes how to open, edit, and reload a precomp script.

To view and edit a precomp script


1. In the Precomp node properties, click Open. This starts a new Nuke session and loads the precomp script. 2. Edit the precomp script as necessary. 3. If you are using version numbers in the Write node file name, select the Write node in the Node Graph and choose Edit > Node > Filename > Version Up from the menu bar. This changes the version number in the file thats rendered, for example, from Precomp1_v01_####.exr to Precomp1_v02_####.exr. 4. Render the Write node. Note that if the proxy mode is on and you have entered a proxy file name for the output node, Nuke will render a proxy image. 5. Select File > Save New Version (or File > Save As) to save the script with a new version number, for example, Precomp1_v02.nk instead of Precomp1_v01.nk.

To reload a revised precomp script


1. Load the main comp.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Using the Precomp Node

139

2. Make sure the filename in the Precomp nodes file field matches the current name of the precomp script. If the precomp script name has been versioned up, you can simply select the Precomp node and choose Edit > Node > Filename > Version Up from the menu bar. This changes the name of the script that is read in, for example, from Precomp1_v01.nk to Precomp1_v02.nk. If the precomp script has been saved with a different name or you want to use a different script as the precomp script, edit the filename in the file field. 3. In the Precomp properties, click Reload.

Collaborative Workflow Example

In this example, a compositor is responsible for the main comp that will be delivered to the client. A lightingTD is responsible for providing a multilayered CG render for use in the main comp. The following describes how the compositor and lightingTD could use the Precomp node to enable a collaborative workflow.

To enable a collaborative workflow


1. The compositor starts building the main comp. 2. The lightingTD does a render of the CG element and a comp of the layers, saving the script as cg_v01.nk. Important

Note that we recommend rendering precomp images as exrs. This way, Nuke will write the hash value of the incoming node tree into the rendered file. If the precomp script changes so that the hashes wont match, Nuke will notify the user who can then update the resulting image. If you use a file format other than exr, the user will not get this notification and the rendered file is likely to become out of date. For more information on hash values, see What is the hash value? on page 136.
3. The compositor creates a Precomp node reading from the file cg_v01.nk, and continues working on the main comp. 4. The lightingTD continues to revise the CG render and the comp, versioning up the Write node and the precomp script .nk name. (See To view and edit a precomp script on page 138.) When better results are achieved, the lightingTD notifies the compositor of the new and improved version of the precomp script. 5. The compositor versions up the Precomp node to the new, improved version and reloads the precomp script. (See To reload a revised precomp script on page 138.)

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Working with File Metadata

140

Working with File Metadata

The nodes in the Metadata menu of the Toolbar let you work with information embedded in your images. This section gives instructions on their usage, teaching you to view, compare, edit, and render metadata.

Metadata in Nuke

Metadata is a set of information about an image embedded in the image file. This information may include the images original bit depth, width, and height, for example. It can be attached to the file by the camera used to shoot the images, and/or edited later. When Nuke loads an image, it reads in the metadata embedded in the image. The metadata is then passed down the node tree so you can view and use it at any point in your script. For example, you can reference metadata via expressions. You can also edit or delete existing metadata, add new metadata to a file, and write the resulting metadata out to files. Note Note

Metadata for QuickTime files does not show gamma or bit depth. When using a Merge node, you can choose which inputs metadata to pass down the tree. In the Merge controls, set metadata from to either A or B.
In the MetaData menu of the Toolbar, Nuke features five nodes that help you work with file metadata: ViewMetaData lets you inspect the metadata passed down by the input node. See Viewing Metadata on page 140. CompareMetaData lets you compare the metadata between two inputs and view the differences. See Comparing Metadata Between Inputs on page 141. ModifyMetaData lets you edit existing metadata in the input stream, add metadata into the stream, and delete metadata from the stream. See Modifying Metadata on page 142. CopyMetaData lets you copy metadata from one input to another and filter metadata to exclude some of it. See Copying Metadata from One Input to Another and Filtering Metadata on page 144. AddTimeCode lets you add a timecode to the metadata passed down by the input node. See Adding a Timecode to Metadata on page 145.

Viewing Metadata

To view metadata
1. Select MetaData > ViewMetaData to insert a ViewMetaData node after the node whose metadata you want to inspect.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Working with File Metadata

141

2. In the ViewMetaData properties, you can see a list of the metadata embedded in the image. This is divided into keys and their values.

3. To filter the lists of metadata, use the search metadata for field. For example, if you enter f in the search metadata for field, only the keys and values that include the letter f are displayed. By default, the search is done within both keys and values. If you want to limit to search to either keys or values only, set within to keys only or values only. For example, you can view metadata specific to the inputs file format by entering the file format (for instance, dpx/) in the search metadata for field and setting within to keys only. Note

When observing the creation time (input/ctime) of an image, Windows generally differs from Linux and Mac OS X. This is due to the different way in which the operating systems deal with file creation times.
Once you know which keys exist on the input, you can reference them in expressions. See Accessing Metadata via TCL Expressions on page 146.

Comparing Metadata Between Inputs

To compare metadata between two inputs


1. From the Toolbar, select MetaData > CompareMetaData to add a CompareMetaData node after the two nodes whose metadata you want to compare. 2. Connect the nodes you want to compare to the A and B inputs of the CompareMetaData node. A list of keys where there is a difference between the two inputs is shown in the CompareMetaData properties.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Working with File Metadata

142

Modifying Metadata

To add metadata
1. Select MetaData > ModifyMetaData to insert a ModifyMetaData node after the node whose metadata you want to add a new key to. 2. In the ModifyMetaData controls, click on the plus (+) button. A placeholder appears in the metadata box. 3. Double-click on the placeholder under key.

Double-click here

The Pick metadata key dialog opens. 4. In the field at the bottom of the dialog, enter a name for the new key you want to add to the metadata. Click OK.

5. Double-click on the placeholder under data and enter a value for the new key. The new key and its value are added to the metadata being passed through.

To edit metadata
1. Select MetaData > ModifyMetaData to insert a ModifyMetaData node after the node whose metadata you want to edit. 2. In the ModifyMetaData controls, click on the plus (+) button. A placeholder appears in the metadata box. 3. Double-click on the placeholder under key. The Pick metadata key dialog opens. 4. Pick the key whose name or value you want to edit and click OK.
The Foundry Nuke 6.3v6

MANAGING SCRIPTS Working with File Metadata

143

The key is added to the ModifyMetaData properties. 5. In the ModifyMetaData properties, double-click on the key or its value and edit the information as required.

To remove metadata
1. Select MetaData > ModifyMetaData to insert a ModifyMetaData node after the node whose metadata you want to edit. 2. In the ModifyMetaData properties, click on the plus (+) button. A placeholder is added to the metadata list. 3. Double-click on the placeholder under action and select remove from the menu that opens.

Double-click here

4. Double-click on the placeholder under key.

Double-click here

The Pick metadata key dialog opens. 5. From the list of existing keys, select the key you want to remove and click OK.

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Working with File Metadata

144

The node now removes the selected key from the metadata, as you can see if you view the metadata in the output.

To edit the list of actions in the ModifyMetaData properties


To perform a new action, click on the plus (+) button. To cancel an existing action, select it from the list and click on the minus (-) button. Note that this only affects the ModifyMetaData actions, and does NOT delete keys from the metadata embedded in the input image. To move an item up in the list, select it and click on the up arrow button. To move an item down in the list, select it and click on the down arrow button.

Copying Metadata from One Input to Another and Filtering Metadata

To copy metadata from one input to another and/or filter metadata


1. Select MetaData > CopyMetaData to insert a CopyMetaData node into your script. 2. Connect the Image input to the node whose image you want to pass down the tree. the Meta input to the node whose metadata you want to copy to the output. 3. Set metadata from to one of the following: Image+Meta to add the metadata from the Meta input to the metadata from the Image input. If the inputs share any common metadata keys, the values taken from the Meta input override those taken from the Image input. Meta only to only use the metadata from the Meta input. Meta+Image to add the metadata from the Image input to the metadata from the Meta input. If the inputs share any common metadata keys, the values taken from the Image input override those taken from the Meta input. Image only to only use the metadata from the Image input. This produces the same result as not using a CopyMetaData at all: both the image and metadata are taken from the Image input. However, this option can be useful if you want to filter the metadata to exclude some of it (see the next step for how to do this). 4. To filter the metadata taken from the inputs, use the copy only fields under Meta filtering and/or Image filtering. For example, if you enter f in the copy only field under Meta filtering, only the keys and values that include the letter f are copied from the Meta input. By default, the
Nuke 6.3v6

The Foundry

MANAGING SCRIPTS Working with File Metadata

145

search is done within both keys and values. If you want to limit to search to either keys or values only, set within to keys only or values only. For example, you can copy metadata specific to the inputs file format by entering the file format (for instance, dpx/) in the copy only field and setting within to keys only.

Adding a Timecode to Metadata

To add a timecode to metadata


1. Select MetaData > AddTimeCode to insert an AddTimeCode node into your node tree. A timecode is added to the metadata being passed through. By default, the timecode is 01:00:00:00 on the first frame. It is updated throughout the frame range according to the input clips playback speed, which in turn is controlled by the fps (frames per second) parameter in the Project Settings. If you change the fps value in the Project Settings, the timecode in the metadata is updated to reflect the change.

2. If you dont want the timecode on the start frame to be 01:00:00:00, enter a new timecode in the startcode field. 3. If you want to specify the playback speed manually rather than get it from the metadata and project settings, uncheck get FPS from metadata and enter a new value in the fps field. 4. If you want to specify a different start frame than the first frame, check use start frame? and enter a new value in the start frame field. If you want to display the timecode on the image, insert a Text node after the AddTimeCode node and enter [timecode] in the message field. For more information on referencing metadata via expressions, see Accessing Metadata via TCL Expressions below.

Rendering Metadata

When rendering with the Write node, Nuke lets you write out metadata into the following file formats: EXR, CIN, DPX, and JPEG. You cannot write out metadata into any other formats. When rendering metadata into an EXR file, you can use the metadata menu in the Write node controls to specify what to write out:

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Working with File Metadata

146

no metadata - Do not write out any metadata, except for metadata that fills required header fields (for example, filename and bbox). default metadata - Write out the timecode, edgecode, frame rate, and exposure. default metadata and exr/* - Write out the timecode, edgecode, frame rate, exposure, and anything in exr/. all metadata except input/* - Write out all metadata, except anything in input/. all metadata - Write out all metadata. When rendering any other file format than EXR, Nuke writes whatever metadata the file format header is known to support. Therefore, what is written out varies according to the file format.

Accessing Metadata via TCL Expressions

You can access metadata via TCL expressions in the following ways: To get a list of all keys in the incoming metadata, use the expression [metadata]. For example, if you add a Text node after an image and enter [metadata] in the message field, a list of all the keys in the incoming metadata appears on the image. The values of the keys are not displayed. To get the value of a particular key in the incoming metadata, use the expression [metadata key]. Replace key with the name of the key whose value you want to use. For example, to display the name and location of the image file on the image, add a Text node after the image and enter [metadata input/filename] in the message field. To get a filtered list of keys in the incoming metadata, use the expression [metadata keys filter]. Replace filter with whatever you want to use to filter the list. You can use asterisks (*) as wildcards in your filter to substitute zero or more characters in the key names. For example, to get a list of all the keys with the letter f in them, use the expression [metadata keys *f*]. To get a list of all the keys starting with input/, use the expression [metadata keys input/*]. By default, the keys are listed on separate lines. To change this, you can use -s "separator" to have the keys separated by a separator of your choice. Replace separator with whatever you want to appear between the different keys. For example, to get a list of all the keys starting with input/ and separated by spaces, you can use [metadata -s " " keys input/ *]. To get the same list separated by commas, use [metadata -s ", " keys input/*]. By default, if you attempt to access metadata that does not exist in the stream, Nuke returns an empty string. To make this error instead, use the -

The Foundry

Nuke 6.3v6

MANAGING SCRIPTS Working with File Metadata

147

e flag before other parameters. For more information on using expressions, see the Expressions chapter in the Nuke User Guide.

Accessing Metadata via Python

You can also access metadata using the Python programming language. For more information, see the Nuke Python documentation (Help > Documentation).

The Foundry

Nuke 6.3v6

TUTORIALS
Welcome to the Tutorials! If youve gone through the Getting Started section and had a look at the Nuke User Guide which we highly recommend you already know something about Nuke. These tutorials show how to pull everything together through a series of practical examples. We will add further tutorials as time goes on. They will appear on our web site between releases of Nuke. You can also go through these tutorials using the Nuke Personal Learning Edition (PLE), but some features used in the tutorials may be disabled in the PLE version. For more information about the PLE version, see About the Personal Learning Edition on page 20.

The Projects

Tutorial 1: Compositing Basics. Explains the Nuke user interface, project workflow, and basic compositing tasks. Tutorial 2: Tracking, Stabilising, and Matchmoving. Demonstrates how to track image patterns, stabilize footage, lock down images for clean plates and matchmove. Tutorial 3: Keying and Mattes. Shows how to pull mattes with standard keying tools and Nukes own image-based keyer. Tutorial 4: 3D Integration. Shows how you can use Nukes 3D workspace to help your 2D compositing.

Installing the Project Files

Before you continue, download the tutorial project files from The Foundry website and move them to a directory youll create, called Nuke_Tutorials. Its up to you where you put your tutorial files, but heres our recommendations below depending on your operating system. Whatever you do, youll need to remember where you put these files. Tip

If youre using a Mac or Linux system, log in under administrator privileges to avoid issues with permissions when installing the files.

To create the tutorial directory (Windows)


1. On the Windows desktop, double-click the My Computer icon to open a file browser. 2. Double-click on Local Disk (C:) and open the C:\Documents and Settings\All Users\Application Data folder.

TUTORIALS Installing the Project Files

149

3. Click the right-mouse button over the displayed directory and choose New > Folder from the pop-up menu. 4. Name the folder: Nuke_Tutorials.

To create the tutorial directory (Mac OS or Linux)


1. Open a shell or terminal window. 2. At the command line, enter mkdir ~/Nuke_Tutorials to create the tutorial directory under your user or home directory.

To download and install the project files 1. Open an internet browser and go to: http://www.thefoundry.co.uk.
2. Navigate to the Nuke product page from the Products menu at the top of the home page. 3. Click on the Tutorials & Example Images link on the right hand side. You can also access this page by selecting Help > Tutorials in Nuke. 4. Click the links to download the project files to your local computer. 5. Extract the downloaded files and move (or copy) them to the Nuke_Tutorials directory you created earlier. Youre now ready to start the first tutorial with Nuke.

The Foundry

Nuke 6.3v6

TUTORIAL 1: COMPOSITING BASICS


Hello! This tutorial is your introduction to Nuke, where youll create a simple composite and breeze through most of the windows, on-screen controls, and other user interface items. Weve heard rumors that many people would rather march through icy rain than review an introductory tutorial on digital compositing. Certainly, thats not you. When you finish this lesson youll have a good understanding of the Nuke workflow and should feel confident about approaching the other tutorials.

Figure 1.1: Your first composite in Nuke. Before you get into the project, we have some administrative things to do such as defining a few application preferences and project settings. We know this sort of thing is not terribly exciting, but it is terribly important, so please be patient and well get through it as quickly as possible. Note

If you havent already downloaded and moved the tutorial project files to the Nuke_Tutorials directory you created, turn to Installing the Project Files on page 148 for instructions.

Starting Nuke

The Nuke icon may appear on your desktop. If so, double-click it to launch the application. Otherwise, start Nuke with one of the methods described below, assuming you have installed Nuke to the default location.

To launch Nuke under Windows


From the Start menu, choose All Programs > The Foundry, and then select Nuke6.3v6.

COMPOSITING BASICS Starting Nuke

151

To launch Nuke under Mac OS X


Open the /Applications/Nuke6.3v6/ folder and double-click the Nuke6.3v6 icon.

To launch Nuke under Linux


Open the /usr/local/Nuke6.3v6/ folder and double-click the Nuke6.3 icon. Tip

If youre operating under Linux, you can also launch Nuke from the command line of a terminal. Simply navigate to the Nuke directory and enter the name of the nuke application.
A clean copy of the main Nuke window appears. Divider lines organize the window into different panes. Each pane has one or more pages of content, separated by tabs at the top of the pane. The Toolbar appears at the left edge of the main window.

content menu toolbar

Viewer pane Properties pane tabbed pages

divider line Node Graph/Curve Editor pane

Figure 1.2: The main workspace. By default, the panes are setup to display the Viewer, the Node Graph/ Curve Editor, and Properties. Youll create the script for this project inside the Node Graph page on the Node Graph/Curve Editor pane. Well talk about each of these on-screen controls when you need them for the project.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Using the Toolbar

152

Using the Toolbar

The Toolbar includes the options you can use to build your project, such as importing images, layering images, drawing shapes and masks, applying color correction, and so on. Each Toolbar icon displays a menu of operators or nodes that you can select. Roll the mouse pointer over the Toolbar and youll see pop-up tool tips that identify each icon.

Using the Menus

The Nuke menu bar appears at the top of your screen, outside the main window. This menu begins with the options File, Edit, Layout, and so on. When instructed to do so, make selections from the menu bar, or click the right mouse button to choose from a pop-up version of the menu bar.

Figure 1.3: The Nuke menu bar. The right-click menu is highly contextual. Its options change according to the location of the mouse pointer. Right-click over the Node Graph, for example, and youll see the options from the menu bar and the nodes you can insert from the Toolbar. Right-click over the Viewer pane and youll see a menu of Viewer options.

Figure 1.4: The right-click menu.


The Foundry Nuke 6.3v6

COMPOSITING BASICS Customizing Your Layout

153

Try the right-click menu when you cant find appropriate controls or menu options. Many features are hidden in the pop-up menu until youre in the situation where you need to use them. Note

Nukes menu bar, at the top of the screen, is organized a little differently between the operating systems, but the right-click menu contains the same options, regardless of the system youre using to run Nuke.

Customizing Your Layout

Nuke gives you several options for customizing the window layout. Its time for you to claim your copy of Nuke and make it your own! You dont need to customize the layout for this lesson, but why not try it now for your own personal amusement? Here are some things you can do to reorganize the window layout: Drag a divider line between panes to change the size of the panes. To divide a pane, click on the content menu (the checkered box at the upper-left corner of each pane), and choose Split Vertical or Split Horizontal. To add a new tabbed page to a pane, click on the content menu and choose one of content options, such as New Viewer or Curve Editor. Click on the x inside a tab to discard a tabbed page. To move a tabbed page, drag the tab to another pane inside the main window. To tear-off a page as a floating window, drag the tab outside the borders of the main window, or simply Ctrl+click (Mac users Cmd+click) on the tab name. Drag a floating window into a pane, inside the main window, to convert it to a tabbed page. From the menu bar, choose Layout > Save Layout x to save the current layout. Choose Layout > Restore Layout x to apply a previously-saved layout. To select a predefined color scheme, click the right mouse button and choose Edit > Preferences. Then click the Choose a Preset button and select a color scheme. Define other appearance options, such as window colors and fonts, by changing the settings under Edit > Preferences > the Node Graph tab.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Customizing Your Layout

154

resize pane

Figure 1.5: Resizing a pane.

split pane

Figure 1.6: Splitting a pane.

close pane

Figure 1.7: Closing a pane.

close tab

Figure 1.8: Closing a tab.


The Foundry Nuke 6.3v6

COMPOSITING BASICS Saving Files and File Backup

155

Saving Files and File Backup

We assume you already know how to save files (Hint: choose File > Save As). In addition, Nuke includes an autosave feature, which helps recover project files after a system failure. Yes, we know that will never happen to you, but in the unlikely event that it does, you wont lose your work when you have autosave enabled.

To define file/saving options


1. Click the right mouse button over the Node Graph pane, and choose Edit > Preferences. Notice the autosave filename directory is set to [value root.name].autosave. You dont need to make a change; this simply tells Nuke to store automatic backup files in the same directories as your project files. Now, how often would you like Nuke to generate an automatic backup while youre working? Every five minutes? 2. Change the force autosave after option to 300 seconds, to generate an automatic backup every five minutes.

3. Click Save Prefs to keep the changes and then Close to return to the main window.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Setting Up the Project

156

If you close this dialog box without clicking the Save button, then the changes will affect only the current session of Nuke.

Recovering backup files


You may ask, How do I recover a backup file in the event of a system or power failure? Good question! When you relaunch Nuke, youll see a message that asks if you want to recover the .autosave file for the project that was last open. Click Yes and Nuke opens the backup file. Tip

The .autosave files can still be useful, even when you properly exit Nuke, because they are not deleted from the directory. You can, for example, rename an .autosave file to create an archive of the previous version of your project file.
Sometimes you will see the recovery message even though you have not experienced a system failure. This happens when you exit Nuke without saving the changes to a project file, and Nuke recognizes that the time stamp on the .autosave file is later than the Nuke project file youre trying to open. In this case, you decide which version of the project file you want to open.

Turning off automatic backup


Okay. Youre reading this, so we assume youre a freewheeling rebel who possibly enjoys the risk of losing your work. Its an adrenaline thing. Or perhaps you prefer to do everything yourself, manually, and you have a secret obsession for saving your files, often. Whatever the reason, you can disable the autosave features by setting the intervals for both autosave idle and force autosave to zero seconds. Thats it. Thats all you need to do. Good luck.

Setting Up the Project

When you start a new project, you need to define project settings for length or frame range, the number of frames per second for playback, and the output format. These options appear on the Project Settings dialog box.

To setup your project


1. Click the right mouse button over the Node Graph, and then choose Edit > Project Settings from the pop-up menu.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Working with Nodes

157

2. In the frame range fields, enter a range of 1 to 28. This will be the length of the shot we create for the project. 3. Enter 24 as the frames per second (fps). 4. Click the full size format list and choose PC_Video 640 x 480. 5. Close the Settings control panel.

Note

On the project Settings control panel, the LUT tab includes options that ensure color integrity for your display and output devices. You dont need to change the LUT for these tutorials, but we recommend that you research and set these options for your own projects.
Until now, everything youve done is standard procedure for a new project. You used the menu bar to access several features during the setup process, and now youll use the Nuke toolbar to insert nodes and create a compositing tree.

Working with Nodes

A node is simply one of the building blocks for the list of operations you want to complete. A node tree is a diagram that shows the order in which the operations will be performed. Do the following to add a few nodes and start your node tree. The result will create the background for the project.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Working with Nodes

158

To insert nodes
1. On the Toolbar, click the first icon to display a menu for nodes that are in the Images category.

2. Select Constant from the menu to insert this node into the Node Graph pane. When you insert a new node, its control panel also appears with parameters that let you define what the node will produce. In this case, the Constant node creates a solid color backdrop.

Constant control panel

Constant node

3. In the Constant control panel, click on the color wheel to open the Color Picker.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Working with Nodes

159

Color wheel icon

Drag inside the wheel to select a value. Drag along the ring to select a color.

4. Drag the color sliders and the cursor inside the wheel to choose a light color, something appropriate for the horizon of the composite background. Then, close the color wheel window. At this point, you should probably rename Constant to something more descriptive. 5. Inside the control panel, click on the Constant name. You can now edit the name, so type Background and press Enter.

From here onward, well call this node the Background node. 6. Close the control panel for the Background node. When you need to reopen it, just double-click the node and the control panel will reappear. 7. Click on the Background node to select it. Then, click the right mouse button and choose Draw > Ramp from the pop-up menu.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Working with Nodes

160

8. Drag the tail of the arrow from the Viewer1 node to the center of the Ramp1 node. Youll see the output of the Background node and the ramp controls displayed in the Viewer window.

9. Click the Color tab inside the control panel for Ramp1. Then choose a dark color that blends well with the color you selected for the Background node.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Working with Nodes

161

10. Click the Ramp tab in the control panel to reactivate the overlay controls. Then, drag the p0 and p1 control points to adjust the spread and angle of the ramp over the background.

11. When youre happy with the results, close the Ramp1 control panel to remove the overlay.

Connection Tips

Most nodes have input and output connectors that are used to establish the order in which the operations will be calculated.

Input connector Mask connector Output connector

Figure 1.9: Connectors on a node. Try the following to connect nodes after you insert them into the Node Graph: Drag an input or an output connector onto another node to establish a connection.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Working with Nodes

162

Select a node, press the Shift key and select a second node. Then press Y to connect the first node to the output of the second node.

Select a node, press the Shift key and select a second node. Then press Shift+Y to connect the second node to the output of the first node.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Working with Nodes

163

Shift+Y

Select a node and press Ctrl/Cmd+Shift+X to extract the selected node from the tree.

Ctrl/Cmd+Shift+X

For nodes that have two inputs, select the node and press Shift+X to swap the A/B inputs.

Shift+X

Drag the mask connector to the node that provides the image you want to use as the mask for the selected node.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Importing Image Sequences

164

Importing Image Sequences

For this project, you need to import a few image sequences for the foreground elements and a background plate.

To read the images


1. Click on a blank space in the Node Graph. This ensures none of the nodes are selected. 2. Click the right mouse button over the Node Graph and choose Image > Read from the pop-up menu.

A file browser appears. This where you select the image file you want to import. When you browse through your directories from this window, Nuke will display sequentially-numbered files as one item in the directory. 3. Browse to the Nuke_Tutorials/CompBasics/ directory. 4. Add a bookmark to this directory. Right-click over the list, on the left side of the file browser window, and choose Add from the pop-up menu.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Importing Image Sequences

165

5. Type a name for the bookmark or keep the default, which is the directory name. Then click OK.

6. Open the engine_rgba directory, select the engine.v01.####.exr image sequence, and click Open.

Nuke retrieves the image sequence and displays it as a thumbnail on the node. The Read control panel displays the resolution and the frame range for the image. Note

Nuke reads images from their native format, but the Read node outputs the result using a linear color space. If necessary, you can change the Colorspace option in the Read nodes control panel, or insert a Color > Colorspace node to select the color scheme you want to output or calculate.
Nuke 6.3v6

The Foundry

COMPOSITING BASICS Navigating Inside the Windows

166

7. Drag a marquee (hold down the left mouse button while dragging) around the Background and Ramp nodes to select them. Then drag them to the right to make room for additional nodes.

8. Choose Image > Read from the right-click menu to import another image sequence. Use the file browser to select the image sequence stored in Nuke_Tutorials/CompBasics/smoke_left.wh/ smoke_left.####.rgba. 9. Add one more Read node and retrieve the image sequence stored in Nuke_Tutorials/CompBasics/smoke_right.wh/ smoke_right.####.rgba

10. Arrange the nodes, as shown above, to allow some room to create the connections for the node tree.

Navigating Inside the Windows

The node graph panel can seem very small, especially when your node tree grows. True, you already know how to resize and tear-off the windows, but sooner or later you will run out of display real estate. Its time to learn some navigation controls that will help you work in the node graph (and other windows) in Nuke. Try the following navigation controls:

Panning your view


Windows/Linux: While pressing the Alt key and the left mouse button, drag the mouse pointer across the node graph.
The Foundry Nuke 6.3v6

COMPOSITING BASICS Navigating Inside the Windows

167

Mac OS X: While pressing the Option (alt) key and the left mouse button, drag the mouse pointer across the node graph. As you drag the mouse, you pan your view of the node graph.

Zooming or magnifying your view


Windows/Linux: While pressing Alt and the middle mouse button, drag the mouse pointer across the node graph. Mac OS X: While pressing Option (alt) and the middle mouse button, drag the mouse pointer across the node graph. Drag to the right and youll zoom-in. Drag to the left and youll zoomout. Keyboard zoom-in/out. Tap the plus (+) key to zoom-in. Tap the minus key (-) to zoom-out.

Using the node graph overview


When the node tree extends beyond the borders of the window, a navigation box appears in the lower-right corner of the node graph. Drag the shaded rectangle inside the box and youll quickly pan to another view of the node tree.

Drag this box to pan the view of node tree

Framing the view in the window


Press the letter F on your keyboard to fit the entire contents of the node tree within the borders of the node graph. The navigation controls for the node graph also work inside the next window on our agenda, the Viewer.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Working with Viewers

168

Working with Viewers

The postage stamps on the nodesthose little pictures, often called thumbnailsshow what each node passes onto the next node in the tree. Although quite lovely, they wont do for real compositing work. You need to open a Viewer window to see the full picture.

currently displayed channels alpha channel / "other" channels

timeline

Figure 1.10: Controls on the left side of the Viewer.

zoom setting downrez setting proxy toggle

Figure 1.11: Controls on the right side of the Viewer. You can open several Viewers at once. In addition, you have up to 10 pages, or buffers, for each Viewer window; these allow you to toggle between different views along the node tree. When you start Nuke, you will see a default Viewer node in the Node Graph. You can easily drag the connection arrow from a node onto the Viewer to
The Foundry Nuke 6.3v6

COMPOSITING BASICS Working with Viewers

169

display the nodes output. You can open additional Viewers by choosing Viewer > Create New Viewer from the menu bar or by pressing Ctrl+I.

To display the images in a Viewer window


1. Drag the connector from the Viewer node onto the Read node for the engine.v01 clip.

Heres an alternate method: Select the engine.v01 clip node and then press 1 to connect to the Viewer node. Nuke displays the nodes output in the Viewer window.
zoom setting red, green, and blue channels displayed

2. Press the Alt key (Mac users press Option) and the left mouse button, and drag the mouse pointer across the Viewer window to pan. 3. Press Alt (Mac users press Option) and the middle mouse button, and drag to zoom in/out. You can also use the zoom list at the top of the Viewer to magnify the view.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Working with Viewers

170

4. Press F to fit the current image into the borders of the Viewer window. This image has different channels of information you can view. The RGB label appears at the top because the Viewer now shows the result of the red, green, and blue channels. 5. To view individual color channels, press R (red), G (green), B (blue) or A (alpha). As you press each hotkey, the label at the top of the Viewer reflects the displayed channel.

red channel displayed

6. Press one of the channel hotkeys again to return to the RGB display, or choose RGB from the Viewers channel list. In addition to the standard color channels for red, green, blue, and alpha, this image also includes channels for specular highlights, reflections, and other masks. 7. To view additional channels, press A to display the alpha channel, and then select the lightingpasses.reflection channel from the Viewer channel list.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Working with Viewers

171

reflection channel displayed in Viewer channel list

You now see the reflection mask from the image file. 8. Select rgba.alpha from the Viewer channel list to reset this as the preferred channel when you press the A key. 9. Press A again to toggle the display and show all color channels.

To view multiple inputs


1. Select the Read node for the smoke_left clip, and press 2 at the top of your keyboard or on the numeric key pad. This creates a second connection to the Viewer from the selected node. When the cursor is over the Viewer, you can press a number on the keyboard to pick the connection you want to view. 2. Move the mouse pointer over the Viewer and press 1 to display the engine.v01 clip. Press 2 to display the result of the smoke_left node. In this manner, you can connect multiple images to the same Viewer and then switch between the images. 3. Select each of the other nodes and press a number to establish a connection to the Viewer.

4. Move the mouse pointer over the Viewer and press the numbers on your keyboard to display each of the connected nodes.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Reformatting Images

172

As you switch between the different views, the images may appear to be the same size. However, if you look in the lower-right corner of the Viewer, youll see the images have different resolutions.

resolution = 1440 x 1152

resolution = 720 x 548

resolution = 1920 x 1080

Figure 1.12: These images have different resolutions. Nuke allows multiple resolutions in one composite, but you need to conform these images to match the project resolution. This will allow the elements to be properly aligned in the composite.

Reformatting Images

Elements created within the Nuke script, such as Background and Ramp, automatically inherit the global format and thats how you want it for this project. The imported images, however, do not conform to the project settings and must be reformatted.

To conform images to the project format


1. Click the Read node for the engine.v01 clip to select it. 2. Click the right mouse button and choose Transform > Reformat from the pop-up menu. 3. Repeat steps 1 and 2 for all the Read nodes in the node graph. 4. Move the mouse pointer over the Viewer, and press the keyboard numbers (1, 2, and 3) to switch between the connected images. Each image should now conform to the project format.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Using Proxies and Down-res

173

If you change the delivery format in the project settings, then all elements set to root.format will also change to the new project settings. If you neglect to reformat images when you read them into the project, the images will retain their original format, independent of the project settings.

Using Proxies and Down-res

Proxies are low-resolution versions of the final image you intend to create. For many compositing tasks, the low-res version can help you work faster. Then, when youre ready to create the final output, switch proxy mode off and return to the full-res version.

Figure 1.13: Full resolution.

Figure 1.14: Proxy resolution.

Nuke can generate proxies on-the-fly, according to the scale or format of your images. You select the method under Edit > Project Settings. To toggle the proxy resolution defined under Project Settings, you use the proxy button on your Viewer. Alternatively, you use the down-res button to lower the display resolution of individual Viewers. The down-res button works both in the full-res and proxy mode.

To activate proxy mode


1. Click the right mouse button over the node graph and choose Edit > Project Settings. 2. Make sure the Viewer window is open. 3. Press the keystroke to toggle Proxy mode, Ctrl+P. A label inside the Viewer indicates that you are now in proxy mode. 4. Move the mouse pointer over the Viewer, and press the plus (+) key several times to zoom-in. 5. Press Ctrl+P a few times to toggle between hi-res and proxy mode. 6. Before you continue, press Ctrl+P to switch back to full resolution.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Compositing Images

174

To activate down-res
1. Choose 4 from the down-res list to change the display resolution to 25% of full resolution.

With a reduced resolution, Nuke requires less time to calculate and display your images. 2. Change the down-res setting back to 1, which is 100% of the active resolution. If you turned off the proxy mode, you should be back to full resolution. If proxy mode is turned on, the display resolution will be 100% of the proxy resolution.

Compositing Images

The Merge nodes create a composite with two or more images, using various compositing algorithms. In this example, well do a very simple A over B composite to layer the foreground image over the background. You can insert a compositing node from the Toolbar or menus, but well show you a shortcut that bypasses both of these. The trick is the select both nodes you want to composite and then press a hotkey to assign a compositing node.

To composite two nodes


1. Select the Reformat1 node, attached to engine.v01. This provides the foreground image for the first compositing operation. 2. Press the Shift key and select the Ramp1 node. Both engine.v01 and Ramp1 nodes should be selected. 3. Press the letter M to insert a Merge node. The first node you selected is attached to the A input on the Merge node, as the foreground input. The second node you selected is attached to B, the background input. If necessary, you can swap the A and B inputs of a merge node by pressing Shift+X.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Compositing Images

175

In the Merge node control panel, the operation parameter determines the compositing algorithm used to generate the result of the two inputsthe selected operation becomes the name of the node in the Node Graph. 4. Rearrange the nodes, so that the node tree looks similar to this:

5. For the next layer, select the Reformat3 node, attached to smoke_right. Then, hold down the Shift key and select the Ramp1 node. 6. Press M to insert a Merge node and composite one image over the other. This composites the smoke_right image over the background.

7. The default compositing algorithm, Over, isnt exactly what we need here. In the Merge2 control panel, click on the operation list and select screen.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Compositing Images

176

8. In the Merge2 control panel, drag the mix slider and change its value to 0.30 to reduce the amount of the image supplied by the A input.

9. An additional Merge node is required. Select Reformat2 for smoke_left. Hold down the Shift key and select the Over node (the first Merge node you inserted).

10. Press M to composite the two nodes. In the Merge3 control panel, change the mix slider to 0.75. The result of your composite should look similar to the example shown below.

Figure 1.15: Result of the composite.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Color-Correcting Images

177

Color-Correcting Images

Color-correction and filters can help you integrate the elements for a better composite. In our example, you want to limit the correction to the foreground element only, so youll insert a color correction node before the Merge nodes. 1. Select the Reformat1 node. Then, right-click over the Node Graph and choose Color > Exposure. This inserts the EXPTool1 node.

2. Suppose you want to adjust the value of the red color channel. Move the mouse pointer over the Viewer window and press R to display the red channel. 3. In the EXPTool1 control panel, uncheck the box for gang sliders. This will allow you to adjust individual color channels.

4. Drag the red slider to adjust the color values. When you are finished, press R over the Viewer to display all channels. The Exposure node worked as expected, but the result is less than spectacular. The color change is too uniform. If only there were a way to limitor, in fact, maskthe color correction, perhaps wed see a better composite. Hmm...

Masking Effects

You can, indeed, apply masks to limit how each of these nodes affects the images. The following shows how to create a Bezier mask to limit the colorcorrection.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Creating Flipbook Previews

178

To Create and Apply a Bezier Mask

1. Click on a blank space in the node graph, so that nothing is selected in the node tree. 2. From the Toolbar, choose Draw > Roto to insert a Roto node. 3. Click inside the Viewer window to draw a Bezier shape over the image, like this:

4. To refine the shape, click on a point to select it and then drag to adjust its position. 5. To create sharp corners, select a point, right-click and choose Cusp from the pop-up menu. 6. To add points to the shape, simply select the Add Points tool and click on the shapes outline. 7. When youre satisfied with the shape, drag the mask connector from the EXPTool1 node to the output of the Roto node. In the EXPTool1 control panel, the mask channel option is now set to the rgba.alpha channel of the node that is connected to the mask input. In this case, this is the alpha channel of the Roto node.

Creating Flipbook Previews

On the Viewer window, the timeline buttons let you play the project, but if you pay attention to the frames-per-second (FPS) field at the top of the Viewer window, you may notice that Nuke doesnt provide real-time playback. This is because Nuke renders on-the-fly to display images in the Viewer. Its fast, but also limited by the amount of memory and computerprocessing power available to you. The Flipbook feature provides better real time preview, because it is prerendered for the FrameCycler viewer, included with Nuke. Keep in mind that the Flipbook feature will render a preview that matches the active resolution; if youre in proxy mode, for example, thats the resolution youll get in the flipbook.

Note

The Flipbook feature renders temporary files in the directory you specified for disk cache under Nuke > Preferences. Youll also find an option there
Nuke 6.3v6

The Foundry

COMPOSITING BASICS Rendering Final Output

179

that allows you to limit the amount of disk space that the flipbook feature may use.

To generate a flipbook
1. 2. 3. 4. Select the Over node at the bottom of your node tree. From the menu bar, choose Render > Flipbook selected. Enter 1-28 as the number of frames to preview and click OK. When the flipbook is ready to view, a copy of the FrameCycler window will appear. Click the Play button to view the results. 5. Close the FrameCycler window to return to your project.

Rendering Final Output

When youre ready to render the results of your composite, you insert a Write at the bottom of the node tree, and specify the pathname for the rendered images. Although well use just one here, you can place several Write nodes in your script, anywhere you like, to render output from different places in the tree. When the render order is important, use the render order option in the Write nodes to specify the order in which multiple renders should be executed.

To render the result of your composite


1. Select the last Over node at the bottom of the node tree. 2. Right-click and choose Image > Write to add a node for output.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Rendering Final Output

180

3. In the control panel for the Write node, click the file folder icon.

file folder icon

4. Browse to the Nuke_Tutorials directory.

click here to create a new folder

5. Click the new folder icon, in the upper-left corner of the browser, and type Rendered as the name for the new folder. Click OK. 6. Select the folder you just created. You should see the Nuke_Tutorials/Rendered/ pathname displayed at the bottom of the browser. 7. At the end of the Nuke_Tutorials/Rendered pathname, type first_comp.####.exr as the name for the rendered image sequence, and then click Save. 8. Choose Render > Render All to render the images, or simply click the Render button inside the Write control panel.

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Rendering Final Output

181

9. Nuke prompts you to specify the frames to render. Enter 1-28 as the frame range and click OK. A status window appears that shows the progress of your render. When the render is complete, youll find the sequential images in the Nuke_Tutorials/ Rendered directory. To check the results, simply insert a new Read node, point to the new image sequence, and then generate a flipbook with the Read node selected.

Using the Nuke frame number variable


Whats that #### bit in the filename, you say? Thats the variable that tells Nuke where to place the sequential numbers or frame numbers. You only type one name to represent the image sequence, but Nuke will create one image file for each frame in your shot. So, in this case, you entered first_comp.####.exr but Nuke will render these files for frames 1 through 5: first_comp.0001.exr, first_comp.0002.exr, first_comp.0003.exr, first_comp.0004.exr, and first_comp.0005.exr. You can change the number of hash marks in the variable##, ###, #####to change the number of padded digits for the frame numbers. An alternative way of marking frame numbers is the Printf (%0d) notation. In this case, the same frame numbers would look like this: "first_comp.%04d.exr". Instead of the number of hash marks, with the printf notation you would change the number before d to adjust the number of padded digits, for example "%03d" or "%05d". You can choose which style you want to use by setting Sequence Display Mode option on the Appearance tab of the Preferences.

Image formats
If you dont specify a file format inside the Write node control panel, Nuke uses the format specified by the filename extension you typed. For example, in this tutorial, you used the .exr extension to tell Nuke to save the images as OpenEXR files.

Rendering with the active resolution


When you execute a render or a flipbook, Nuke assumes you want to render the active resolution. When youre in full-res mode, for example, Nuke renders full-resolution images to disk. When youre in proxy mode, Nuke assumes you want to render the proxy resolutiondefined in the Project Settings windowto the path and filename you specified as the proxy

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Epilog

182

filename in the Write node. If the proxy field is empty or pointing to an invalid path, Nuke returns an error. Its easy to toggle to proxy mode and then forget your images will be rendered in the lower resolution. Before you execute a render, its always a good idea to check which resolution is active. In the Viewer, the label at the lower-right corner of your image will indicate whether you are in full-res or proxy mode.

Rendering multiple channels


When you insert a Write node, Nuke assumes that you need only the RGB channels in the final render. In many cases, this is acceptable because you wont need the alpha channel or other channels from the node tree when you deliver final shots to your clients. However, sometimes you need to render intermediate filessuch as mattes, projection elements, or subcompsand include all the channels in your node tree.

For example, rather than manage several elements for an animated character, you could combine the character animation, the lighting passes, alpha channel, and a depth mask in one image sequence on disk. This makes it easier to manage elements in the final composite and simplifies the artists workflow. To output all channels, change the Write nodes Output list from RGB to All Channels, select the OpenEXR file format, and then execute the render. Currently the OpenEXR format (.exr) is the only file format that supports unlimited channels.

Epilog

In this tutorial, you setup a new project and created a simple composite. You learned how to use (or at least, locate) practically every Nuke window and tool, and you rendered out the result of your composite. Youre finished! Go home! Well... there might be a few more things you want to know. After this

The Foundry

Nuke 6.3v6

COMPOSITING BASICS Epilog

183

tutorial, you should feel comfortable with the Nuke user interface, so put on your explorer hat and review the other tutorials. Theres no specific order from here, so look through the following pages until you find what interests you.

- End of Tutorial -

The Foundry

Nuke 6.3v6

TUTORIAL 2: TRACKING, STABILISING, AND MATCHMOVING


Every filmmaker knows the challenges of putting together a vision. You may not have the money to build post-apocalyptic Montreal, but you might have enough to create it in post. You may have brilliant performances by your actorsbut not together in the same shot. Fortunately, you can composite the best takes. Your battle sequence with 5 A-list actors, 100,000 extras and 57 elephants, comes back from the lab with scratches on the negative. You can fix it. You can. A savvy production team knows how to leverage digital technology to make it possible, and Nukes tracking tools are indispensable for these situations. As you may know, tracking is the process of recording the location of features as they move through the scene. The result is stored as 2D coordinates on the image plane. Once you have the tracking data, you can use the movement to perform a variety of useful tasks, such as stabilizing the footage, applying the movement to other elements in your composite, and improving the accuracy of roto mattes.

Figure 2.1: Tracking image features. An important aspect of the tracking process involves carefully reviewing your footage before you attempt to track. Play your images several times preferably with a flipbookand look at the direction of movement for the features you want to track. Note potential problems with motion blur, obscuring objects, or frames where the features are hidden or move off screen. Tip

Nuke can often compensate for problem footage, but tracking works best when you can identify distinct features throughout the length of the shot.

TRACKING, STABILISING, AND MATCHMOVING One-Point, Two-Point, Three-Point, Four

185

One-Point, TwoPoint, Three-Point, Four

Before we get into the first example, lets review a few tracking concepts. You can track up to four distinct features or patterns with each Tracker node in Nuke. How do you decide whether to track one, two, or more features? It depends on what you want to do with the data and the level of accuracy you need in the result. Here are some general guidelines:

Figure 2.2: One track: X and Y position only.

Figure 2.3: Two tracks: X, Y, and Zrotation.

Figure 2.4: Three tracks: X, Y, Z-rotation, & scale. One-point tracking. Track one features horizontal (x-axis) and vertical (y-axis) position, with little or no perspective change on the image. You can apply this information to move other elements in the composite or apply the inverse to stabilize the image. Two-point tracking. Track horizontal and vertical position for two features. The feature positions, relative to each other, indicate whether the image is rotating clockwise or counter-clockwise (z-axis rotation). In some cases, two tracking points is sufficient to calculate the scaling of the features, as well. Three-point tracking. Track horizontal and vertical position for three features. Provides all the benefits of two-point tracking with an additional set of tracking data for more accuracy on z-rotation and scaling. Four-point tracking. Again, all the benefits of the lesser tracks with an additional set of tracking data. Three-point is usually sufficient for most 2D tracking needs, but four-point makes it possible to distort and

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Open the Tutorial Project File

186

matchmove another element into the four points, or corners, of the features you track. Thats why four-point tracking is typically called cornerpin tracking.

Open the Tutorial Project File

In this tutorial, you work from a project file that already includes the node trees. Each tree is setup for the examples that follow.

To open the project file


1. Launch the Nuke application and choose File > Open from the menu bar. 2. In the file browser, navigate to your Nuke_Tutorials/Tracking/ folder, select the tracking_tutor.nk project file and click Open. 3. It will show some nodes in error. Dont worry! It cant find the tutorial files. So before doing anything else you have to tell this script where to find these tutorial images, assuming you can remember where you put them. Double-click on the NoOp node in the top left corner of your node graph. Its called Tutorial_Path. Double clicking will bring up a property panel on the right. Enter the path to the tutorial files in the Tutorial Project Directory. Use the file browser as thats often easier than typing it in. You should then see tutorial images appear. 4. Move the mouse pointer over the node graph, and press F to frame the entire contents of the project file. The examples in this project file are grouped with colored boxes, called backdrops, and each contains a node tree for the tutorial examples that follow. Tip

Backdrops let you organize groups of nodes, like those shown in this project file. Choose Other > Backdrop from the Toolbar. Drag the backdrop title bar to move it. Drag the backdrop corner to resize it. Any nodes surrounded by the borders of the backdrop will move with the backdrop when you drag its title bar.

Tracking a Single Feature

In this first example youll learn how to track a single feature, which is the most basic 2D tracking operation. After you achieve a solid track for one feature, you can build on that and track other features as needed.

To track one feature (one-point tracking)


1. In the project workspace for the tracking_tutor.nk file, locate the node tree labelled Tracking an Image.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Tracking a Single Feature

187

2. Click on the LondonEye Read node to select it. 3. From the menu bar, choose Render > Flipbook selected. When the FrameCycler window appears, play the flipbook several times to review the footage. 4. Look at the features in the image and notice the amount and direction of movement as the clip plays. When youre done, minimize the FrameCycler window. 5. Choose Transform > Tracker from the Toolbar to attach a new Tracker node to the LondonEye Read node.

6. Connect the Viewer1 node to the Tracker1 node. Inside the Viewer, youll see one tracking marker. 7. In the Viewer, scrub the time slider to frame 1, to make sure youre at the beginning of the shot. 8. Use the mouse to drag the tracking anchor over the tower spire, shown below:

tracking anchor pattern box search area box

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Tracking a Single Feature

188

9. Click on the pattern box (inner box) of the tracking marker, and adjust its size to contain the feature. 10. Click the search area (outer box) of the tracking marker, and adjust its size to enclose the amount of space you think the feature may move between frames. Large search areas require more calculation time, so keep it as small as possible. However, when the search area is too small, the feature may move outside the box and youll lose the track. If you arent sure how large to make the search area, go back and review the flipbook of your image. 11. In the control panel, click the track forward button to generate the track.

When completed, youll see the track curve with points that mark the keyframe positions along the curve.

12. Use the next frame and previous frame buttons on the timeline to step through the timeline and verify the accuracy of the track.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Tracking a Single Feature

189

step backward

step forward

The track is fairly solid in this example. However, some images dont track as easily as this one. When you need to edit track data, what do you do? You open the Curve Editor of course! Lets assume you need to smooth the points of this track.

To edit track data


1. In the tracker control panel, click the animation button next to the Tracker 1 parameter, and choose Curve editor from the pop-up menu.

2. Click the items in the Curve Editor outline and youll see values recorded for each of the parameters during the tracking process.

3. Hold down the Shift key and click the X and Y curves, under track1, to select both curves at once and press the F key to frame the curves. To adjust a value, select a point and drag it up or down. To change the frame for a particular point, select it, hold down the Ctrl key and drag the point left or right.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Tracking Obscured Features

190

4. Lets assume you want to smooth a curve by applying a filter to the values. Draw a marqueedrag while pressing the left mouse button around a section of the curve to select multiple points.

5. Click the right mouse button to display a pop-up menu of Curve Editor options. Choose Edit > Filter and enter 2 as the number of times to filter the key frames.

Nuke averages the location of each point based on the values of the surrounding points, and this helps to smooth the curve. 6. Close the Curve Editor window and then play the result in the Viewer. Those are the basics for tracking and editing the results for a single feature. In the next example, well make it a little hardertracking a feature that moves out of view.

Tracking Obscured Features

At the end of the previous example, you may have noticed the track was dropped at frame 58 when the feature moved off the screen. Disappointing? Yes. A disaster? Probably not. When features move out of frame, or become obscured by other elements in the image, you can use the track offset feature to pass the tracking operation to another feature in the image. Nuke then attempts to continue the track along its current course.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Tracking Obscured Features

191

To track a feature that moves off screen


1. In the project workspace, locate the node tree Tracking Obscured Features. 2. Double-click the Tracker2 node to open its control panel. This node tracks one of the chimneys in the clip you used from the previous example. 3. Attach a Viewer to the Tracker2 node and scrub the timeline until you see the tracked feature move out of frame.

As you can see, track1 accurately tracks its feature through most of the clipuntil it moves off the screen at frame 44. This is where the problem starts. 4. Press the plus key (+) on your keyboard a few times to zoom in on the Viewer. You want to select an alternate feature that stays in view during the length of the clip. 5. At frame 44, press the Ctrl (or Command) key and drag the track1 point to the first chimney at the right.

The offset1 label appears with a line connecting the new feature to the original feature.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Stabilising Elements

192

6. In the Tracker2 control panel, press the track forward button and Nuke continues the track off the screen.

Why is this cool? Because you can now use the track data to matchmove an elementa trail of chimney smoke, for examplethat will lock to the feature even after it moves off the screen. 7. The track is now complete, so you can click the clear offset button in the Tracker2 control panel. 8. Uncheck the enable box for track1 to prevent it from being recalculated. 9. Before you continue, close all Tracker control panels that are currently open. The offset doesnt change the track location. Instead, it allows Nuke to continue the track with the assumption that the offset feature remains at the same relative distance to the original feature. Later in this chapter, youll see how to use this tracking data to composite another element to match the background plate.

Stabilising Elements

Stabilisation is the process of removing motioncamera-shake, for exampleand locking down the element for your composite. A one-point track provides enough information to stabilize horizontal and vertical motion along the image plane. A two-point track lets you stabilize horizontal and vertical motion, and remove rotation in the image, as well.

To track and stabilize


1. Locate the node tree labelled Stabilizing Elements. 2. Youll see a copy of the same LondonEye Read node that weve been using for the other examples. Click on it to select it. 3. Choose Transform > Tracker and then attach a Viewer to the new Tracker3 node. 4. In the control panel for Tracker3, check the boxes to enable Tracker1 and Tracker2.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Stabilising Elements

193

5. For each track, check the boxes for T (translate), R (rotate) and S (scale).

6. In the Viewer, scrub to the end of the timeline and adjust the size and position of each tracking marker for the features shown below:

7. In the control panel, click the track backward button to generate the tracks.

Now you have the position data for two tracks, and you can use this information to remove the unwanted movement in the image.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Stabilising Elements

194

8. In the Tracker3 control panel, click the Settings tab and choose Translate/Rotate/Scale from the warp type list.

9. Click the Transform tab and choose stabilize from the transform list.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Matchmoving Elements

195

10. In the Viewer, click the play forward button and review the results.

As the clip plays, youll see the features remain locked to the same position within the compositing frame. Tip

After you track and stabilize footage, you can add a Transform > Transform node after the Tracker3 node to adjust the position and the rotation of the stabilized image for a final composite.

Matchmoving Elements

Matchmoving is the opposite of stabilisation. The intent is to record and use the motion in an image and apply it to another element. In the following example, youll use the tracker to matchmove and composite a mask image onto the performer in a background plate.

To matchmove an element
1. Find the node tree labelled Matchmoving Elements. 2. Drag the time slider to the beginning of the timeline. Select the ColorCorrect1 node and then choose Transform > Tracker.

3. Attach a Viewer to the new Tracker4 node and position the track1 marker over the performers right ear.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Matchmoving Elements

196

4. Adjust the size of the pattern box and the search area as shown. 5. In the control panel, next to Tracker1, check the boxes for T (translate), R (rotate) and S (scale). 6. Click the enable box for Track 2 to activate the controls for an additional track. Check the boxes for T (translate), R (rotate) and S (scale) on this track, also. 7. Press the minus key (-) over the Viewer to zoom out, and youll see a second tracking marker appears.

8. Adjust the size and position of the second tracking marker, as shown below.

9. In the control panel for Tracker4, click the track forward button to generate the tracks. After you get a solid track on the performer, you need to make a copy of the Tracker4 node to create the matchmove.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Matchmoving Elements

197

10. Select the Tracker4 node and press Ctrl+C to copy it. 11. Select the Transform1 node and press Ctrl+V to paste the Tracker node copy (Tracker5). 12. Connect the Viewer to the Over node. Your node tree should now look similar to this:

13. In the Tracker5 control panel, click the Transform tab and choose match-move. Then close the Tracker5 control panel.

14. Click the play forward button in the Viewer or render a flipbook and you should see the Mardi Gras mask transform to match the movement of the performer.

The Foundry

Nuke 6.3v6

TRACKING, STABILISING, AND MATCHMOVING Epilog

198

If you see jitter in the movement, you can edit the track data in the Curve Editor to smooth out the data. You can also add a small value to the dejitter parameter or add values to the smooth T, R, and S parameters on the Transform tab to filter the tracks.

Epilog

In this tutorial, you worked with several examples for the Tracker node. You learned how to record the locations for multiple features and you applied the tracking data for other tasks in the composite, such as stabilisation and matchmoving.

- End of Tutorial -

The Foundry

Nuke 6.3v6

TUTORIAL 3: KEYING AND MATTES


Keying is one of those fundamental compositing skills. You cant composite anything until you have mattes pulled for the elements you want to layer together. Its nice to say you could just push a button to complete this task, but as you probably know, one keying operation seldom produces an acceptable matte. Image quality, lighting conditions, subject motion, colorseven camera movesaffect the steps required to get a clean matte for your composite.

Figure 3.1: Keying Footage in Nuke. So how do you get a clean matte in Nuke? The best approach is to understand the strengths of each keying tool and combine them as needed. This tutorial shows how to pull keys in Nuke and how to layer the results with channel operations, merge nodes, and rotoshapes.

Open the Tutorial Project File

The project file for this tutorial includes several node trees for the keying operations described in this chapter.

To open the project file


1. Launch the Nuke application and choose File > Open from the menu bar. 2. In the file browser, navigate to your Nuke_Tutorials/Keying/ folder, select the keying_tutor.nk project file and click Open.

KEYING AND MATTES Open the Tutorial Project File

200

3. Double-click on the Tutorial_Path node, located on the left side of the script, to open its control panel.

4. In the Tutorial_Path control panel, click the file folder button. Browse to the location where you installed the tutorial project files, and then click Open to select the location.

After you select the correct path, the error messages should clear from the Read nodes, and the thumbnails in the script will update with the correct images. 5. Close the Tutorial_Path control panel. Then, choose File > Save As to save a copy of the project file. 6. Move the mouse pointer over the node graph, and press F to frame the entire contents of the project file. The green arrows (lines) show the links between the Tutorial_Path node and the Read nodes. 7. If you wish, press Alt+E to hide the expression arrows. The Tutorial_Path node saves the location of the project files on your computer, so you dont need to repeat this for future sessions.

Figure 3.2: Node trees in the keying_tutor.nk project file.


The Foundry Nuke 6.3v6

KEYING AND MATTES Keying with Primatte

201

Keying with Primatte

The Primatte keyer includes a quick Auto-Compute option that evaluates your image and determines a good baseline key. From there, you can easily tweak the settings and generate an acceptable matte. The two examples in this section show how to pull a key with the AutoCompute option (method 1), and also how to manually sample a color from the screen background and build your key from there (method 2).

To pull a key with Primatte (method 1)


1. In the project file, locate the node tree labeled Keying with Primatte, and make sure a Viewer is attached to the Reformat1 node. 2. Choose Keyer > Primatte to insert the keyer between the foreground image and the Viewer.

3. Drag the bg connector from Primatte1 to the Reformat2 node, which supplies the background image for this example. The fg connector should be attached to Reformat1. 4. Move the time slider to frame 50, and click the Auto-Compute button inside the Primatte1 control panel.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying with Primatte

202

Thats it. Youre done... well, nearly done. We need a free-floating goldfish, but the reflections in the aquarium glass clearly indicate captivity. A garbage matte will easily remove the reflections, and youll learn how to do that later in the section on rotoscoping. For now, lets keep working with Primatte. As youve seen, Primattes auto-compute option can quickly pull keys on certain images. However, you should also know how to pull and tweak keys manually. You might, for example, need more control over the transparency of the fins on the goldfish.

To pull a key with Primatte (method 2)


1. Continuing from the previous example, open the Primatte1 control panel. 2. Click the undo button at the top of the control panel to step back to the previous state of the Primatte1 node. Or, you can also delete the current Primatte1 node and insert a new one.

3. Scroll down through the Primatte options and set the keying operation to Select BG Color.

4. The current color chip should display the eyedropper icon. If it doesnt, click on the color chip to toggle the eyedropper.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying with Primatte

203

5. Hold down the Ctrl+Shift keys (Mac users, hold down Command+Shift) and dragor scrubover a portion of the greenscreen in the image displayed in the Viewer.

This returns an average color-pick of the sampled pixels. If you want a color pick from a single pixel, press Ctrl or Command and click once over the greenscreen. After you pick, you can clear the red square by Ctrl- or Command-clicking again. 6. Press A over the Viewer to toggle to the alpha channel display. Looks like the aquarium is not as clean as we thought. Our color pick gave us a fairly noisy key, so lets clean it up.

Now youll sample a few areas of the image to push selected pixels to one of three areas: the transparent matte, the opaque subject, or the semi-transparent part of the matte. 7. In the Primatte1 control panel, change the keying operation to Clean BG Noise.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying with Primatte

204

8. Press Ctrl+Shift or Command+Shift and drag a small square over the dark area in the lower-right corner of the image.

This second color sample cleans the background by pushing the selected pixels into the transparent area of the matte. You probably need a few more samples to get a better key.

9. Scrub a few small areas in the background, focusing on the gray pixels until the matte improves.

The background doesnt need to be solid black. Were just trying to get a good separation between our foreground subject and the greenscreen background. 10. Change the keying operation to Clean FG Noise. This time, sample areas of gray pixels inside the goldfish.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying with Primatte

205

One or two small samples should be enough. The color pick pushes the selected pixels to the opaque part of the matte.

You want to keep the gray pixels inside the fins to retain a semi-transparent matte in these areas. If you go too far, you can always press the undo button in the control panel to step back to the previous action. 11. Press A again over the Viewer to toggle to all color channels. Your image should look similar to the example shown below. You may see some detail dropping out from the fins.

12. Change the keying operation to Restore Detail, and scrub over the fins to bring back some of the edge detail.

You may get different results than those shown here, depending on the pixel values you sample from the image. Use Restore Detail to push the selected pixels back toward the opaque part of the matte. Use the Make FG Transparent operation to fine-tune the semi-transparent area.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Image-based Keying

206

You could go back and forth, between cleaning the background and foreground, but this usually produces a matte with crunchy edges. The goal is to find the balance between foreground and background that produces an acceptable matte for your subject. Later in this chapter, youll use the rotoscoping tools to clean-up this matte and combine this with the image from the next example.

Image-based Keying

Many keying tools, like Primatte, use a color-pick as the baseline for the matte extraction process and then require the artist to tweak the matte from that baseline. Nukes image-based keyer (IBK) uses the pixel values of the compositing images, instead of a color-pick, to generate the best matte for the image you want to extract. It works by generating a processed screen image that preserves the color variations of the blue- or greenscreen and using this - rather than a single color - to pull the key. This generally gives good results and speeds up the keying process when working with uneven blue- or greenscreens.

Image-based keying requires two nodes in Nuke. First, you insert an IBKColour node to process the screen image, which is preset to work with either greenscreen or bluescreen. This node generates the processed screen image that preserves the color variations in your blue- or greenscreen. Then, you insert an IBKGizmo node to generate the matte using the processed screen image, the original image, and also the background image for the composite.

To pull a key with IBK


1. In the keying_tutor.nk project file, locate the node tree labelled, Image-based Keying. 2. Right-click over the Reformat3 node and choose Keyer > IBKColour from the pop-up menu. Drag the IBKcolorV3_1 node to the right.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Image-based Keying

207

3. Click an empty spot in the node graph to deselect all nodes. Then, choose Keyer > IBKGizmo from the pop-up menu. 4. From IBKGizmoV3_01 node, connect fg (foreground) to the Reformat3 node. Connect c (color screen) to the IBKcolorV3_1 node. 5. Connect bg from IBKGizmoV3_1 to the Reformat4 node, which supplies the background for the comp. 6. Connect the Viewer to the IBKGizmoV3_1 node, and your node tree should look similar to this:

7. Open the control panel for IBKColourV3_1 and change the screen type to green.

8. Open the control panel for IBKGizmoV3_1, and change its screen type to C-green.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Image-based Keying

208

You should see an acceptable matte, shown in the screen capture below, on frame 50.

This is a very good start for this image. 9. Connect the Viewer to the IBKColourV3_1 node. Youll see the processed screen image, which is essentially a Gaussian-filtered highcontrast key.

10. Choose Merge > Merge (or press M over the node graph) to insert a Merge (over) node.

11. Connect IBKGizmoV3_1 to the A input of the Merge (over) node. Then connect the B input to the Reformat4 node.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Image-based Keying

209

The color of this greenscreen is completely out of the region of the acceptable industry standard, but IBK does a good job anyway, by smoothing the screen and using the result to essentially create a difference matte with the foreground. Tip

IBK has presets for green and blue screens, but you can also do a color-pick for any screen color inside the IBKGizmo node.
If you zoom-in on the image, youll see small areas near the subjects hair, where the matte is compromised.

compromised matte edges

12. Connect the Viewer to IBKcolorV3_1 and youll see color artifacts around the edges of the matte.

color artifacts

When you look at the smoothed screen produced by IBKColor, you should see only values of your screen color and black. 13. In the IBKcolorV3_1 control panel, lower the darks, g (green) setting to -0.08. (If you were keying a bluescreen image, you would lower the b value for darks.).

The Foundry

Nuke 6.3v6

KEYING AND MATTES Image-based Keying

210

This fixes most of the problems at the hairline, but destroys the good key for the lower portion of the image. Tip

The artifacts in the IBKColor image appear as specific color shades: light green, dark green, light red, dark red, light blue, and dark blue. To remove these, simply adjust the appropriate controls for the artifacts you want to remove: lights/g, darks/g, lights/r, darks/r, lights/b, and darks/b.

14. In IBKcolorV3_1, raise the darks, g value to -0.03. Then change the lights, g value to 0.75. This corrects the artifacts of the screen image. 15. Now, change the patch black setting to 1.5 to restore the edge detail of the hairline.

patch black restores detail

The Foundry

Nuke 6.3v6

KEYING AND MATTES Rotoscoping

211

16. Connect the Viewer to the IBKGizmoV3_1 node. Press A and youll see the current alpha channel produced by the IBK system.

The displayed alpha image shown is correct for the IBK. If the intensity of the noise in your alpha channel is greater than the example show above, you may need to adjustin very small incrementsthe dark and light values for the color channels in the IBKColor node. 17. Press A again over the Viewer to toggle back to display all color channels, and scrub through the timeline to check the matte at various points in the clip.

18. If you havent already done so, save your project under a new file name to save the changes youve made to project.

Rotoscoping

In this example, well return to our first keying example to apply a garbage matte and clean-up the aquarium image.

To draw a garbage matte


1. Go back to the node tree from the first example, and connect the Viewer to the Primatte1 node. Drag the time slider to frame 50. 2. Click an empty spot on the node graph to deselect all nodes, and choose Draw > RotoPaint from the pop-up menu.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Rotoscoping

212

3. At this point, you dont need to connect the RotoPaint1 node to anything, but its control panel must be open, and the first tab, RotoPaint, should be active.

4. Inside the Viewer, youll see the goldfish image. Click the Bezier tool in the RotoPaint toolbar on the left side of the Viewer. Then in the Viewer, click four points around the goldfish to create a rotoshape. You can drag+click to draw a point and adjust its curve at the same time.

Tip

As long as the RotoPaint1 control panel is open, you can view and edit the rotoshape. You can press O over the Viewer to toggle the display overlay, if necessary. Click the right mouse button over any point to select options for the rotoshape.
Because this will be a garbage mask, we want to edit the shape to remove elements from the glass aquarium. 5. Drag the points and adjust the tangentsthe handles on each of the pointsto refine the rotoshape.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Rotoscoping

213

Now we need to animate the garbage matte to follow the motion of the fish. 6. In the RotoPaint tool settings panel, on top of the Viewer, the autokey option should be active. If not, click the box for this option.

7. Move the time slider to frame 1 and click the Transform tab in the RotoPaint control panel. Then select the entire Bezier shape in the stroke/shape list (at the bottom of the control panel) or by clicking one of the points in the shape using the Select All tool. A transform jack appears.

transform jack

8. Drag the center point of the transform jack, and move it over the current position of the goldfish.

9. Go to end of the timeline, to frame 60. Drag the shape once more to adjust for the movement of the goldfish.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Rotoscoping

214

If your Bezier shape is similar to the one shown above, then you probably dont need more than the three key frames at frames 1, 50, and 60. However, you may want to scrub through the timeline and make adjustments. 10. Scrub to frame 60 on the timeline and youll see the roto gets a little close to corner-line that we want to remove from the aquarium glass. 11. Click on an empty spot in the Viewer to deselect all points. Then, press Ctrl/Cmd and click on the point near the goldfishs nose, to temporarily break the points tangent handle. 12. Adjust the handles to create a peak at the fishs nose.

Now, for good measure, lets create a feathered edge for this particular point. 13. With the point selected, drag the feather handle away from the fish to create a feathered edge for this point, at this frame.

So youve drawn and animated the rotoshape. Lets wire it into the node tree to mask out the garbage.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Rotoscoping

215

14. Drag the bg connector off the Primatte1 node to disconnect it from the Reformat2 node. 15. Choose Merge > Merge from the pop-up menu. Connect Primatte1 to the A input on the over node. Connect Reformat2 to the B input.

16. Connect the RotoPaint1 node to the mask connector on the over node. This effectively removes the aquarium reflections in the image.

You might want to scrub through the timeline to see if there are places where you need to adjust the rotoshape. If you want to take this a little further, you can now add the goldfish to the composite from the second example. 17. Select and drag the Merge (over) node and the RotoPaint1 node below the node tree you used for the IBK example.

18. Drag the Viewer node over, as well, and keep it connected to the Merge (over) node.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying Video

216

19. Drag the B connector from the Reformat2 node and connect it to the over node in the IBK node tree.

The Viewer shows the result. Of course you might want to add a Transform node after the first Merge (over) node, to size and position the goldfish. Otherwise, this project is completed.

Keying Video

Nukes Keyer node provides standard controls for pulling luma keys, green and blue screens, and color channels. Well use this keyerand a few other nodesto handle a special keying situation: video. Well begin by inserting a group of nodes that allow you to pull a cleaner matte by filtering the compression artifacts in the chroma red and chroma blue channels of digital video. This involves converting the image back to its original colorspace, blurring the channels with the artifacts, and then converting the image back to Nukes native linear colorspace.

To prepare video footage for keying


1. In the Keying Video node tree, select the fgman.0001.dpx node. When Nuke reads images into the workspace, it converts them to a linear colorspace. So here the first step is to convert the video image back to video YCbCr colorspace.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying Video

217

2. Right-click over the node tree and choose Color > Colorspace from the pop-up menu. 3. In the Colorspace1 control panel, change the out parameter to YCbCr.

No, youre not having an 80s flashback. What youre experiencing is the result of the red, green, and blue channels remapped to the native video channels for luma (Y), chroma blue (Cb) and chroma red (Cr), respectively.

4. Press r over the Viewer to look at the Y channel. Press g to view Cb, and b to view Cr.

Above, you see the Y channel image on the left. The Cb channel image is shown on the right. Notice the blocky compression artifacts in the Cb channel. These make it difficult to get a clean edge for your matte, but since most of your detail is in the Y channel, you can apply a small blur operation to the Cb and Cr channels to improve the situation without losing much detail. 5. Press r, g, or b again to toggle back to all color channels.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying Video

218

6. Right-click on the Colorspace1 node and choose Filter > Blur. In the Blur1 control panel, set the blur size to 4.

7. Select rgb in the channels menu and uncheck the red channel box. You dont want the blur operation to process the image in the red channel (the remapped Y or luma channel) because this channel is uncompressed. 8. Right-click on the Blur1 node and add another Color > Colorspace node. Change the in parameter to YCbCr and the out parameter to Linear. This converts the image back to standard rgb/linear.

To pull a basic greenscreen key


1. Select the Colorspace2 node, and choose Keyer > Keyer from the right-click menu. This inserts a keyer named luminance key, which is the default keying operation for this node.

2. Attach a Viewer to the luminance key node and then press A to display the alpha channel.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying Video

219

In the control panel for the Keyer node, youll see the range graph:

B handle, high value

A handle, high value

The range graph is where youll adjust the low and high pixel values of the matte. The first yellow handle on the left determines the low or transparent values of the key and second handle, on the upper-right, determines your high or opaque values. 3. Drag the first yellow handle to the right until it reads .303 (approximately), and watch the effect in the Viewer.

This sets the low value for the matte. Any pixels that fall below this value are clipped to black. 4. Drag the yellow handle, located at the upper-right edge, to the left until it reads .455 (approximately).

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying Video

220

This sets the high value for the matte. Pixel values above this setting are clipped to white. At these settings, its not quite matte-worthy, so lets make an adjustment. 5. Drag the A handle to change the low setting from .303 to .424, and drag the B handle to change the high value from .455 to .61.

As you adjust the location of the handles, the slope of the line controls the softness, or level of grays, for the matte edge. A gradual slope produces a softer edge. A sharper slope produces a jagged or crunchy edgedrag the A handle on top of the B handle and youll see what that means.
B handle slope of line controls edge softness C handle

A handle

target range for pixels to key

D handle

The default positions let you control the low and high values, assuming your image has distinct light and dark areas. However, sometimes the subject of the matte falls into the middle-gray area; the C and D han-

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying Video

221

dles on the curve, after the first two, let you shift the center for the high values of the key. 6. Change the keying operation to greenscreen. Pull the high value handle to the right, up to the value of 1.0. Then, set the low value at .90.

Theres a lot of garbage around the image, but it looks like youve got a fairly clean edge around your subject. Lets check it in the comp. 7. Switch the Viewer to display all color channels and then attach the Viewer to the Merge (over) node.

Thats completely terrible. What happened? The alpha channel created by the greenscreen keyer must be multiplied into the pixel values of the original image in order to generate the matte. Some keyers, like Primatte, provide a "composite" output option which handles the multiplication for you. The Keyer node does not, so you'll have to do it manually.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying Video

222

8. Select the greenscreen keyer node and choose Merge > Premult from the right-click menu.

9. Adjust the high and low ranges values in the greenscreen nodes control panel to refine the edges around your subject.

This keyer isnt particularly good at handling spill, so lets add a colorcorrection node to remove those green edges. 10. Select the Premult1 node and then choose Color > HueCorrect from the right-click menu.

11. Select the g_sup parameter in the HueCorrect1 control panel to select the green suppression curve.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Keying Video

223

12. Over the Viewer, press the Ctrl or Command key and scrub over the green edges.

Inside the HueCorrect1 control panel, youll see a yellow vertical line, which marks the place in the curve that you need to lower to suppress the samples pixels. 13. While viewing the edges you want to suppress, adjust the g_sup curve so that it looks similar to this:

When youre satisfied with the spill-suppression, you may want to add a quick garbage matte to remove the rigging. 14. Click on an empty place in the node tree, and add a Draw > RotoPaint node. 15. Select the Bezier tool in the RotoPaint toolbar on the left side of the Viewer and click (and drag if you want curved points) over the Viewer to draw a Bezier shape around the man. Four points should be enough.

The Foundry

Nuke 6.3v6

KEYING AND MATTES Epilog

224

16. Select the RotoPaint node and press M to add a Merge node thats the shortcut for choosing Merge > Merge from the menuand change the merge operation to mask.

17. Rewire the nodes as shown below. The RotoPaint1 node should be connected to the A input on the mask node, HueCorrect1 should be connected to the B input. Connect the output of mask to the elbow dot.

This method of masking is a little different than what you did in the previous example. The point here is that there are different ways to structure these types of composites. Your results should look similar to the screen capture below.

Epilog

Keying is rarely a simple matter of picking the screen color you want to remove. To get the very best mattes, you often need to combine several techniques and youve learned several in this chapter. Youve pulled mattes

The Foundry

Nuke 6.3v6

KEYING AND MATTES Epilog

225

with Primatte and Nukes Image-based Keyer, and youve used the rotoscoping tools to cleanup a matte and control the parts of the image you want to use in the composite. Youve also seen how to key video footage by converting the image to its native colorspace and filtering the compressed channel data to pull a cleaner matte.

- End of Tutorial -

The Foundry

Nuke 6.3v6

TUTORIAL 4: 3D INTEGRATION
Nukes 3D workspace creates a powerful compositing environment within your project script. This workspace combines the advantages of cameras, lighting, and a three-axis (x, y, and z) environment, with the speed of nodebased compositing. You pipe 2D images into the 3D space, setup a camera, animate your scene, and then render the results back to the 2D composite.

Figure 4.1: Compositing in the 3D workspace.

The Basic 3D System

The 3D workspace is defined by a group of nodes in your script. The most basic setup includes a Camera node, a Render node, a Scene or Geometry node, and nodes that provide the 2D images you want to pipe into the 3D compositing space.

Figure 4.2: The basic 3D node tree: 2D image, geometry, scene, render, and camera.

The 3D Viewer

Once you have the 3D node structure, you can use any Viewer in Nuke as a gateway to the 3D compositing space. Choose 3D from the view list, or press the Tab key over the Viewer to toggle between the 2D and 3D views.

3D INTEGRATION The Basic 3D System

227

Figure 4.3: Each Viewer window can also display the 3D workspace. On the view list, youll also see orthographic viewsrtside, lfside, top, bottom, front, back which provide non-perspective views into the scene. In three-quarter perspective, it can be difficult to accurately place objects on the axes, and the non-perspective views make it easier to line things up.

The Geometry or Scene Node

Every 3D system needs a piece of geometrya card, a sphere, a cube, something to receive an image or clip that the camera can see. One is all you need, but you can setup complex systems with a large amount of 3D data. When you have two or more objects for a 3D system, you need a Scene node to create a place where the camera (and the ScanlineRender node) can see all the objects at once.

The Camera Node

The Camera node creates your view into a scene. It has several controls to help you match the properties of a physical camera. You can animate its position or import animation or tracking data to matchmove your 3D scene with a background plate. A 3D system can have multiple cameras connected to the Scene node, to create different views on a 3D scene. Tip

Only one camera can be connected to the ScanlineRender node to generate the output, but you can insert multiple ScanlineRender/Camera node pairs to generate output from various perspectives.

The ScanlineRender Node

The last node, ScanlineRender, sends the results of your 3D scene back into your composite as a 2D image. Its always 2D in, 3D manipulation, and then 2D back out, which is why this is often called 2-and-a-half-D.

The Foundry

Nuke 6.3v6

3D INTEGRATION Open the Tutorial Project File

228

The optional bg pipe defines the output resolution of the 3D system.

Figure 4.4: The scanline render node converts the image back to 2D. The image created by the ScanlineRender node will be the same resolution as your project settings. When you need to render a specific resolution, use the optional bg pipe. Connect a Constant node with the resolution you want and that will define the output of the ScanlineRender node. So now you know the basic 3D setup for your compositing script. Lets take a test drive.

Open the Tutorial Project File

The 3Dinteg_tutor.nk project file includes the node trees for the first part of this chapter.

To open the project file


1. Launch the Nuke application and choose File > Open from the menu bar. 2. In the file browser, navigate to your Nuke_Tutorials/3DInteg/ folder, select the 3dinteg_tutor.nk project file and click Open. 3. Locate the Tutorial_Path node, on the left side of the script, and double-click it to open its control panel.

The Foundry

Nuke 6.3v6

3D INTEGRATION Setting Up a 3D System

229

4. Click the file folder button. Browse to the location where you installed the tutorial project files, and then click Open to select the location.

After you select the correct path, the error messages should clear from the Read nodes, and the thumbnails in the script will update with the correct images. 5. Close the Tutorial_Path control panel. Then, choose File > Save As to save a copy of the project file. 6. Move the mouse pointer over the node graph, and press F to frame the entire contents of the project file. The green arrows (lines) show the links between the Tutorial_Path node and the Read nodes. 7. If you wish, press Alt+E to hide the expression arrows. The Tutorial_Path node saves the location of the project files on your computer, so you dont need to repeat this for future sessions with this project file.

Figure 4.5: Node trees in the 3dinteg_tutor.nk project file.

Setting Up a 3D System

Lets start with the basics. In this first example, youll create a basic 3D node tree, map an image to a 3D card, manipulate it, and then render the result back out to the 2D composite.

To setup a 3D node tree


1. In the 3Dinteg_tutor.nk project file, locate the backdrop node labeled Setting Up a 3D System. Youll see a Read node with the image youll use for this example.

The Foundry

Nuke 6.3v6

3D INTEGRATION Setting Up a 3D System

230

2. Right-click over the nuke_sign.jpg node, and choose 3D > Geometry > Card.

This attaches a Card1 node. Lets see what it looks like in 3D.

3. Attach a Viewer to the Card1 node and Nuke switches the Viewer to 3D. Wow, thats amazing. It looks exactly like the 2D Viewer. How can anyone tell the difference? Check the lower-left corner of the Viewer and youll see an orientation marker for the three axes in 3D. Youll also see that 3D is displayed on the view list.

That sign is a little darker than expected, isnt it? Actually, you cant see the image yet because the default view of the 3D workspace is at the origin or center of the space. Perhaps zooming-out will improve the view.

The Foundry

Nuke 6.3v6

3D INTEGRATION Setting Up a 3D System

231

4. Press the Alt key (Windows /Linux) or the Option key (OS X), and drag with the middle mouse button to zoom or dolly. Drag to the left and youll zoom out.

Hey, look. Theres the Nuke emblem. In the 3D Viewer, the pan and zoom controls are exactly the same as what youve used for the node tree and the 2D Viewer, but lets try tumbling to get a better view. 5. Alt- or Option-drag with the right mouse button to rotate around the origin point of the 3D workspace. You now see the 3D grid and the image mapped to the card.

When an image is connected directly to a Card node like this, it is applied as a flat or planar map. The size of the card adjusts to the dimensions of the image. 6. Click on the card and you will select the node in the node tree and also the card inside the 3D workspace. 7. Use the mouse (and the Alt or Option key) to navigate through the workspace. Go ahead, pan, dolly, and rotate at will. Then, press F over the Viewer to frame the 3D view. Tip

If you dont like the standard navigation controls, open the Preferences control panel (Shift+S), select the Viewers tab and change the 3D control type to Maya, Lightwave, or Houdini.
8. Click on an empty spot in the Node Graph to deselect all nodes. Lets add the other nodes you need.

The Foundry

Nuke 6.3v6

3D INTEGRATION Setting Up a 3D System

232

9. Right-click on the Node Graph and choose 3D > Camera from the popup menu. Keep its control panel open so you can manipulate the camera in the Viewer. 10. Right-click and choose 3D > ScanlineRender to insert a render node, and then connect the nodes as shown below.

11. Connect the Viewer to the ScanlineRender node, and you have the most basic 3D system in Nuke. 12. Press Tab over the Viewer to change to the 2D view. You wont see the Nuke emblemhey, where did it go? We saw it before. 13. Press Tab again to switch back to 3D. Youll see the default camera position is too close to view the card. Lets move things around to get an image for 2D.

To position objects in the scene


1. Alt- or Option-drag with the middle mouse button to dolly out and show more of the 3D workspace. 2. Select the camera. You can do this by clicking the camera object in the Viewer or clicking the Camera1 node in the Node Graph. 3. Drag the transform handles to move the camera away from the card, along the z-axis.

The Foundry

Nuke 6.3v6

3D INTEGRATION Setting Up a 3D System

233

As you drag the camera, look at the cameras control panel. Youll see the x/y/z transform values reflect the cameras current position.

translation (position) for x, y, and z

rotation for x, y, and z

4. Press Ctrl (Mac users press Command) over the Viewer and the transform handles change to rotation rings.

5. Drag the green ring to rotate the camera around the Y-axis. Notice the x/y/z rotation values in the control panel reflect the angle of the rotation. The blue handle rolls or rotates on the Z-axis, and the red handle rotates on X. 6. Now, select the card object and move it away from the camera. Keep the control panel open for the Card node. As with the Camera node, the transform handles disappear from the Viewer when you close the control panel.

The Foundry

Nuke 6.3v6

3D INTEGRATION Setting Up a 3D System

234

7. Drag the cards transform handles to position it in the 3D workspace. If you wish, press the Ctrl key (Mac users press Command) over the Viewer and rotate the card.

8. Press Tab over the Viewer to switch between the 2D and 3D views to see the image the ScanlineRender node will produce.

9. Before you continue to the next example, close all the control panels that are currently open. In this example, it doesnt matter where you move the camera or card. In reality, however, you often need to use specific values, which you can enter directly in the control panels. You can also import camera data or animation curvesdid you notice the import chan file button in the cameras control panel?and apply them to the objects in the workspace.
The Foundry Nuke 6.3v6

3D INTEGRATION Making a Scene

235

Making a Scene

We mentioned earlier the Scene node creates a place where multiple objects may be seen by the camera and the render node. If you only have a single object, you dont need a Scene node, but wheres the fun in that? Scene nodes make it possible to really tap into Nukes ability to handle huge amounts of 3D information, and you should know how to use it.

To setup a scene
1. Inside the Setting Up a 3D System node tree, drag a selection around the nuke_sign.jpg node and the Card1 node to select them.

2. Press Ctrl+C (Mac users press Command+C) to copy the selected nodes or choose Edit > Copy from the pop-up menu. 3. Press Ctrl+V (Mac users press Command+V) or choose Edit > Paste to insert a copy of the nodes. Press Ctrl+V or Command+V again to insert a second copy, and then arrange the nodes as shown below.

4. There are multiple cards now, and you need a Scene node to create a space where the rendering node can see all cards at once. 5. Click on an empty space in the node graph to deselect all nodes. Rightclick and choose 3D > Scene to insert the Scene1 node.

The Foundry

Nuke 6.3v6

3D INTEGRATION Making a Scene

236

6. Drag the Scene1 node onto the obj/scn connector to insert the Scene1 node between Card1 and ScanlineRender1.

7. Connect the obj/scn connector from the ScanlineRender1 node to the Scene1 node. Connect each Card node to the Scene1 node.

8. Double-click on the Card1 node to open its control panel. In the Viewer, youll see the transform handles for the first card. 9. Move and rotate the card to a different position. For this example, it doesnt matter where you place it. 10. Open the control panel for Card2 and move its card to a different place in the scene. 11. Open the Card3 control panel and move that card, also.

You could switch to the 2D view to see the result, but why not just look through the camera? Next to the view list, you see the button that locks the 3D view to the camera.

The Foundry

Nuke 6.3v6

3D INTEGRATION Merging and Constraining Objects

237

selected camera lock 3D view to selected camera

12. From the view list, choose 3D (V) to switch to a 3D perspective view. Then click the lock view to 3D camera button.

13. Turn off the lock 3D view to camera button. You wont need it during the rest of this tutorial.

Merging and Constraining Objects

You can merge objects and move them together as a group. To do so, you need to insert MergeGeo and TransformGeo nodes after the objects. The MergeGeo node first merges the objects together, after which you can use the controls of the TransformGeo node to move the merged objects in the 3D space. You can also use the TransformGeo node to constrain objects, as you will notice later in this tutorial. To merge the three card objects together, right-click on the Card1 node and select 3D > Modify > MergeGeo. This inserts a MergeGeo node between Card1 and Scene1. Disconnect the Card2 and Card3 nodes from the Scene node and connect them into the MergeGeo node. Then, right-click on the MergeGeo node and select 3D > Modify > TransformGeo. Your node tree should now look like the following:

The Foundry

Nuke 6.3v6

3D INTEGRATION Merging and Constraining Objects

238

On the TransformGeo nodes, you see multiple connectors. The connector without a label should be attached to a geometry object or a MergeGeo node. The other connectors act as constraints on the connected objects position.
You can connect look to the object or camera that the current object should face. You can connect axis to an Axis node. This links the position of the current object to the position of the Axis node.

When a camera or object is connected to the optional look connector, the TransformGeo node adjusts the rotation so that the objects z-axis always points to the camera or object. The axis connector can be used to link the current object to the position, rotation, and scale of a special 3D object called the Axis node. If youve worked with other 3D applications, you know the Axis node as a null or locator object. You are still working with the Setting Up a 3D System node tree. The following steps show how you can move the merged nodes, and also how to make objects look at the camera and other objects.

The Foundry

Nuke 6.3v6

3D INTEGRATION Merging and Constraining Objects

239

To move the merged objects together


1. Click on the TransformGeo1 node to select it. Its control panel should also be open and youll see its transform handles in the Viewer. 2. Drag the handles to move all the cards merged with the MergeGeo node. 3. Press the Ctrl or Command key and drag the rings to rotate the cards as a group.

4. In the TransformGeo1 control panel, drag the uniform scale slider to increase the size of the entire group of cards.

To make objects look at the camera


1. Drag the look connector from the TransformGeo1 node onto the Camera1 node.

In the Viewer, youll now see the TransformGeo1 node is constrained to the location of the camera.

The Foundry

Nuke 6.3v6

3D INTEGRATION Animating a Scene

240

2. Select and move Camera1 in the Viewer window. As you do so, the three cards controlled by the TransformGeo1 node rotate to look at the camera location. Why is this useful? Lets assume you have a 2D matte painting mapped to a card in your scene. The look option ensures that the plane of the painting always faces the camera, regardless of the camera position, and maintains the illusion depicted by the painting. Before you move on, disconnect the TransformGeo nodes look connector from the camera.

Animating a Scene

The little scene youve created would be more interesting with a camera move. You can animate both cameras and objects; in each control panel, youll see an Animation button next to each parameter you can animate over time.

To animate the camera


1. In the Viewer, drag the time slider to frame 1 on the timeline. 2. Lets switch to an overhead view to move the camera. Choose top from the view list.

3. Double-click on the Camera1 object (either inside the Viewer or on the node graph) to open its control panel. 4. Move the camera to the right and rotate it to look at the center of the 3D workspace.

The Foundry

Nuke 6.3v6

3D INTEGRATION Animating a Scene

241

5. Click on the animation button next to the cameras translate parameters, and choose Set key.

The background of the parameter boxes change color to show that a keyframe is now set for these values at the current frame in the timeline. Now, you need to set a keyframe for the rotation values. 6. Next, click the animation button next to the cameras rotate parameters, and choose Set key. 7. In the Viewer, scrub to the end of the timeline. Then, move the camera to the left side and rotate it to face center. This automatically sets keys for the translate and rotate parameters, for the last frame.

8. Drag through the timeline and the camera moves between the positions recorded by key frames. Yawn. With only two key frames, the camera moves in a straight line, from start to finish. Lets edit the animation curves to make this more interesting.

The Foundry

Nuke 6.3v6

3D INTEGRATION Animating a Scene

242

9. Click the animation button next to the cameras translate parameters and choose Curve editor from the pop-up menu.

This opens the Curve Editor window in the same pane as the Node Graph. The outline at the left side of the Curve Editor displays a list of the parameters youve animated, and the curves show the values plotted over time. Each dot shows the value recorded for a value on a keyframe.

Yes, we know. They dont look like curves - yet. You only set two key frames, remember? You can press Ctrl+Alt (Mac users press Command+Option) and click on any line to add more key frames. However, lets assume you want to create a smooth arc between the first and last recorded position of the camera. Rather than set more key frames, lets just change the shape of the curve. 10. You want to control the shape of the camera path along the zthe distance between the origin point and the camera, so click the translate / z parameter in the Curve Editor. Click on the first point of the translate/z curve to select it, and drag the tangent handle upward, as shown below.

The Foundry

Nuke 6.3v6

3D INTEGRATION Animating a Scene

243

From this point forward, the curve increases the distance of the camera on the z-axis, which youll now see in the Viewer.

11. Click on the last point of the translate/z curve to select it, and drag it upward also to finish the desired shape. This eases the distance back toward the value of the keyframe at the end of the timeline.

Select the camera in the Viewer and you should see the gradual slopes of the curve create a more interesting arc for the camera move. Switch to the 3D (V) perspective view and scrub through the timeline to see the new camera move.

Your version may look a little different than this, depending on the positions and rotations you defined, but you get the idea. 12. If you wish, you can set additional key frames to refine the camera path. Hold down Ctrl+Alt or Command+Option and click on the z-axis curve in the Curve Editor, to add new points to the curve, and then adjust their positions. 13. Before you continue, click the Node Graph tab to hide the Curve Editor and return to the node trees. 14. Close all the control panels that are currently open.

The Foundry

Nuke 6.3v6

3D INTEGRATION Working with Geometry

244

Working with Geometry

In the previous example, you worked with the card object. Nuke also includes primitive geometry, which can be used as set-extension geometry or placeholders for other elements you plan to add to scene.

To add primitive objects to the scene


1. In the 3Dinteg_tutor.nk project file, locate the node tree labelled Working with Geometry. Weve already supplied the 3D node tree with a camera for you, so you need to add the geometry objects, and also create a scene where they can coexist. 2. Right-click over the node graph and choose 3D > Scene. Connect Scene2 to ScanlineRenderG. 3. Connect a Viewer to the ScanlineRenderG node and switch to the 3D perspective view. 4. Right-click and choose 3D > Geometry > Cube.

The default cube primitive appears at the center of the 3D workspace. Lets reduce the number of subdivisions on the cube.

The Foundry

Nuke 6.3v6

3D INTEGRATION Working with Geometry

245

5. In the Cube1 control panel, change the rows parameter to 4. Change the columns parameter to 4, also.

6. Connect the Cube1 node to the Scene2 node. Now lets adjust the shape of the cube.

7. Reduce the height of the cube by dragging the top-center point down.

8. From the view list, choose the front view to see a non-perspective view of the cube. These non-perspective views can help you size and position objects with more accuracy than you might get in a perspective view. Mm... the cube is actually below the x-axis. Lets move it up, but check the values in the Cube1 control panel.

The Foundry

Nuke 6.3v6

3D INTEGRATION Working with Geometry

246

9. Drag the top of the cube until the t (top) value in the Cube1 control panel is about 0.3. Drag the bottom of the cube to align it with the xaxis.

10. It looks like you dont need 4 divisions on the sides of the cube, so change the number of rows to 2 in the Cube1 control panel.

Now lets add a few more primitivesa cylinder and a sphere. 11. Right-click on the node graph and choose 3D > Geometry > Cylinder. Connect the Cylinder1 node to the Scene2 node.

12. Change the view to 3D (V) and zoom out a little to see the whole cylinder.

The Foundry

Nuke 6.3v6

3D INTEGRATION Working with Geometry

247

13. In the Cylinder1 control panel, set the rows to 1, the columns to 20.

14. Set the radius to 0.35 and the height to 1.5. Also check the box for close top.

So now you have a cylinder in the scene. 15. Choose front from the view list and move the cylinder up to rest on top of the cube.

The Foundry

Nuke 6.3v6

3D INTEGRATION Working with Geometry

248

16. Now add a sphere. Choose 3D > Geometry > Sphere. In the Sphere1 control panel, set both the rows and columns to 15, and change the radius to 0.35.

17. Make sure the Sphere control panel is open and move the sphere object to cap the top of the cylinder.

18. Select the 3D from the view list and rotate the view around the objects in your scene. At this point, they have no surface properties, so youll need to connect a 2D image from the Node Graph to each object.

The Foundry

Nuke 6.3v6

3D INTEGRATION Lighting and Surface Properties

249

19. In the Node Graph, connect the concrete.jpg to each of the objects.

Lighting and Surface Properties

Nuke includes lighting tools to enhance the existing lighting in the plates and images you include in a 3D scene. Also included are fundamental surfacing tools to control the attributes of the objects in the 3D workspace. These tools are not designed to replace the use of true 3D lighting and surfacing, but they can definitely help you punch up the scene and quickly tweak the settings without sending elements back to the 3D application.

The Foundry

Nuke 6.3v6

3D INTEGRATION Lighting and Surface Properties

250

Nukes lighting objects introduce lighting and surface attributes into your scene. When the scene has no lighting objects, then all surfaces are illuminated with the same properties and level of brightness. In the following steps, youll first add nodes that define surface properties for the objects, and then youll add the light objects to illuminate them.

To define surface attributes to objects


1. Click on an empty place in the node graph to deselect all nodes. Then, choose 3D > Shader > BasicMaterial. 2. Drag the BasicMaterial1 node onto the connector between concrete.jpg and Sphere1.

In the Basic Material control panel, you will see parameters to define the amount of light emission, diffusion, and specular properties of the surface. You can mask these properties by connecting images to the mapS (specular), mapE (emission), and mapD (diffuse) connectors, but this is not required for this example.

3. Set the light emission control to 0.25. Set diffuse to 0.18, and specular to 0.75. 4. Adjust the min shininess and max shininess values to adjust the quality of the specular highlights. Once again, nothing seems to happen! Thats because you havent yet added a light into the scene. All surfaces are illuminated with the same level of brightness, so there are no specular highlights or other controllable light properties visible. Its not very exciting, but dont worry - you get to add a light into the scene soon. 5. Make two copies of the BasicMaterial1 node and attach a copy before Cylinder1 and before Cube1.
The Foundry Nuke 6.3v6

3D INTEGRATION Lighting and Surface Properties

251

To add light objects to a scene


1. Choose 3D > Lights > Spot and connect the light node to the Scene2 node. 2. In the Spotlight1 control panel, rename the light to Keylight.

3. Switch to the top view and drag x-axis handle (red) to move the light to the left.

4. Drag the z-axis handle (blue) to move the light closer to the bottom edge of the screen. Then, press the Ctrl or Command key and rotate the light to face the pillar object.

5. Switch to the 3D (V) view and rotate the view so you can see both the Keylight and the pillar geometry. 6. Drag the y-axis handle (green) to move the light up above the pillar.

The Foundry

Nuke 6.3v6

3D INTEGRATION Epilog

252

7. Press the Ctrl or Command key and rotate the light down to shine on the pillar.

Thats the basic setup for lighting and surfaces, but there are other tools for more complex setups. Refer to the Nuke User Guide for more information on the 3D lighting and surfacing tools.

Epilog

In this chapter, you learned how to setup a 3D workspace for your composite, and how to work with 3D geometry and lighting. These are all prerequisite skills for more advanced topics, such as camera projections, matchmoving, and set replacement.

- End of Tutorial -

The Foundry

Nuke 6.3v6

You might also like