Trees | Indices | Help |
|
---|
|
1 # -*- coding: utf-8 -*- 2 3 """ Check for multiple views in files when a read node is created, by 4 looking for a VIEW_NAMES entry in the node's metadata. 5 Most file types won't specify views but EXR/SXR and potentially other 6 files may do. 7 Registers for callbacks when a Read node is created, or its 'file' knob 8 is changed. If there are multiple views, and they do not exist on the 9 root node, the user is asked if they should be created. 10 """ 11 12 import nuke 13 from PySide2.QtCore import QTimer 14 from PySide2.QtWidgets import QApplication, QMessageBox 15 16 # Global for storing when the user says no 17 UserAlreadySaidNo = False 1820 """ Add the views in a list to the root node. """ 21 for view in views: 22 # Set "left" and "right" colours to match "setup views for stereo" behaviour 23 if view == "left": 24 nuke.root().addView(view, "#FF0000") 25 elif view == "right": 26 nuke.root().addView(view, "#00FF00") 27 else: 28 nuke.root().addView(view)29 3032 """ Attempt to get the views from a read node's metadata. Returns an 33 empty list if no views were found or if the node is disabled. """ 34 35 # disabled nodes return None when calling metadata() 36 if read['disable'].value(): 37 return [] 38 39 readMetadata = read.metadata() 40 if type(readMetadata) is not dict: 41 return [] 42 43 # Try to read the expected key. Catch KeyError and return an empty list if 44 # not present 45 try: 46 # If present, the metadata value is a list of view names separated by 47 # newlines. 48 views = readMetadata[nuke.VIEW_NAMES].split('\n') 49 50 # Now exclude any views that are wrapped in [], which indicate they're generic views rather 51 # than explicitly specified named views (e.g. we're reading from a multitrack QuickTime file 52 # and hence they're just some placeholder names generated by the reader). 53 # rick: This shouldn't be necessary when we support view-to-track mapping for QuickTimes, etc. 54 trueViews = [] 55 for view in views: 56 if not (view.startswith('[') and view.endswith(']')): 57 trueViews += [view] 58 return trueViews 59 except KeyError: 60 return []61 6264 """ Check if a read has multiple views, and if so, ask the user if they 65 want to add them to the root node. """ 66 global UserAlreadySaidNo 67 # Check we have a nuke read node rather than a timeline read node as the view checks 68 # for timeline read nodes are carried out in MediaSearch::promptUserToCreateViews() 69 isNukeReadNode = (read.rootNode() is nuke.root()) 70 if not UserAlreadySaidNo and isNukeReadNode: 71 views = getViews(read) 72 if views: 73 # Find the views in the read that do not exist on the Root node and if 74 # there are any, ask the user what to do. 75 rootViews = nuke.views() 76 missingViews = [ view for view in views if view not in rootViews ] 77 78 if missingViews: 79 userChoice = nuke.showCreateViewsDialog(missingViews) 80 if userChoice is nuke.DONT_CREATE_VIEWS: 81 UserAlreadySaidNo = True 82 elif userChoice is nuke.REPLACE_VIEWS: 83 viewsToDelete = [ view for view in rootViews if view not in views ] 84 # Create all views in the clip 85 createViews(views) 86 # Remove the views that are not in views 87 for existingView in viewsToDelete: 88 nuke.root().deleteView(existingView) 89 elif userChoice is nuke.ADD_VIEWS: 90 # Create only the missing views 91 createViews(missingViews)92 9395 """ Callback when a Read node is created. Note that the knob values 96 don't seem to be set when this callback occurs. Defer the check with 97 a QTimer, which will cause the views check to be done when the Qt event 98 loop next sends events. 99 """ 100 read = nuke.thisNode() 101 QTimer.singleShot(0, lambda: checkReadNodeViews(read))102 103 110 111 112 # Register the callbacks 113 nuke.addKnobChanged(onReadNodeKnobChanged, nodeClass="Read") 114 nuke.addOnUserCreate(onReadNodeCreated, nodeClass="Read") 115
Trees | Indices | Help |
|
---|
Generated by Epydoc 3.0.1 on Sat Jul 14 17:14:17 2018 | http://epydoc.sourceforge.net |