sketchucation logo sketchucation
    • Login
    🛣️ Road Profile Builder | Generate roads, curbs and pavements easily Download

    [Plugin] importDXFtext

    Scheduled Pinned Locked Moved Plugins
    165 Posts 18 Posters 86.1k Views 18 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.
    • uwesketchU Offline
      uwesketch
      last edited by

      @tig said:

      Let me know... I can only say 'no'...

      Will do. Indeed 😄

      1 Reply Last reply Reply Quote 0
      • uwesketchU Offline
        uwesketch
        last edited by

        I have now compared a few files we receive regularly and a lot of the imported text looks fine.
        I have compiled below a list of differences and have created a dxf showing these, so that you can readily reproduce the cases. (The dxf file is attached at the end.)

        The color indications below give the link to the pictures.
        The post is a bit lengthy. But for some points I think it took me more time to document than it will take to implement the change in the plugin 😉
        Btw, the print screens were done in Trimble connect where I uploaded the dxf file and the skp file with the imported text.

        Let me know what you think.

        • Currently the 3D-text are all groups. Could instead components be created? Then put the text into the instance name and description (in case too long). Like this we can see the original text in the outliner and component list

        Import Issue 3D-text component vs group outliner.png
        Import Issue 3D-text component vs group ElementInfo.png

        • (Orange marked) it seems that a leading space is not respected. For instance for m², the dxf contains " m".
          If I create a 3D-text for " m" manually in SketchUp, this is converted into 3D-text component for "m", but the origin of the component is positioned to the left of the bounding box.
          So creating SketchUp 3D-texts as components should solve the issue, if the origin is used to place the 3D text at the position as defined in the dxf.

        • (blue marked) a minus sign (dash) as a value of a block Attribute definition is placed too low compared to the text beside it.
          See DUMMY_561, which contains a value being a dash "-".
          The issue here is, that SketchUp creates a boundingbox around the minus sign and the origin of the created component is on the lower left corner minus sign.
          So the minus sign is placed too low.
          Possible solution: always add an M at the end or beginning (when aligned right) of the string for 3D-text.
          Then shift the origin of the 3d-Text component along the Y-axis to the lower left corner of the M. Then delete the M from the generated 3D text.

        • (green marked) some 3D-Texts are positioned a bit too high.
          Reason is, that they contain a p, y, j or g and then the lower end of 3D-text bounding box is not on the writing base line.
          Currently the lowest point of the letter is positioned on the writing base line of normal text - meaning too high.
          This could be corrected by shifting the 3D-text box a bit down. Or if 3D-text components are created, then shift the origin a bit up.

        Result after import
        Result as defined in DXF

        • (brown marked) dxf superscript and subscript commands are not recognized.
          Superscripts are used in architetural drawings to indicate the mm number.
          "20 superscript 5" means 20.5cm, "2.92 superscript 5" means 2.925m
          Does UTF-8 have codes for superscripts which can be used? For example U+2075 (8309) is the unicode number for superscript 5.
          See https://en.wikipedia.org/wiki/Unicode_subscripts_and_superscripts
          Alternatively a separate 3D-text could be created for the superscript signs like:
          Make the superscript or subscript number half the height of the normal text and shift by half a font height up or down. Like this it does not get above or below normal text.

        superscript as shown after import
        Result as defined in DXF

        • (purple marked)** add a line break in the 3D Text** so it gets not wider than indicated in the dxf file. Use the MTEXTBEGIN and MTEXTEND definition of the dxf? (assuming this defines the width of the MText box.
          text not wraped after import
          Result as defined in DXF

        2nd example: (I think this is a bit tricky to implement):
        no text wrapped
        Result as defined in DXF

        • (grey marked) create SketchUp dimensions from DXF dimensions.
          Use only the begin and end point and the position of the line from the dxf.
          For the arrow head, just try to figure it out from the dxf and use the Sketchup model default, if in the dxf we cannot find the three possibilities given in SketchUp.
          For texts with a line to a point like heights, create a dimension where the line is not offset from the starting point and choose text position "start outside" and no arrow head or a dot.
          Or create a radius dimension and type in the text and choose an arrow or point as arrow head.
          Set the dimension text in SketchUp to what the MText in dxf indicates.

        only MText is imported from dimensions
        Result as defined in DXF

        • (red marked) MText rotated: currently MText that is rotated is not rotated during import. Can this be done?
          Currently dimension texts are also always imported as horizontal as they are MTEXTs. Could one rotate the dimension text to be along the dimension lines?
          However, if dimensions are imported as such in SketchUp, then this is not important anymore.

          Btw, text that comes from a block attribute is rotated correctly already.

        MText imported only horizontally
        Result as defined in DXF


        DXF file with text import issue examples

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

          ADDRESSED

          The following are fixed and will be in an update soon...

          'Orange' leading space missed e.g. in m² - first thought because leading & trailing spaces are trimmed [strip] from the text string, but when I thought I'd fixed that issue persisted.
          Finally fixed it - silly typo.

          'Blue' minus sign too low down. Trapped for -ve signs and move them up.

          'Green' error - text containing hanging parts set to high.
          Trapped for qypgj and shunted up a little.

          'Brown' superscripts 0-9 now implemented, previously 2 & 3 only.
          Similar subscripts have also been added.
          BUT unsure why your error shows \A15 as that isn't a Unicode way ?
          e.g. it's \U2075 for "⁵" ? Please confirm...

          NOT YET CONSIDERED.

          The group parts could be 'named' differently ?
          Or if made as compos, the whole text could be in a description ?
          But it does have far ranging ramifications...

          'Purple' overly long strings split up...
          Hard to implement as we've no idea how long the string will format in 3dText.
          Looking at MTEXTBEGIN and MTEXTEND ??

          Dims are also extremely complicated to read/recreate...

          Rotated Mtext was meant to be implemented but it has had limitations.
          Do you have other example DXF files you could share ?

          TIG

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

            Here's v3.5
            https://sketchucation.com/pluginstore?pln=importDXFtext
            Which includes the tweaks outlined in my previous post...

            TIG

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

              Thanks for the quick response.
              I fixed the typo in the version and republished v3.5 !

              I'll need a while to look through your other points...

              TIG

              1 Reply Last reply Reply Quote 0
              • uwesketchU Offline
                uwesketch
                last edited by

                Thanks a lot.

                After installing the Plugin, the version text still says 3.4, so I first thought the install did not work. But all fine.

                Yes, I have more dxf files. What should they ideally contain?

                • 'Orange': Leading space: confirm it works

                • 'blue': works for the minus sign.
                  Tested as well with other chars like: °"*='^`
                  But these are still placed down at the bottom.

                • 'green': works nicely

                • 'brown': Superscripts. I see no difference yet.

                The MText contains for instance the following value string in the dxf:

                \A1;{\fArial|b0|i0|c0|p34;2.88\fArial|b0|i0|c0|p34;\A1{\H.66x;\S5^  ;}}
                

                The imported result of this is:

                2.88\A15
                

                I think correctly interpreted is the follwoing part:
                \A1;{\fArial|b0|i0|c0|p34;2.88\fArial|b0|i0|c0|p34;.....}

                But the part \A1{\H.66x;\S5^ ;} is generating the string \A15
                I think that the dxf code \H.66x;\S....^ means: by a factor 0.66 of font height shift the string starting after /S upwards (^)

                • 'components': I would prefer if the 3D-text is created as a component, not a group. The description (not the name) of the component could then contain the text used in the 3D-text. If someone wants to recreate the 3DText manually, only the description has to be copy/pasted into a new 3DText.
                  If the text would also be used as the instance name, The text would be easily recognizable as well in the outliner. But this is just an option.
                  The component name (definition) can stay as it is now.

                • 'Rotated MText': would it be easier, if only a rotation around the z-axis would be considered? I think the rotation angle and the position of the "attach" or "center" point is an attribute in the dxf of the MText.
                  For me this would be enough, as I import dxf text only for 2D drawings.

                • 'Purple': Line breaks.
                  I am not sure, but I thought in dxf there is kind of a column width defined for the MText Codes. Could this be used to estimate the number of characters that fit into the width? For instance assuming an average character in a text is half as wide as high.
                  Example: if the width of the box is 1500mm and the font height is 250mm, then we can place around 12 chars into the box before doing a line break.
                  Forget the MTEXTBEGIN and MTEXTEND, I thought this defines the width of the mtext box.

                • 'Dimensions':
                  I agree it is not trivial. I was thinking about a pragmatic implementation like:

                • get the type of dimension as linear or radial. If the dxf contains a type we cannot map in SketchUp, then ignore it and just import the text as is done today.

                • get the insertion/definition points. But do not try to attach the dimension to an entity.
                  For a radial dimension, just create a small circle (for type diameter) or arc (for type radius) at the definition point and attach it to the SketchUp radial dimension. Once the dimension is created, delete the circle/arc.

                • get the text to be used. (do not let Sketchup set the text)

                • try to figure out the arrow style (none, point, open arrow, closed arrow, dash). If nothing matching is found in the dxf, just use the default arrow style from SketchUp.

                • get the distance of the dimension line (linear) or text (radial) from the definition point(s). I would start with only dimensions in the XY plane. (2D).
                  (I will try to find out how these dimensions can be drwan using ruby in the general case. In the SketchUp UI I think it is limited to 6 variants: either the dimension measures the X, Y, Z coordinate or the length of the projection on the XY, XZ or YZ plane)

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

                  The 2.88\A15 is therefore equal to 2.88⁵
                  I can trap for that, but are there any other decimal parts e.g. 2.88³ ??

                  I see that \A is a DXF alignment code, where 1 is btm, 2 is center, 3 is top
                  The part after that is the formatted string - e.g. 5
                  It also has a trailing ; that needs stripping.

                  v3.6 will be published soon and will incorporate that...

                  I've also added the lone - alignment/height adjustment to include other lone characters like ` °"*='^`` too...

                  TIG

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

                    Here's v3.6
                    https://sketchucation.com/pluginstore?pln=importDXFtext
                    Containing the recent changes outlined in my last post...

                    TIG

                    1 Reply Last reply Reply Quote 0
                    • uwesketchU Offline
                      uwesketch
                      last edited by

                      Looks very nice! Thanks.

                      This numbering format with the "mm" number shown superscripted only shows a whole number, no decimals in the superscript.
                      But in theory there could be also more than one digit/character superscript.

                      I have attached another dxf which is as received. It contains a map and isocontours with a lot of text. Here you see, that rotating the text along the contours would be very helpful.
                      The coordinate system is the Swiss coordinate system LV95.
                      The origin is 2'677'085 m west and 1'237'410 m south of the lower left corner.

                      I have another similar file which is in 3D. But I think the 2D is good to start with.


                      Map with Isocontours, descriptions and height texts

                      1 Reply Last reply Reply Quote 0
                      • uwesketchU Offline
                        uwesketch
                        last edited by

                        @tig said:

                        The 2.88\A15 is therefore equal to 2.88⁵
                        I can trap for that, but are there any other decimal parts e.g. 2.88³ ??

                        I see that \A is a DXF alignment code, where 1 is btm, 2 is center, 3 is top
                        The part after that is the formatted string - e.g. 5
                        It also has a trailing ; that needs stripping....

                        I have created an additional test case (see attached dxf file) with the following dxf script:
                        \A1;Nische für späteren \A1;{\fArial|b1|i1|c0|p34;17\fArial|b1|i1|c0|p34;\A1{\H.66x;\Ssuper;normal}\A1{\H.36x;\Sscript;small}} Duscheneinbau

                        But I think this is really pushing it.

                        I think a formatting command starts with a "" and ends with a ";"

                        • The \H..x; command indicates the text height as a factor.
                        • The \S...; command is the superscript. The text to superscript starts right after the "S" until the ";".
                        • The \Ax; command can also be written without the ending ; as it takes only one parameter.
                        • curled brackets {} are to limit a command to the block inside the curled brackets.
                          The import looks like this:
                          Import Issue superscript test.png
                          It should look like this:
                          Import Issue superscript test DXF correct.png

                        DXF test file with extended text formatting commands

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

                          Here's v3.7
                          https://sketchucation.com/pluginstore?pln=importDXFtext
                          It now correctly rotates MTEXT [and all other text-types] - I might have messed up somewhere, please test...
                          Code 50 used by TEXT/ATEXT can be in MTEXT's definitions, but not in the examples provided, so we have to rely on codes 11/21 to work out the vector rotations about the Z, then the result is in radians not degrees !

                          I'll look at other outstanding issues when I can...

                          TIG

                          1 Reply Last reply Reply Quote 0
                          • uwesketchU Offline
                            uwesketch
                            last edited by

                            Since version 3.5 and higher another issue has sneaked in: TEXT objects are not imported anymore
                            (our main test file does not have text objects, so I did not realize it before)
                            There should be 74 TEXT ENTITIES imported from the attached file called
                            "map with Isocontours TEXT.dxf"
                            Currently the console output looks like this:

                            
                            --------------------------------------------
                            importDXFtext
                            --------------------------------------------
                            DXF = 'D;\xxx\Sketchup\Import\dwgtest\map with Isocontours TEXT.dxf'
                            UNITS = 'm'
                            
                            4 STYLES;
                            ....
                            
                            67 LAYERS;
                            ....
                            
                            0 TEXT ENTITIES;
                            
                            25 MTEXT ENTITIES;
                            ....
                            
                            436 ATTRIBUTE TEXT ENTITIES;
                            ....
                            
                            
                            

                            Rotation
                            MText Rotation angle looks good. But the position is not right anymore. I assume the issue is that the wrong rotation (attachment) point is taken.
                            What I found in the ACAD documentation on MTEXT:

                            @unknownuser said:

                            MTEXT code 71: Attachment point:
                            Values mean: 1 = Top left; 2 = Top center; 3 = Top right
                            4 = Middle left; 5 = Middle center; 6 = Middle right
                            7 = Bottom left; 8 = Bottom center; 9 = Bottom right

                            What I found in the ACAD documentation on rotation angles and text points in relation to text justification:

                            
                            MTEXT codes 10, 20, 30; x,y,z coord for Insertion point
                            MTEXT code 50; Rotation angle in radians
                            MTEXT codes 11,21,31; x, y, z coord of X-axis direction vector (in WCS)
                                                  A group code 50 (rotation angle in radians) passed as DXF input is converted 
                                                  to the equivalent direction vector ([u]if both a code 50 and codes 11, 21, 31 
                                                  are passed, the last one wins)[/u]. This is provided as a convenience for 
                                                  conversions from text objects
                            MTEXT code 71; Attachment point;
                                           Values are; 1 = Top left; 2 = Top center; 3 = Top right
                                                       4 = Middle left; 5 = Middle center; 6 = Middle right
                                                       7 = Bottom left; 8 = Bottom center; 9 = Bottom right
                            
                            TEXT codes 10, 20, 30; x, y, z coord for First alignment point (in OCS)
                            TEXT code 50; Text rotation (optional; default = 0)
                            TEXT codes 11,21,31; x, y, z coord for Second alignment point (in OCS) (optional)
                                                 These values are meaningful only if the value of a 72 or 73 group is nonzero 
                                                 (if the justification is anything other than baseline/left)
                            TEXT code 72; Horizontal text justification type (optional, default = 0) integer codes 
                                          (not bit-coded)
                                          values are; 0 = Left; 1= Center; 2 = Right
                                                      3 = Aligned (if vertical alignment = 0)
                                                      4 = Middle (if vertical alignment = 0)
                                                      5 = Fit (if vertical alignment = 0)
                                          See the Group 72 and 73 integer codes table for clarification
                            TEXT code 73; Vertical text justification type (optional, default = 0); integer codes 
                                          (not bit-coded);
                                          values are; 0 = Baseline; 1 = Bottom; 2 = Middle; 3 = Top
                                          See the Group 72 and 73 integer codes table for clarification
                            
                            A-TEXT codes 10, 20, 30; x,y,z coord for Text start point (in OCS)
                            A-TEXT code 50; Text rotation (optional; default = 0)
                            A-TEXT codes 11,21,31; x, y, z coord for Alignment point (in OCS) (optional)
                                                   Present only if 72 or 74 group is present and nonzero
                            A-TEXT code 72; Horizontal text justification type (optional; default = 0). See TEXT group codes
                            A-TEXT code 74; Vertical text justification type (optional; default = 0). See group code 73 in TEXT
                            
                            

                            Examples for Rotation issues with MTEXT.

                            Below cases are based on our dxf test file called "dxf issues with special chars.dxf":

                            • The black text is the unrotated text produced from v3.4
                            • The red text is the rotated text from v3.7
                            • The green text is as it should be (taken from trimble viewer) using the indicated rotation point
                              DXF rotation issue 1 SNQ4.png
                              DXF rotation issue 2 SNQ4.png
                              DXF rotation issue 3 OKMauer.png
                              DXF rotation issue 4 Dim text.png

                            Good examples are also in the file "map with Isocontours.dxf", for instance the texts "Rinderweidstrasse" and "Rindwerweidweg".
                            Below examples have the same black/green/red colouring.
                            Most rotated green and red texts to not overlap. Only unrotated and the rotated text "3" match.
                            DXF rotation issue 5 Rinderweidstrasse.png
                            DXF rotation issue 6 Rindwerweidweg.png

                            As **a further test, **the attached dxf "map with Isocontours TEXT.dxf" can be used. It contains mostly the same text as the previous sent file "map with Isocontours.dxf", just that most MTEXTs are TEXT. So when importing both in SketchUp, texts should be at the same position, except the descriptions of the isocontours, because these are shifted a bit.


                            Map with isocontours and texts using TEXT instead of MTEXT

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

                              Thanks for the feedback.
                              I'll investigate the TEXT missed out weirdness...
                              The rotation angle seems right but the attachment is off...
                              Perhaps I need to locate it first, then rotate about that point...
                              I'll investigate... code-71

                              TIG

                              1 Reply Last reply Reply Quote 0
                              • uwesketchU Offline
                                uwesketch
                                last edited by

                                @tig said:

                                Thanks for the feedback.
                                Perhaps I need to locate it first, then rotate about that point...
                                I'll investigate... code-71

                                Yes, angles are 👍
                                I think so too, as 3D text cannot be created indicating the position. So the attachment point can be picked from the bounding box only in a second step. And then the attachment point is moved to the position indicated in the codes (10,20,30) and the rotation (around the attachment point) applied as indicated in codes (11,21,31) or code 50.

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

                                  Here's v3.8
                                  https://sketchucation.com/pluginstore?pln=importDXFtext
                                  I corrected the stupid typo which was preventing TEXT being processed.
                                  I think I've now sorted the text-group's rotation about its origin... please test and report if otherwise...

                                  TIG

                                  1 Reply Last reply Reply Quote 0
                                  • uwesketchU Offline
                                    uwesketch
                                    last edited by

                                    Whow, that was quick. I tested.

                                    The TEXT is back, but the Block Attribute Text is now gone 😲
                                    For the file "dxf issues with special chars.dxf"
                                    with version 3.4:

                                    8 STYLES:
                                    16 LAYERS:
                                    0 TEXT ENTITIES:
                                    11 MTEXT ENTITIES:
                                    16 ATTRIBUTE TEXT ENTITIES:
                                    ...
                                    Making 0 TEXT Entities...
                                    Making 11 MTEXT Entities...
                                    Making 16 ATTRIBUTE TEXT Entities...

                                    with version 3.8:
                                    8 DXF STYLES:
                                    16 DXF LAYERS:
                                    0 TEXT ENTITIES:
                                    11 MTEXT ENTITIES:
                                    16 ATTRIBUTE TEXT ENTITIES:
                                    ...
                                    Making 0 TEXT Entities...
                                    Making 11 MTEXT Entities...

                                    ...

                                    For the file "map with Isocontours TEXT.dxf"
                                    with version 3.4:
                                    4 STYLES:
                                    67 LAYERS:
                                    74 TEXT ENTITIES:
                                    25 MTEXT ENTITIES:
                                    436 ATTRIBUTE TEXT ENTITIES:
                                    ...
                                    Making 74 TEXT Entities...
                                    Making 25 MTEXT Entities...
                                    Making 436 ATTRIBUTE TEXT Entities...

                                    with version 3.8:
                                    4 DXF STYLES:
                                    67 DXF LAYERS:
                                    74 TEXT ENTITIES:
                                    25 MTEXT ENTITIES:
                                    436 ATTRIBUTE TEXT ENTITIES:
                                    ...
                                    Making 74 TEXT Entities...
                                    Making 25 MTEXT Entities...

                                    ...

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

                                      Aargh!
                                      I disabled the ATEXT for quicker testing...
                                      But I thought I set it back on !!! typo !!!

                                      Here's v3.9 that's fixed.
                                      I also added different names for the types of DXF text used to make the groups [TEXT..., MTEXT..., ATEXT...], so it's easier to find the type etc...
                                      https://sketchucation.com/pluginstore?pln=importDXFtext

                                      TIG

                                      1 Reply Last reply Reply Quote 0
                                      • uwesketchU Offline
                                        uwesketch
                                        last edited by

                                        No problem. Shit happens ,-) and for this I test 😄

                                        Another issue came now back.
                                        The shift of the 3D-Text in case there are letters going beyond the writing base line:
                                        Issue with letters going beyond the base line

                                        The type of text is helpful. Could you also add the content of the text somewhere?
                                        Then I could even search for a specific 3DText. It does not have to be the full text. Maybe the first 20 chars, so that the outliner does not yet get a horizontal scroll bar?
                                        add 3DText value to group name

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

                                          The -ve sign should move up ??
                                          Weissputz has a downstanding 'p' again they should push up ??
                                          I'll investigate...

                                          TIG

                                          1 Reply Last reply Reply Quote 0
                                          • uwesketchU Offline
                                            uwesketch
                                            last edited by

                                            @tig said:

                                            The -ve sign should move up ??
                                            Weissputz has a downstanding 'p' again they should push up ??
                                            I'll investigate...

                                            Yes, it worked in version 3.6. All nicely shifted up. Including characters like °'`^". They were shifted up to the top.

                                            1 Reply Last reply Reply Quote 0
                                            • 1
                                            • 2
                                            • 3
                                            • 4
                                            • 5
                                            • 6
                                            • 7
                                            • 8
                                            • 9
                                            • 6 / 9
                                            • First post
                                              Last post
                                            Buy SketchPlus
                                            Buy SUbD
                                            Buy WrapR
                                            Buy eBook
                                            Buy Modelur
                                            Buy Vertex Tools
                                            Buy SketchCuisine
                                            Buy FormFonts

                                            Advertisement