• Login
sketchucation logo sketchucation
  • Login
ℹ️ GoFundMe | Our friend Gus Robatto needs some help in a challenging time Learn More

[Plugin] Hatchfaces (v1.8 beta) UPDATED 15-Dec-2012

Scheduled Pinned Locked Moved Plugins
360 Posts 41 Posters 228.5k Views
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.
  • J Offline
    jolran
    last edited by 22 Aug 2011, 07:35

    A lot of experiments going on. I welcome ideas and possible options that could be added or improved πŸ’­
    look at the dialogs what is planned, already.

    Got the tiling going pretty nicely. (Not from file yet) It's quite slow if having complex patterns. Fewer (tile) copies is considerably faster regardless of the sum of edges πŸ˜• So crosshatching may be restricted to linehatches only. Rather create more patterns=larger library than doing a 2nd computation? Patterns with faces is slowest.

    Since the goal is to have a big library of hatches, they may be difficult to remember by name. So I guess webdialog is the best solution. Im not to sure about that one yet, though. Havent done any webdialogs, yet. It might be a very step learning curve to get it right for all plattforms ❓ On the pic there is a inputbox version with dropdownlist. For round 1 that might be the solution, there are a lot of quirks to sort out first..

    http://sketchupapi.blogspot.com/2011/07/gofaster-parameter.html
    FYI: saw this post on API blog and performed som tests with this method(not the pic, more complex pattern), and boy what an speed increase!
    On test 1: 5.226 seconds
    On test 2: 2.793 seconds! Just typing "true" in the model.start_operation('bla bla', true)
    On test 3: 2.496 seconds. Same test as 2, but outliner closed.

    There are some issues with this method though..

    http://forums.sketchucation.com/viewtopic.php?f=180&t=25305

    This is of course interesting as well. But maybe before doing any performance increases I will work on the features.


    dialogs.jpg

    1 Reply Last reply Reply Quote 0
    • J Offline
      jolran
      last edited by 22 Aug 2011, 11:17

      Excellent TIG!

      So far so good! Havent failed yet. Works in off axis, strange rotations etc.

      Needs some more testing of course, but THANK YOU! THANK YOU!
      Things can probably move forward now.

      Oh Yeah, and the code is much more streamlined, as you call it. πŸ‘

      1 Reply Last reply Reply Quote 0
      • K Offline
        kaas
        last edited by 23 Aug 2011, 09:34

        Hello Jolran,

        First of all; thanks again a million for your effort and to those who are helping you! It's a much much welcomed addition to Sketchup! I can't wait to test it out! πŸ‘

        I think your Photoshop dialog already has all the options we could want. Maybe you could add a target layer-option for the hatches? The visual webdailog of course would be the most user-friendly but I wouldn't mind the non-visual dialog. You could always print out the patterns + names on a sheet of paper instead.

        @jolran said:

        Got the tiling going pretty nicely. (Not from file yet) It's quite slow if having complex patterns.

        I wouldn't be too much concerned with the performance. The time for the calculation of hatches will be much less compared to having to draw them yourself by hand! The plugin itself always be a great time-saver and will save us from dull repetitive work.

        Greetings,

        Max

        1 Reply Last reply Reply Quote 0
        • J Offline
          jolran
          last edited by 23 Aug 2011, 10:57

          Hi Kaas!

          Finaly someone answered πŸ˜„

          @unknownuser said:

          Maybe you could add a target layer-option for the hatches?

          That should be possible. You do mean put the hatch in a layer already existing in the model?
          Anyway I think layers are pretty flexible to work with.

          @unknownuser said:

          You could always print out the patterns + names on a sheet of paper instead.

          That is a good solution, if going for inputboxes. I guess file browser is also possible, like TIG's 2d tools hatches.

          Thank you for the inputs, and please don't hesitate to add more requests.

          1 Reply Last reply Reply Quote 0
          • K Offline
            kaas
            last edited by 23 Aug 2011, 11:58

            @jolran said:

            You do mean put the hatch in a layer already existing in the model?

            Yes. Most people will work with a template file which already contains standard layers, styles, scenes etc. I guess there is no need to over-complicate the code at this stage for adding new layers on the fly.

            1 Reply Last reply Reply Quote 0
            • J Offline
              jolran
              last edited by 23 Aug 2011, 13:52

              @unknownuser said:

              I guess there is no need to over-complicate the code at this stage for adding new layers on the fly.

              I don't swear by it, but it should be relatively straightforward to get a list of layers pop up in the inputbox.
              I think it is a good idea you have, otherwise ALL hatches will end up into 1 layer unless moved manualy.
              Putting "hatchlayer" as default in inputbox means one won't have to select layers if happy with that layer.

              I put this on the todo list πŸ˜„

              1 Reply Last reply Reply Quote 0
              • J Offline
                jolran
                last edited by 9 Sept 2011, 19:26

                Good evening.

                Things are moving forward, but have been hooked on webdialogs and speed performance lately.

                All in all, all features I can think of is implemented. Loading from file and tiling with some options to it, is ok.(not from some dialog, in script)

                The "tech" part:
                Some sort of dialog has to be made. I'm thinking webdialog, but quite scared of diving into that part actually πŸ˜•
                But it will be difficult using dropdownlist with a long list. And I don't know if a list can be updated automatically if user add new components ❓ I guess UI.openpanel can only be used for images?

                Also performance is an issue.. Things can get quite slow sometimes, maybe to slow..

                The plugin tiles the group in 1 direction inside group1. Then it copies group1 in the cross direction.

                Copying groups are fast. Exploding and intersections is slow. I don't know if there is any way to speed up thoose things.
                Is there any way to copy and tile entities collection without using groups ❓

                Have also been experimenting with textures+lines combinations to "get away" with less geometry, but the result is less then satisfactory. Look pics:

                More artistic questions arise, what is needed from hatches anyway?
                Have been looking for ISO standards but can't find information regarding exact size of patterns. If you look at Doublecad for ex. When creating a hatch, the sizes of pattern often need to be adjusted. So what is the scaling standards? This could be of importance regarding speed. Cause, the bigger patter=less geometry >> speed increase.

                Any tips would be welcome. πŸ˜„


                texvsvector.jpg

                1 Reply Last reply Reply Quote 0
                • TIGT Offline
                  TIG Moderator
                  last edited by 9 Sept 2011, 22:26

                  If you go down the texture route then my 2dTools '2dHatching' already does much of this [without scaling etc]... with a fairly comprehensive list of tileable .PATT clone .jpg files...

                  TIG

                  1 Reply Last reply Reply Quote 0
                  • J Offline
                    jolran
                    last edited by 10 Sept 2011, 06:54

                    Yeah, thanks. I have been looking at your plugin, TIG. There is no point in reinventing the wheel that's rolling well, so I will go the "line hatching" way. If it wasen't clear, I'm not convinced textures are good enough for CD's. Inconsistency in line widths..

                    So far as I can see, 2dtools imports a jpg texture, while hatchfaces will be working with skp.files.
                    And if I understand API docs right, you can only use images for UI:openpanel.

                    The strategy I'm having is to have 1 color method for linehatching and another non-color method.
                    Non color method will be standard-mode, and it's there where I aim to increase speed somehow.

                    πŸ’­ Plan A is to find a solution to create all edges inside 1 group without the need for exploding, then use face-classify to remove unwanted edges.

                    Plan B is create groups, intersect with face-clone(gents) and remove unwanted edges with face-classify points. That way there is no need to explode large amounts of groups. But intersection can be quite slow...

                    Plan A need some thinking, and there is quite a lot of unnecessary geometry created as well. A big square, size of diagonal to compensate for rotations around center...
                    It's difficult to do rotations prior to tiling. Unless doing zick-zack copying πŸ˜•

                    1 Reply Last reply Reply Quote 0
                    • TIGT Offline
                      TIG Moderator
                      last edited by 10 Sept 2011, 10:28

                      UI.openpanel(title,folder,type) simply opens a file-browser, starting in the given folder and returns the selected file [if any] - so you could access whatever file-type[s] you want. The API example is simply showing one method..,

                      My '2dHatching' happens to use jpg files that are kept in a special subfolder - it then uses the one of them that's been selected as the texture for a [new] material that's then applied to any picked face. It just so happens that I had all of the typical CAD PATTs as tileable jpg files! IF I had had them as tileable SKPs I would have simply changed my code to suit that file-type...

                      Idea...
                      You know the bb=face.bounds and from that cent=bb.center and diag=bb.diagonal
                      Make your hatching group in the face.parent.entities, at the 'origin', laid flat.
                      Its center at the origin.
                      Draw you hatching from min to max based on the diag/2 used to offset points in x/y.
                      Now you have a load of lines in a group that will always exceed the bounds of the face is overlaid on it.
                      The group is not yet aligned with the face.plane.
                      Transform the group axes
                      group.transform!(Geom::Transformation.new(ORIGIN, face.normal))
                      Now the group's plane parallel to the face.plane
                      Move the group
                      group.transform!(Geom::Transformation.new(cent)).
                      Now the group is located with the same center as the face.
                      You now need the quickest way to trim your hatching to the face's loops...
                      Use intersect_with() on the group.entities and the face.edges+[face] this should then split all of the groups edges as the cross the face's perimeter edges.
                      Now iterate through the edges in the group and inspect them.
                      Use face.point_classify(mid) on the mid-point of every edge [we already have code for finding this from earlier exchanges].
                      As all edges have already been split by the intersection with face's perimeter edges only those that are on the face are to be kept - all others are then collected and erased en mass after the inspection.
                      So now we should have a group overlaying the face with its hatching lines all trimmed to the perimeter of the face, including any 'holes'.
                      No exploding or cloning required...

                      Next... IF you want the hatching to have a 'perimeter' you can replicate the face.edges within the group.entities, transforming each edges vertices to match the group.transformation.inverse ?
                      IF you then want that perimeter to be split at every meeting with a hatching line then you can intersect_with() the group.entities with group.entities.to_a [you may find you need to do this more than once to ensure all are fully split?]. I can see little advantage in adding this??

                      Optionally Exploding the group over the face will merge the edges with the then split face

                      I can't see why you'd want faces for the hatching inside the group... BUT if you do then you can clone the face inside the group and intersect the group.entities with the cloned_face....

                      For cross-hatching simply do the hatching twice and then group the two hatching groups into one ?

                      TIG

                      1 Reply Last reply Reply Quote 0
                      • K Offline
                        kaas
                        last edited by 10 Sept 2011, 12:10

                        @jolran said:

                        Things can get quite slow sometimes, maybe too slow..

                        More artistic questions arise, what is needed from hatches anyway?
                        ... This could be of importance regarding speed. Cause, the bigger patter=less geometry >> speed increase.

                        Any tips would be welcome. πŸ˜„

                        I can only speak for myself but I'm very interested in this plugin regardless of any speed issue. At the moment I draw the hatches in SU by hand. I can't imagine your plugin would be slower than doing this 'boring' process by hand.

                        As long as people can edit the hatch-SU-files themselves as well they can choose to use hi-res hatches or low-res and by doing so control the speed and add a personal style.

                        Going into the path of using textures as hatches would be a pity because people sometimes have to export LO files to dxf/dwg for use by other contractors who use Autocad etc. Hatched lines would convert into cad-lines. Textures would not.

                        Greetings and πŸ‘ ,

                        Max

                        1 Reply Last reply Reply Quote 0
                        • J Offline
                          jolran
                          last edited by 10 Sept 2011, 12:57

                          @unknownuser said:

                          UI.openpanel(title,folder,type) simply opens a file-browser, starting in the given folder and returns the selected file [if any] - so you could access whatever file-type[s] you want. The API example is simply showing one method..,

                          Thats good to know when dealing with dialogs later on.

                          Regarding your idea, I will have a look at that, TIG. I'm not sure I'm quite following what you mean. I am using skp.component patterns loaded from file and place them on the face and do the tiling on required up/down vectors. Based on face diagonal length.

                          Anyway I will reread you idea to see more clearly what you mean. Thanks TIG.

                          Max. Thanks for giving feedback πŸ˜„

                          I'm not going the texture way, so don't worry about that. The oportunity to be able to export the line geometry is what I had in mind as well. But mostly, it gives better and more predictable results when printing.
                          Also I won't experiment with performance(I hope)for to long. We are dealing with creating 2d-3d-geometry and not vectorgraphics, so that has to be taken in consideration for this plugin.

                          1 Reply Last reply Reply Quote 0
                          • J Offline
                            jolran
                            last edited by 10 Sept 2011, 15:52

                            Hmm.. reading my post again I think I wasent clear about how the plugin works at the moment, so here is a more illustrated explanation.
                            It looks like you where giving advice about linehatches, before TIG? I think we have that one working already.
                            Now it's pattern-time.

                            Been looking at sin and cos 😲 for calculating rotations and how relations of borders behave when tiling rotated geometry. To be able to copy less geometry.
                            Not an easy task. Also can't figure out a way to get length and width of face anyway so I will know how many copies to be made.

                            Bounds.diagonal and center is good and consistent mesures. But NOT bounds.width or height, even if it's a face=2d bounds! It will still mesure from a 3d boundingbox compared to axes. So if the face is tilted youre scr@w@d..

                            Here's how it works at the moment anyway. Just the tiling. After tilings done. One can use proper method of intersecting and
                            remowing unwanted edges. Have tried different methods of those..


                            geos.jpg

                            1 Reply Last reply Reply Quote 0
                            • TIGT Offline
                              TIG Moderator
                              last edited by 10 Sept 2011, 15:58

                              I was speaking about 'line-hatch' - I thought you were looking at speeding everything...

                              However, all you do differently for the 'component-hatch' is add component-instances to the [initially flat] group, set at the center and the with copies offset in x/y based on the 2d component's bounds.
                              The spacing of the instances is within the same limits as the 'line-hatch' version.
                              Then you explode the instances in the group and proceed with the intersect_with() etc as with line-hatch........

                              TIG

                              1 Reply Last reply Reply Quote 0
                              • J Offline
                                jolran
                                last edited by 10 Sept 2011, 17:05

                                @unknownuser said:

                                I was speaking about 'line-hatch' - I thought you were looking at speeding everything...

                                Ahh, ok. I understand. 😳

                                @unknownuser said:

                                Then you explode the instances in the group and proceed with the intersect_with() etc as with line-hatch........

                                Yeah, that's what I thought as well. Will try to get things rolling..

                                Thanks.

                                1 Reply Last reply Reply Quote 0
                                • J Offline
                                  jolran
                                  last edited by 10 Sept 2011, 19:28

                                  Been trying more realistic sizes of patterns. Noticed I was testing on a face 30 meters long πŸ˜„
                                  Times are a little better now, unless using circles with plenty of geometry..
                                  This is on a pole 3m high. Remember time will be aprox the same if the pole would be 3 m wide...

                                  Now, still haven't found ISO standards for patterns so I'm eyeballing size here.. If someone find info regarding that please mention it here.

                                  Colors on edges added.


                                  tests.jpg

                                  1 Reply Last reply Reply Quote 0
                                  • TIGT Offline
                                    TIG Moderator
                                    last edited by 10 Sept 2011, 20:28

                                    Look at the jpg PATTerns in my 2dHatching subfolder - these are most of the standard ACAD PATT files - note how they are all relatively simple line patterns - NO real circles!
                                    Simple hatch/cross-hatch are 'simple' - the concrete, grain etc are more complex - but still relatively simple tileable sets of a few edges... πŸ˜•

                                    TIG

                                    1 Reply Last reply Reply Quote 0
                                    • J Offline
                                      jolran
                                      last edited by 11 Sept 2011, 06:45

                                      Yeah, you are right. The standard patterns are not that dense. The ones in "Hatchingextra" folder is quite dense, but not extreme.
                                      Think I'll drop the "performance hysteria" for a moment, and continue with the rest of the job πŸ˜‰

                                      1 Reply Last reply Reply Quote 0
                                      • TIGT Offline
                                        TIG Moderator
                                        last edited by 11 Sept 2011, 12:19

                                        The main folder is based on most of the ACAD standard PATTs.
                                        The '..extras' folder contains mostly 'non-standard' hatches.

                                        TIG

                                        1 Reply Last reply Reply Quote 0
                                        • J Offline
                                          jolran
                                          last edited by 12 Sept 2011, 07:00

                                          @unknownuser said:

                                          The '..extras' folder contains mostly 'non-standard' hatches

                                          Ah, ok. That make sence.

                                          Have been looking at the PAT format though.
                                          http://docs.autodesk.com/ACD/2010/ENU/AutoCAD%202010%20User%20Documentation/index.html?url=WS73099cc142f4875513fb5cd10c4aa30d6b-7e57.htm,topicNumber=d0e368209

                                          Hmm, wonder if it would be possible with an importer of autcocad-patterns.. Major project perhaps. πŸ˜•

                                          Got my hands busy with learning html, css, js and jquery anyway πŸ˜„

                                          1 Reply Last reply Reply Quote 0
                                          • 1
                                          • 2
                                          • 11
                                          • 12
                                          • 13
                                          • 14
                                          • 15
                                          • 16
                                          • 17
                                          • 18
                                          • 13 / 18
                                          • First post
                                            Last post
                                          Buy SketchPlus
                                          Buy SUbD
                                          Buy WrapR
                                          Buy eBook
                                          Buy Modelur
                                          Buy Vertex Tools
                                          Buy SketchCuisine
                                          Buy FormFonts

                                          Advertisement