Advertisement
Guest User

Untitled

a guest
Aug 17th, 2017
57
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.19 KB | None | 0 0
  1. import nuke
  2. import nukescripts
  3.  
  4. def paintPoints():
  5.  
  6. geoNode = nuke.activeViewer().node()
  7.  
  8. camera = nuke.selectedNode()
  9. if not camera.Class() in ( 'Camera', 'Camera2' ):
  10. nuke.message( 'Por favor, seleccione un nodo de la cámara primera')
  11. return
  12.  
  13. geoKnob = geoNode['geo']
  14. objects = geoKnob.getGeometry()
  15. if not objects:
  16. nuke.message( 'No se han encontrado geometría en %s' % geoNode.name() )
  17.  
  18. pts = []
  19. for o in objects:
  20.  
  21. objTransform = o.transform()
  22. for p in o.points():
  23.  
  24. worldP = objTransform * nuke.math.Vector4(p.x, p.y, p.z, 1)
  25. pts.append( [worldP.x, worldP.y, worldP.z] )
  26.  
  27. curvesKnob = nuke.createNode( 'RotoPaint' )['curves']
  28. task = nuke.ProgressTask( 'painting points' )
  29.  
  30. for i, pt in enumerate( pts ):
  31.  
  32. if task.isCancelled():
  33. break
  34.  
  35. task.setMessage( 'painting point %s' % i )
  36. stroke = nuke.rotopaint.Stroke( curvesKnob )
  37. pos = nukescripts.snap3d.projectPoint( camera, pt )
  38. ctrlPoint = nuke.rotopaint.AnimControlPoint( pos )
  39. stroke.append( ctrlPoint )
  40. curvesKnob.rootLayer.append( stroke )
  41. task.setProgress( int( float(i)/len(pts)*100 ) )
  42.  
  43. b = nuke.nodes.Blur ()
  44. k = nuke.Array_Knob("myctrl", "My Control")
  45. b.addKnob(k)
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement