Welcome to the Onshape forum! Ask questions and join in the discussions about everything Onshape.

First time visiting? Here are some places to start:
  1. Looking for a certain topic? Check out the categories filter or use Search (upper right).
  2. Need support? Ask a question to our Community Support category.
  3. Please submit support tickets for bugs but you can request improvements in the Product Feedback category.
  4. Be respectful, on topic and if you see a problem, Flag it.

If you would like to contact our Community Manager personally, feel free to send a private message or an email.

Routing curve & Control point curve - Introduction of two new features for 3D curve creation

13»

Comments

  • billy2billy2 Member, OS Professional, Mentor, Developers, User Group Leader Posts: 2,056 PRO
    edited September 5

    So I've read all that I could and watched all the videos about polyline creation. I'm working on a plumbing project and trying to make "route curve" parametric.

    Notes:

    -The "polyline" stores x,y,x locations for points. There are no angles involved.

    -At each point, it does remember the orientation of the manipulator.

    -The relationship between a point, manipulator & mate connect is weird.

    It seems odd that the inputs are called vertex and everywhere else they're called points, I'll call them points:

    At each point, the manipulator orientation is remembered. Rotating the manipulator is an unknown value and not sure it's useful. I hope someone can explain why this is needed:

    "add point on drag" doesn't work if the you've rotated the triad. I usually just reset it and then leave it alone. You can see below it didn't add a point:

    Referencing other points is hard. "relative to previous point" works well. I'm at point 1 so I know I'm working at the beginning of route. Notice that it says "mate connector" for the reference. Notice that the point is highlighted and picking it will change the focus to point 0. When assigning a reference for a point, you can not pick any other points. The change focus overrides your wishes. You always have to pick a mate connector or an external point for a reference, never a point in your route. Notice the point is highlighted and picking it changes to point 0:

    Highlighting the mate connector will allow you to reassign the reference to the start. You could have easily used "relative to previous point" which is usually the preferred referencing scheme. With this approach, all subsequents points are relative to each other and update in a meaningful way:

    This comes up a lot "part of a mate connector" as a reference. I think this should be removed and changed to the mate connector in it's entirety:

    The "previous reference" below is wrong and needs to be assigned to the end point. This is how the route was created. Defining the end of a route is always more challenging. Below is the way the route was built:

    I change the reference to the mate connector defining the end of the route. Notice it's just "part of mate connector". It's the point of a mate connector. Below the offset is based on the last point or the "to" of the route. In all your routes, you have to deal with a "from" and a "to". The "to" is not easy in "route curve":

    So the simple routing above is parametric and will update correctly all day long with any change that'll come along.

    So let's break it.

    It's not hard to break the parametrics in "route curve". Let's remove the diagonal tube and route using ortho path. There are 3 choices, and I want the fewest bends, I choose a path which extends the starting offset:

    "curve reference"

    The world coordinate system is probably the worse system to use. A better approach is to use "curve reference" which establishes all orientations for points. Another way is to be careful and select point 0 correctly. When you have many routes, you'll learn to define a coordinate before starting a route.

    This is the cleanest looking plumbing when everything is in alignment:

    Make a change, I don't think "route curve" will ever be parametric.

    A quick fix, delete the errored point:

    And do it again:

    If you figure out how to make this more parametric, please let me know.

  • Chris_D_Mentes_001Chris_D_Mentes_001 Member, csevp Posts: 91 PRO

    I want to start using the Button Parameter in a feature I just made for woodworking but can't seem to find any documentation on it other then a little note in editing logic function section:

  • Nick_HolzemNick_Holzem Member Posts: 110 PRO

    The final button is missing from CPC.

  • JosefBurjetaJosefBurjeta Member Posts: 23 PRO

    If you're serious about good surface modeling, you'll eventually end up following those rules since it's the only way to achieve good surface quality and final model. 🙂

    When I first learned about them in the university (while working in Alias) I thought I could live without them and do things on my own. It didn't take long and I got back to them, study and understand them. You're not able to produce good surface from terrible inputs as I initially thought. 😁

  • jelte_steur814jelte_steur814 Member Posts: 148 PRO
    edited September 11

    I agree, and I did end up following them. but seeing them made explicit and how to work around challenges (e.g. if your surface isn't four sided) is very helpful. I was never taught surface modeling well. I've just learn't it over time.

  • GregBrownGregBrown Member, Onshape Employees Posts: 186

    Another update today! In this version we ensure that arbitrary periodic curves can now be processed and their degree can be elevated/decreased. I know this issue came up early in some folk's testing, so hopefully you can try it out again on those use cases.

    Today's version:

    https://cad.onshape.com/documents/2c2c376d9979115f9f969a08/v/8d24d6dd5f7ac9587f5d4220/e/929d02bbbb5f71c6176ac653

  • S1monS1mon Member Posts: 2,847 PRO
    edited September 11

    Hmmm. I had this 3D curve (degree 9, 9 spans, closed):

    I hit elevate once, and it comes up with this:

    This is not what I would expect.

    I was able to approximate/process a sketched circle and get something useful, but again, elevation is strange.

    Hit elevate once and we get degree 9 with 8 spans:

    Here's what I would hope to see when elevating a degree 8, 2 span closed curve (this was done by changing the approximate/process parameters):


    [edit to add this bug:]
    I'm also noticing that if I approximate/process and change the degree and number of points the resulting degree is adjusted correctly, but the resulting number of spans gets stuck.

  • S1monS1mon Member Posts: 2,847 PRO
    edited September 11

    I tried approximate/processing a sketch which is a 180-degree arc and a half-ellipse. The resultant control point arrangement is not exactly what one would hope to see, and the curvature combs are not symmetric like the input curves.


  • S1monS1mon Member Posts: 2,847 PRO

    Here I tried reference edges which are two degree 7 Bridging curves (in a symmetric arrangement). Through trial and error, I found that approximate/process to degree 8 with 16 points got the closest without adding too much wobble, but it's still far from the underlying curves.

    I can understand how the previous test with an arc and elliptical arc was challenging due to them only being G1, but this arrangement of inputs is G3. The result does seem to be symmetric, which is good, but the zig-zagging of the control points is not ideal.

  • STEGSTEG Member, User Group Leader Posts: 94 PRO

    Control over the angle of the manipulator is a must.

  • S1monS1mon Member Posts: 2,847 PRO

    Now that Control point curve is getting better at creating closed curves, Boundary surface's inability to handle closed curves is more frustrating. Clean closed curves are more useful if you can use them to create clean surfaces. Right now you have to split closed curves in order to use Boundary instead of Loft (which turns everything into multi-span degree 3 curves).

    Please vote for this improvement request.

  • Romain_JOUBERTRomain_JOUBERT Member Posts: 2

    What an amazing job ! Thanks !
    In the particular case of piping and tubing (or electrical routings), how would it be possible to add a parameter to keep automatically a given distance from the environment ? I don't even know if it's possible…

  • Jed_YeiserJed_Yeiser Member Posts: 35 PRO

    This may be a small quibble, but I've noticed that control point curve is static once processed. I'm using it to create an approximated spline through a number of edges in a configured design. When I update the configuration, the location of the seed edges change, but the Control curve output does not (until I manually edit the feature and re-process). There are ways around this problem (3D Fit Spline, creating a small/simple approximate spline FS), but It'd be great if Control point curve would update dynamically to take upstream model changes into account.

  • S1monS1mon Member Posts: 2,847 PRO

    It's been some time since the last update. I've been trying to use CP curve for a real project, but the fact that "Process" is not parametric and I need to edit the curve each time the underlying edge changes makes it not really useable.

    With more use, I'm also thinking that having a choice of a "point reference" that is local to the curve, but scales as the chord changes (à la Mutate Curve) would be really nice. Full NUV and/or slide (along the control polygon) movements would be nice, but just to start, it would be great to have the reference be the mid-point of the chord and the average plane through the rest of the CPs.

Sign In or Register to comment.