sketchucation logo sketchucation
    • Login
    ℹ️ Licensed Extensions | FredoBatch, ElevationProfile, FredoSketch, LayOps, MatSim and Pic2Shape will require license from Sept 1st More Info

    Solid Trim Tool

    Scheduled Pinned Locked Moved Plugins
    19 Posts 7 Posters 1.2k Views 7 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • TIGT Offline
      TIG Moderator
      last edited by

      To keep the layers unchanged edit Jim's script with Notepad or a similar plain-text editor, around line#81 you need to change this

      def_to_keep.name = @model.definitions.unique_name(name)
      grp = @first_picked.trim(@last_picked)
      
      

      to this

      layer=@last_picked.layer
      def_to_keep.name = @model.definitions.unique_name(name)
      grp = @first_picked.trim(@last_picked)
      grp.layer=layer
      

      The two extra lines saving/using the original's layer... so that it will retain the original layering of the now-trimmed-object.

      Also, if you find yourself always purging the original unused untrimmed version, then you can further adjust the code, just before it says ' @model.commit_operation' insert these lines of code reading

      if UI.messagebox("Delete Unused Definition?",MB_YESNO,"")==6
          def_to_keep.entities.erase_entities(def_to_keep.entities.to_a)
      end
      @model.commit_operation
      

      On 'Yes' it will remove the earlier definition from the Component Browser's list after all instances of it have now been set to be ' new_def'... This will save you having to purge it later manually...

      TIG

      1 Reply Last reply Reply Quote 0
      • Dave RD Offline
        Dave R
        last edited by

        Thank you TIG! Both of those work like a charm.

        Etaoin Shrdlu

        %

        (THERE'S NO PLACE LIKE)

        G28 X0.0 Y0.0 Z0.0

        M30

        %

        1 Reply Last reply Reply Quote 0
        • R Offline
          Robert Lang
          last edited by

          Without the plug in you can simply select the new group and explode it. After the explode, all the geometry is selected so you can right click and select "Make Component". Give it the exact same name it had to begin with and all is well.

          Bob Lang

          1 Reply Last reply Reply Quote 0
          • Dave RD Offline
            Dave R
            last edited by

            That does work but it's extra steps.

            Etaoin Shrdlu

            %

            (THERE'S NO PLACE LIKE)

            G28 X0.0 Y0.0 Z0.0

            M30

            %

            1 Reply Last reply Reply Quote 0
            • TIGT Offline
              TIG Moderator
              last edited by

              Also you'd need to reassign the original layer manually [if you remembered it].

              So Jim's tool - with my tweaks - means the trimmed component >> group is automatically made back into a component of the same name [including all instances updated], it's kept on its original layer, and you have the option of removing the now unused component from the browser or keeping it if you might like to reuse it somehow... ☀

              TIG

              1 Reply Last reply Reply Quote 0
              • Dave RD Offline
                Dave R
                last edited by

                And after exploding, you'd have to move the geometry back to Layer 0 where it should be.

                I have a keyboard shortcut for Jim's plugin and now, with the modification it is absolutely painless for even the most simple trim operations.

                Etaoin Shrdlu

                %

                (THERE'S NO PLACE LIKE)

                G28 X0.0 Y0.0 Z0.0

                M30

                %

                1 Reply Last reply Reply Quote 0
                • Dave RD Offline
                  Dave R
                  last edited by

                  TIG, out of curiosity, assume that there would never be a need to keep the original version of the component. what would the code be to make the script automatically purge the unused version?

                  Etaoin Shrdlu

                  %

                  (THERE'S NO PLACE LIKE)

                  G28 X0.0 Y0.0 Z0.0

                  M30

                  %

                  1 Reply Last reply Reply Quote 0
                  • TIGT Offline
                    TIG Moderator
                    last edited by

                    Remove the two lines ' if...' and ' end' at the start/end of the added code, so that the only thing you add is def_to_keep.entities.erase_entities(def_to_keep.entities.to_a) before the @model.commit_operation

                    Then there's no choice - the original object's shape is lost... 😮

                    TIG

                    1 Reply Last reply Reply Quote 0
                    • Dave RD Offline
                      Dave R
                      last edited by

                      Thanks, TIG.

                      If I were using other tools to do the same thing I would do with Trim and Keep I wouldn't have the original shape either. So far that's never been a problem.

                      Etaoin Shrdlu

                      %

                      (THERE'S NO PLACE LIKE)

                      G28 X0.0 Y0.0 Z0.0

                      M30

                      %

                      1 Reply Last reply Reply Quote 0
                      • TIGT Offline
                        TIG Moderator
                        last edited by

                        OK...
                        If you ever need to delete a group/component in code you can use
                        * defn.entities.erase_entities(def_to_keep.entities.to_a)
                        or to be even shorter
                        * defn.entities.clear!
                        !!!

                        Calling it * def_to_keep is somewhat whimsical as it's the one to go !
                        Which is actually the same thing - but perhaps easier to grasp ?!
                        Always provided that it's inside a model.start_operation()...model.commit_operation block

                        TIG

                        1 Reply Last reply Reply Quote 0
                        • bmikeB Offline
                          bmike
                          last edited by

                          thanks TIG, marked to come back and tinker with code later....

                          mike beganyi design + consulting llc

                          1 Reply Last reply Reply Quote 0
                          • D Offline
                            david.
                            last edited by

                            LIL

                            Seems like this thread is a more general topic than Woodworking. I was wondering if it should/could be moved to the SU Discussions subforum? Just a thought...

                            1 Reply Last reply Reply Quote 0
                            • TIGT Offline
                              TIG Moderator
                              last edited by

                              I've moved this thread into Plugins, which is probably a more logical home for it...

                              TIG

                              1 Reply Last reply Reply Quote 0
                              • 1 / 1
                              • First post
                                Last post
                              Buy SketchPlus
                              Buy SUbD
                              Buy WrapR
                              Buy eBook
                              Buy Modelur
                              Buy Vertex Tools
                              Buy SketchCuisine
                              Buy FormFonts

                              Advertisement