Straight Skeleton 2d Offset (Alpha) =================================== .. image:: https://github.com/user-attachments/assets/d47db67a-7f1f-4930-b8f6-b688d54c32de :target: https://github.com/user-attachments/assets/d47db67a-7f1f-4930-b8f6-b688d54c32de Functionality ------------- This node is a python wrapper of function "Skeleton Offset 2d" of CGAL https://doc.cgal.org/latest/Straight_skeleton_2/index.html. This package implements straight skeletons offset for two-dimensional polygons with holes. Simple example: .. image:: https://github.com/user-attachments/assets/8fb1ad28-4e4c-4cd5-8afe-8e0a7b5d27e5 :target: https://github.com/user-attachments/assets/8fb1ad28-4e4c-4cd5-8afe-8e0a7b5d27e5 More complex example: .. image:: https://github.com/user-attachments/assets/afa62b30-d5e4-4877-8efc-ccade1730e63 :target: https://github.com/user-attachments/assets/afa62b30-d5e4-4877-8efc-ccade1730e63 Additionally you can perform the offset connection of profiles to get a dimensional shape: .. image:: https://github.com/user-attachments/assets/72cbb4df-097c-4a2f-9b7b-413d539c642f :target: https://github.com/user-attachments/assets/72cbb4df-097c-4a2f-9b7b-413d539c642f Install dependency ------------------ To use node install additional library pySVCGAL in the Extra Nodes Section: .. image:: https://github.com/user-attachments/assets/548ad0a2-86af-4f12-9f39-230f6cda7d41 :target: https://github.com/user-attachments/assets/548ad0a2-86af-4f12-9f39-230f6cda7d41 Inputs ------ - **Vertices**, **Edges**, **Faces** - Input Mesh (2D only) or Meshes. You can use several meshes as input. .. image:: https://github.com/user-attachments/assets/b36eab6d-395c-49b5-9e43-c66c83e78d70 :target: https://github.com/user-attachments/assets/b36eab6d-395c-49b5-9e43-c66c83e78d70 - **Join mode**. Preprocess source meshes. **Split**, **Keep**, **Merge**. .. image:: https://github.com/user-attachments/assets/eb3f3937-466e-4621-9edf-25a07f837620 :target: https://github.com/user-attachments/assets/eb3f3937-466e-4621-9edf-25a07f837620 - **Split** - separate source meshes into independent islands and process them individually. Results boundaries can overlaps. - **Keep** - If source meshes has several islands then they has influence. - **Merge** - Combine all islands to influence all islands. .. image:: https://github.com/user-attachments/assets/3cc4b707-2068-4743-8c81-2b707edfc8ef :target: https://github.com/user-attachments/assets/3cc4b707-2068-4743-8c81-2b707edfc8ef - **Combine mode**. How to combine shapes and profiles. .. image:: https://github.com/user-attachments/assets/130fc055-a563-48fe-a118-8109dc1b7f96 :target: https://github.com/user-attachments/assets/130fc055-a563-48fe-a118-8109dc1b7f96 - **one dot** - combine one shape and one profile. If no profile then skipped - **three dots** - combine every shape with all profiles. .. image:: https://github.com/user-attachments/assets/491362a5-e47f-4ee4-b1e1-2348fceab2d9 :target: https://github.com/user-attachments/assets/491362a5-e47f-4ee4-b1e1-2348fceab2d9 - **Matrixes** - Apply matrixes to the results parts if Shape Mode or Result Mode sets with SPLIT/MERGE .. image:: https://github.com/user-attachments/assets/c045d9d8-41a6-47da-99d5-dfca194035bb :target: https://github.com/user-attachments/assets/c045d9d8-41a6-47da-99d5-dfca194035bb .. image:: https://github.com/user-attachments/assets/17928457-8849-4180-baa4-7897f0263090 :target: https://github.com/user-attachments/assets/17928457-8849-4180-baa4-7897f0263090 - **Shapes mode**. **Original**, **Exclude Holes**, **Invert Holes**. .. image:: https://github.com/user-attachments/assets/51292f9a-44bb-40e3-adda-d80cfc303602 :target: https://github.com/user-attachments/assets/51292f9a-44bb-40e3-adda-d80cfc303602 - **Original** - Process original meshes. - **Exclude holes** - process only external boundaries. - **Invert Holes** - process holes as islands, exclude external boundaries from process. .. image:: https://github.com/user-attachments/assets/f3b577f9-25c1-424b-ac55-0b7ceb754877 :target: https://github.com/user-attachments/assets/f3b577f9-25c1-424b-ac55-0b7ceb754877 - **Offsets**, **Altitudes**. **Offsets** - distance from contour in plane (one can use negative value). **Altitudes** - results heights in Z axis (one can use negative value). .. image:: https://github.com/user-attachments/assets/a6d31042-4564-4b38-a90c-ab8d32f8109e :target: https://github.com/user-attachments/assets/a6d31042-4564-4b38-a90c-ab8d32f8109e If you do not connect any lists of floats values then this value will be used for every objects connected into this node: .. image:: https://github.com/user-attachments/assets/378b3a91-a5f1-4660-9c81-81e196b063ee :target: https://github.com/user-attachments/assets/378b3a91-a5f1-4660-9c81-81e196b063ee - **Profile faces indexes**. Only used in **Bevel mode**. List of indexes to connect offsets. If you use some mesh objects you can use profile faces to connect these offset as in profile shape: .. image:: https://github.com/user-attachments/assets/1d73265a-ca29-40bc-a460-04a9dcab39d8 :target: https://github.com/user-attachments/assets/1d73265a-ca29-40bc-a460-04a9dcab39d8 - **Profile close mode**. Only used in **Bevel mode**. This option affects the way the profile points are connected. .. image:: https://github.com/user-attachments/assets/07570dd0-d855-4135-a835-29775adf83ea :target: https://github.com/user-attachments/assets/07570dd0-d855-4135-a835-29775adf83ea - **Close** - Profile forms closed shape. The first and last points are connected. The shape is closed from all sides. .. image:: https://github.com/user-attachments/assets/81804a13-c392-48f9-9cc6-c9401e013928 :target: https://github.com/user-attachments/assets/81804a13-c392-48f9-9cc6-c9401e013928 - **Open** - Profile forms opened shape. The first and last points do not connect .. image:: https://github.com/user-attachments/assets/30697e95-8c08-4e65-bf3b-9442c880ea03 :target: https://github.com/user-attachments/assets/30697e95-8c08-4e65-bf3b-9442c880ea03 - **Pair** - List items are joined in pairs. If an index is out of offset index range, the pair is completely ignored. Ex.: [1,2,3,4,5,6,7,8,9,0] will be [1,2],[3,4],[5,6],[7,8],[9,0] and you get the bands .. image:: https://github.com/user-attachments/assets/a72f8880-daf3-4062-adda-1a902a2d0375 :target: https://github.com/user-attachments/assets/a72f8880-daf3-4062-adda-1a902a2d0375 - **Mask of objects** - Mask hide objects. If element of boolean mask is True then object are hidden. If length of mask is more than length of objects then exceeded values will be omitted. .. image:: https://github.com/user-attachments/assets/112402bd-e369-468e-84cd-b8537611bda8 :target: https://github.com/user-attachments/assets/112402bd-e369-468e-84cd-b8537611bda8 You can get this result with boolean mask too .. image:: https://github.com/user-attachments/assets/655d5abe-cfab-40c1-873d-ae11f86f6eca :target: https://github.com/user-attachments/assets/655d5abe-cfab-40c1-873d-ae11f86f6eca Parameters ---------- .. image:: https://github.com/user-attachments/assets/40187fad-ab8f-4e01-b299-c19d3c383f5a :target: https://github.com/user-attachments/assets/40187fad-ab8f-4e01-b299-c19d3c383f5a - **Result Type**. **Contours**, **Faces**, **Bevel**, **Skeleton**. .. image:: https://github.com/user-attachments/assets/c9fb9213-649b-4e31-a608-22af8d84b461 :target: https://github.com/user-attachments/assets/c9fb9213-649b-4e31-a608-22af8d84b461 - **Contours** - results are only edges. - **Faces** - Results are faces with holes. - **Bevel** - Offsets are connected in shapes or figures. - **Skeleton** - Show Straight Skeleton scheme. .. image:: https://github.com/user-attachments/assets/3f04fc16-212e-457d-9dc2-3b56a0284d5f :target: https://github.com/user-attachments/assets/3f04fc16-212e-457d-9dc2-3b56a0284d5f - **Results Join Mode**. **Split**, **Keep**, **Merge**. .. image:: https://github.com/user-attachments/assets/64594acc-667e-4547-bee5-49004dc9f9b6 :target: https://github.com/user-attachments/assets/64594acc-667e-4547-bee5-49004dc9f9b6 - **Split** - Separate all results into independent meshes. - **Keep** - If some of objects has several independent meshes then they will be as one object on output. - **Merge** - This node will merge all vertices, edjes, and faces into a single object. Results in merge mode can be overlapped. .. image:: https://github.com/user-attachments/assets/e469b38b-a0de-4e7a-a595-a027e77aae48 :target: https://github.com/user-attachments/assets/e469b38b-a0de-4e7a-a595-a027e77aae48 - **Force z=0.0** - To force use meshes as planes. Useful for ex. bezier 2D curve some time take Z not zero. .. image:: https://github.com/user-attachments/assets/171ee664-1f24-4f00-aed7-4d69ab0f8e75 :target: https://github.com/user-attachments/assets/171ee664-1f24-4f00-aed7-4d69ab0f8e75 - **Only Tests** - If you have a hi poly mesh like imported SVG file one can save time and do not Skeletonize all meshes before fix all. You can connect viewer draw into the "Wrong Contours Verts" with red color or any color you prefer for errors to see any wrong contrours. Red dots are wrong contours. - **Verbose** - Enabled - Show process messages in console while process meshes. Disabled - Hide any process messages. .. image:: https://github.com/user-attachments/assets/b5c4590d-8eff-4e32-8626-6c8cd8be0f6d :target: https://github.com/user-attachments/assets/b5c4590d-8eff-4e32-8626-6c8cd8be0f6d - **Use cache** - Store Straight Skeleton 2D calculations in cache. If you pass the geometry for calculation a Straight Skeleton a second time, the result will be taken from the cache. This is a new feature so this is disabled by default. If the setting is disabled, the cache is not used. - **Detailed split** - Work only in Bevel mode. Additional separation of the object by profile faces in **split** mode. .. image:: https://github.com/user-attachments/assets/69670c31-d4e8-42ff-936f-699500f41359 :target: https://github.com/user-attachments/assets/69670c31-d4e8-42ff-936f-699500f41359 Output sockets -------------- - Vertices, Edges, Faces - Results meshes. - Wrong Contour Verts - If source meshes can't be processed then this socket will output vertices of that contours (ex. if meshes contours is self intersection) .. image:: https://github.com/user-attachments/assets/18cc453d-c1a7-4692-a5b4-ba2e67eb7203 :target: https://github.com/user-attachments/assets/18cc453d-c1a7-4692-a5b4-ba2e67eb7203 Performance ----------- If you have a low poly model then no problem - you can work with it in real time: .. raw:: html If you try high poly like Besier 2D with many points and hi resolution (1) then better is to turn off (2) update sverchok nodes while editing objects and run process manually (3): .. image:: https://github.com/user-attachments/assets/429e6571-fe73-4fc7-b242-4f038f670871 :target: https://github.com/user-attachments/assets/429e6571-fe73-4fc7-b242-4f038f670871 Also you can use cache mode (it is experimental property for a while!!!): .. image:: https://github.com/user-attachments/assets/2e8eaadc-ac14-4789-826a-3bf992ebeb7d :target: https://github.com/user-attachments/assets/2e8eaadc-ac14-4789-826a-3bf992ebeb7d Examples -------- Boundary background contour: .. image:: https://github.com/user-attachments/assets/f6cf099c-1e3a-47ac-be87-e6e9b44b4683 :target: https://github.com/user-attachments/assets/f6cf099c-1e3a-47ac-be87-e6e9b44b4683 Inner Offset .. image:: https://github.com/user-attachments/assets/78568725-254e-469c-98bd-50ffb24321b0 :target: https://github.com/user-attachments/assets/78568725-254e-469c-98bd-50ffb24321b0 Extrude with profile faces: .. image:: https://github.com/user-attachments/assets/e7278c18-18aa-4e3c-8897-71369f8566b9 :target: https://github.com/user-attachments/assets/e7278c18-18aa-4e3c-8897-71369f8566b9 DEVELOPMENT ----------- If you have skills for work with CGAL see: https://github.com/satabol/SVCGAL