Brilliant. I am amazed that I actually did almost exactly what you are
outlining, haha. But I was so not sure if I'm doing the right thing, so thanks
heaps for clarifying/assuring!
One day we might end up in the same city and there will be beer payments due!
cheers,
frank
On Mar 7, 2011, at 3:42 PM, Ivan Busquets wrote:
> Hallo, Frank.
> Despite writing that tutorial, I am by no means an expert in matrix and
> maths. :)
>
> But I've learnt a thing or two about how they apply to things like camera
> transforms, etc., so hopefully I'll be able to help with this one.
>
> I think the easiest in your case (easiest to code, not necessarily to
> understand :p) is to start with the camera's transformation matrix instead of
> the Euler rotations. If you want to use Euler angles as a starting point,
> then you'll need to check for rotation order and such.
>
> To get the camera's transformation matrix, i usually do one on the following:
>
> - If your camera doesn't have any other Cameras or Axis driving its final
> transformation, you can simply do:
>
> cam_transform = nuke.toNode('camera_name')['transform'].value()
>
> - If you're interested in getting the final transformation matrix of a
> concatenated set of transforms, I usually use the following to wrap the
> contents of the 'world_matrix' knob into a nuke.math.Matrix4 object:
>
> #########
> def getCameraTransformMatrix(cameraNode):
> m = nuke.math.Matrix4()
> try:
> for i in range(0,16):
> m[i] = cameraNode['world_matrix'].value(i%4, i/4)
> except:
> print "couldn't get all values for a 4x4 Matrix. Identity matrix returned
> instead"
> m.makeIdentity()
> return m
> ##############
>
>
> Finally, once you have your transformation matrix in a nuke.math.Matrix4
> object, getting the lookAt and the Up vectors should be a matter of setting
> the initial direction of those two vectors, and then transform them using the
> matrix.
>
> I.E.
>
> # For a single, non concatenated camera. Otherwise use the helper funcion
> above.
> cam_matrix = nuke.toNode('camera_name')['transform'].value()
>
> # set up initial lookAt vector
> lookAt = nuke.math.Vector3(0,0,-1) # because Nuke's default cam looks at -Z
>
> # Initial up vector
> up = nuke.math.Vector3(0,1,0)
>
> #Final lookAt vector
> lookAt = cam_matrix.vtransform(lookAt)
>
> #Final up vector
> up = cam_matrix.vtransform(up)
>
> # Note that the key here is to use the "vtransform" method instead of
> "transform", since you want to apply the transformation to a direction
> vector, but ignore any scaling or translation.
>
> I think this should get you the right values to go from a Nuke camera to,
> say, a Camera + Aim + Up in Maya (don't have Maya here to check, though).
>
> Hope that helps!
>
> Cheers,
> Ivan
>
>
> On Sun, Mar 6, 2011 at 3:06 PM, Frank Rueter <[email protected]> wrote:
> Hola,
>
> has anybody converted a nuke camera (Euler rotations) to LookAt and Up
> vectors? as used by some other applications
> I am just starting to read Ivan's tutorial on Nukepedia hoping it will shed
> some light on this for somebody with very limited understanding of 3D
> rotational maths (aka "me") but thought I'd spread my feelers in here at the
> same time.
>
> Cheers,
> frank_______________________________________________
> Nuke-python mailing list
> [email protected]
> http://support.thefoundry.co.uk/cgi-bin/mailman/listinfo/nuke-python
>
> _______________________________________________
> Nuke-python mailing list
> [email protected]
> http://support.thefoundry.co.uk/cgi-bin/mailman/listinfo/nuke-python
_______________________________________________
Nuke-python mailing list
[email protected]
http://support.thefoundry.co.uk/cgi-bin/mailman/listinfo/nuke-python