Curve Frame on Surface¶
data:image/s3,"s3://crabby-images/288d2/288d2521e567603afeedbd0a4384dd3461e3a34e" alt="https://user-images.githubusercontent.com/14288520/210639554-d0a9be1f-e0ef-4c9f-b165-2f17dad71e20.png"
Functionality¶
Given a surface and a curve in the surface’s U/V space, this node calculates a reference frame of a curve for the given value of curve’s T parameter. The frame is calculated so that:
it’s X axis is pointing along surface’s normal;
it’s Z axis is pointing along curve’s tangent (in 3D space);
it’s Y axis is perpendicular to both X and Z.
This node allows one to place some object at the curve on the surface, while aligning it both with curve’s tangent and surface’s normal.
data:image/s3,"s3://crabby-images/83443/8344386b3b5815c69d2aa05d67b48d77785b1d70" alt="https://user-images.githubusercontent.com/14288520/210656324-3e8fdb9f-8654-491b-b305-cf512293a717.png"
Inputs¶
This node has the following inputs:
Surface. The surface to put the curve into. This input is mandatory.
UVCurve. The curve to calculate frame for. The curve is supposed to lie in XOY plane; X coordinate means U parameter of the surface, and Y coordinate means V parameter. This input is mandatory.
T. The value of curve’s T parameter. The default value is 0.5.
data:image/s3,"s3://crabby-images/0938f/0938fe9e5368298f012052a1d42283941e7b174f" alt="https://user-images.githubusercontent.com/14288520/210652754-f1802ae1-4cab-4761-80fc-eab7a03965b2.png"
Parameters¶
This node has the following parameter:
Join. If checked, then the node will output single (concatenated) list of matrices for all input curves. Otherwise, it will output separate list of matrices per each input curve. Checked by default.
data:image/s3,"s3://crabby-images/0f3f6/0f3f6ad610230347bafa8e87999df554407680c6" alt="https://user-images.githubusercontent.com/14288520/210657860-01c05782-4475-4d65-b6d0-3a22d2fe1bf3.png"
Outputs¶
This node has the following outputs:
Matrix. The matrix defining the frame for the curve at the specified value of T parameter. The location component of the matrix is the point of the curve.
Tangent. The direction of curve’s tangent vector at the specified value of T parameter.
Normal. The direction of curve’s main normal at the specified value of T parameter.
Binormal. The direction of curve’s binormal at the specified value of T parameter.
data:image/s3,"s3://crabby-images/136e3/136e3ce19956b092ecc2fc61c59ecac4b340ffba" alt="https://user-images.githubusercontent.com/14288520/210658893-6fb8a1e6-4913-4d04-8a3d-0d49ea85aa60.png"
Examples of usage¶
Let’s generate an ellipse by generating a sine wave in U/V space of cylindrical curve. Then we use “Curve Frame” node to place cubes along that ellipse:
data:image/s3,"s3://crabby-images/287f6/287f68c4ddb3c50155ca27f1e2f111c0fb192ce6" alt="https://user-images.githubusercontent.com/284644/89296471-d28d0480-d67b-11ea-9ac0-d6104821ea94.png"
As you can see, the cubes are aligned with a plane where the ellipse lies, but they are not aligned with the cylinder surface. Now let’s use “Curve frame on surface” node instead:
data:image/s3,"s3://crabby-images/8f80b/8f80b2900312d644624af559ed608578acc7c8eb" alt="https://user-images.githubusercontent.com/284644/89296479-d456c800-d67b-11ea-9409-2f83e9db415b.png"
Replay with new nodes:
https://gist.github.com/c119546943b4ce703d0f55be00cbedbd
data:image/s3,"s3://crabby-images/b8185/b818503862041354c640d396b8f4a11a577f55e7" alt="https://user-images.githubusercontent.com/14288520/210871891-c0228c13-2dc8-472d-ab3d-f806be82aed3.png"
Generator-> Box
Curves-> Circle (Curve)
Curves-> Curve on Surface
Curves-> Evaluate Curve
Curves-> Curve Domain
Curves-> Curve Frame
Surfaces-> Curve Formula
Surfaces-> Extrude Curve Along Vector
Number-> A Number
Number-> Number Range
Viz-> Viewer Draw
Script-> Formula
data:image/s3,"s3://crabby-images/419b0/419b0baa65fc5dcefeb4151420c6e02ca9496069" alt="https://user-images.githubusercontent.com/14288520/210870497-8c9108bb-0bfa-41d2-b1b8-fdfad1fc59c3.gif"
https://gist.github.com/5fdc5d5e6169a86f9356ff461be321d3
data:image/s3,"s3://crabby-images/831f8/831f8e154c0c180ed5f8cfdfbae95c4c8e7b4e61" alt="https://user-images.githubusercontent.com/14288520/210880364-869888dd-9ede-4131-8bc5-473f5624e5b0.png"
Generator-> NGon
Generator-> Box
Curves-> Cubic Spline
Curves-> Evaluate Curve
Surfaces-> Evaluate Surface
Surfaces-> Surface from Curves
Transform-> Move
Number-> Number Range
Matrix-> Matrix In
Mutrix Multiply: Matrix-> Matrix Math
Viz-> Viewer Draw
Scene-> Bezier Input