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

    Trouble with .position_material method

    Scheduled Pinned Locked Moved Developers' Forum
    36 Posts 6 Posters 4.6k Views 6 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.
    • thomthomT Offline
      thomthom
      last edited by

      Just noticed something...

      Error 404 (Not Found)!!1

      favicon

      (code.google.com)

      @unknownuser said:

      a Point3d containing the UV coordinates where the X value is the U value, the Y value is the V value and the Z value is a Q value (which is not used).

      It claims that the Q value is not used. But that does not seem to be the case from the values we get from the UVhelper.

      Thomas Thomassen — SketchUp Monkey & Coding addict
      List of my plugins and link to the CookieWare fund

      1 Reply Last reply Reply Quote 0
      • F Offline
        fizgig
        last edited by

        @thomthom said:

        hm... there is something weird with the UV co-ords the UVhelper returns. That textures is mapped to be stretched almost one time across the face - the UVs to stretch a map across a face once is should not exceed 1.0

        I'm not sure what's going on.

        Yeah, if I understood what the units of the u/v coordinates were, I'd be able to troubleshoot this more.

        1 Reply Last reply Reply Quote 0
        • thomthomT Offline
          thomthom
          last edited by

          If you have a texture tiled once across a face you'd have a set of UV co-ords like this:

          0.0,0.0
          1.0,0.0
          1.0,1.0
          0.0,1.0

          You then match these pairs with 3D points the four corners on the face.

          If you want to tile the texture two times across:

          0.0,0.0
          0.5,0.0
          0.5,0.5
          0.0,0.5

          Does that make sense?
          With the given set of XYZ 3D points - the UV values define how many times the texture is tiled between the XYZ points. 1.0 = 100% - 0.0 = 0%

          Thomas Thomassen — SketchUp Monkey & Coding addict
          List of my plugins and link to the CookieWare fund

          1 Reply Last reply Reply Quote 0
          • thomthomT Offline
            thomthom
            last edited by

            @thomthom said:

            0.0,0.0
            0.5,0.0
            0.5,0.5
            0.0,0.5

            sorry - I might not be correct here...

            Thomas Thomassen — SketchUp Monkey & Coding addict
            List of my plugins and link to the CookieWare fund

            1 Reply Last reply Reply Quote 0
            • thomthomT Offline
              thomthom
              last edited by

              Yea - I was wrong. If you want to tile a texture twice it should be 2.0.
              0.5 will tile the texture only half.

              Thomas Thomassen — SketchUp Monkey & Coding addict
              List of my plugins and link to the CookieWare fund

              1 Reply Last reply Reply Quote 0
              • thomthomT Offline
                thomthom
                last edited by

                I'm really puzzled by the values returned by the UVHelper.

                It does seem that the UVHelper uses the Q value when the texture is skewed.

                However - it returns some strange numbers - even for textures stretched once across a face. You'd think it's be returning 0.0 or 1.0 values for each corner vertex - but it doesn't. I can't make sense of the numbers.

                Btw: I made a small tool to quickly investigate the UVQ values: http://forums.sketchucation.com/viewtopic.php?f=180&t=21472&p=183291#p180592

                Thomas Thomassen — SketchUp Monkey & Coding addict
                List of my plugins and link to the CookieWare fund

                1 Reply Last reply Reply Quote 0
                • F Offline
                  fizgig
                  last edited by

                  Using your comment - that the UV coordinates are normalized to a max of 1 (for no tiling),
                  I changed the pts matrix to the following:

                  pts=[
                                       [479.0, 0.0, 95.5],
                                       [1.0, 1.0, 1.0],
                                       [0.0, 0.0, 95.5],
                                       [0.0, 1.0, 1.0],
                                       [0.0, 0.0, 0.0],
                                       [0.0, 0.0, 1.0],
                                       [479.0, 0.0, 0.0],
                                       [1.0, 0.0, 1.0]
                                       ]
                  

                  It is almost perfect. The picture isn't stretched to fit perfectly like it's shown in my first post. That does seem to beg the question as to why any UV coordinate would have a value over 1.0 if it isn't tiled. Wish I could tweak the picture positioning a bit and save it.

                  1 Reply Last reply Reply Quote 0
                  • thomthomT Offline
                    thomthom
                    last edited by

                    I'm curious to how that texture in your sample model was textured. The UVQ values returned gives Q values that are not 1.0. If I remove the material and apply it again - stretching to fit - I get a new set of UVQ values - this time their Q values are 1.0.

                    Thomas Thomassen — SketchUp Monkey & Coding addict
                    List of my plugins and link to the CookieWare fund

                    1 Reply Last reply Reply Quote 0
                    • F Offline
                      fizgig
                      last edited by

                      Not sure what you're getting at. My q values are very close to 1.0 as it is. I think they're ignored anyhow.

                      I think the way the texture mapping works is you specify up to 4 vertex pairs where each pair has a vertex in the model and a vertex on the texture. If you give 4 pairs, it will stretch, rotate, shear and tweak the texture until all pairs line up. You don't need q-values on the texture to accomplish that, just u,v values.

                      1 Reply Last reply Reply Quote 0
                      • F Offline
                        fizgig
                        last edited by

                        Sure wish I could figure this out. Anyone have any ideas why I'm experiencing the problem with this texture and face?

                        1 Reply Last reply Reply Quote 0
                        • thomthomT Offline
                          thomthom
                          last edited by

                          I mentioned this to the Google dev team. I asked what the Q value did - as the manual claims it's unused.

                          @unknownuser said:

                          Hi Thomas,

                          I looked at the code, and the Q value (or Z attribute of the Point3D returned) is explicitly set to a value of 1.0 in the Point3d object returned. However, the method also does the transform to get the UV values, (which is stored in a 3x3 matrix) on the return Point3d after it initializes Q/Z to 1.0. So for transform matrices such as skew, which operate on the Z coordinate, you will end up getting a value that does not equal 1.0 (this probably also explains why UVHelper returns Point3d objects in stead of a simple UV array, so that the matrix math lines up -- still doesn’t excuse it though 😉). So while the value may not always be 1.0, it is not getting the value from any internal representation of the model.

                          Matt

                          Thomas Thomassen — SketchUp Monkey & Coding addict
                          List of my plugins and link to the CookieWare fund

                          1 Reply Last reply Reply Quote 0
                          • S Offline
                            sahi
                            last edited by

                            
                            pts=[[479.0, 0.0, 95.5],[0,0,0]]
                            material.texture.size = [height, length]
                            face.position_material material, pts, true
                            
                            
                            1 Reply Last reply Reply Quote 0
                            • F Offline
                              fizgig
                              last edited by

                              Appreciate the posts everyone. Not sure if I have a solution though. I'm trying to understand why the UVhelper script is giving me point data that doesn't work when I use it. Thanks for any insight you can provide.

                              1 Reply Last reply Reply Quote 0
                              • F Offline
                                fizgig
                                last edited by

                                @sahi: I think you're on to something there with the texture.size method. I notice that the texture doesn't have the right height and width. In fact, I never really noticed those parameters before, I just left them at whatever they were and then stretched the texture out with the pins.

                                Since the texture has a width of about 2.5' and the wall itself is 40' long, the texture has to be stretched to 16x it's width in order to fit. That would explain some of those large values in the UVhelper script.

                                Unfortunately, I have to put this down for awhile but I'll report back later what else I figure out.

                                1 Reply Last reply Reply Quote 0
                                • thomthomT Offline
                                  thomthom
                                  last edited by

                                  hm...

                                  The material size should only be relevant if thereæs no UV mapping. It specifies the default size of the texture. When you map 3D model points to 2D UV points it shouldn't matter.

                                  Thomas Thomassen — SketchUp Monkey & Coding addict
                                  List of my plugins and link to the CookieWare fund

                                  1 Reply Last reply Reply Quote 0
                                  • F Offline
                                    fizgig
                                    last edited by

                                    @thomthom:

                                    Interesting point. That makes sense. Sahi's method still has some application here as he just specifies one point in the real world and one in the texture. That allows the width and height parameters of the texture to take control.

                                    I imagine if you gave it more point pairs, the width and height parameters would not apply anymore.

                                    Guess I'm still stuck.

                                    Do you think this is a bug? Should I file it?

                                    1 Reply Last reply Reply Quote 0
                                    • thomthomT Offline
                                      thomthom
                                      last edited by

                                      I asked this at the beta forum - the best answer that what I quoted earlier. I'm not sure what to make of it. I'll try to prod again. But you can try as well - just to make some more noise about this matter from multiple sources. SU UV mapping is a bit of a mystery and a black art to master.

                                      Thomas Thomassen — SketchUp Monkey & Coding addict
                                      List of my plugins and link to the CookieWare fund

                                      1 Reply Last reply Reply Quote 0
                                      • F Offline
                                        fizgig
                                        last edited by

                                        Well, I changed the scale of the texture to be a width of 40' and a height of 8.5'

                                        I then remapped the texture by hand using the pins. When I then looked at the UV values, I got the same geometry positions but the uv coordinates had changed to unit values:

                                        [479", 0", 95.5"],
                                        [1",1",1"],
                                        [0", 0", 95.5"],
                                        [0",1",1"],
                                        [0",0",0"],
                                        [-0", -0", 1"],
                                        [479", 0", 0"],
                                        [1", -0", 1"]

                                        I made a script that uses these values and the script does work. Not sure why as I tend to think you're right: the UV coordinate mappings should overide size and width - otherwise, why have more than one pair of coordinates?

                                        Me still confused.

                                        1 Reply Last reply Reply Quote 0
                                        • F Offline
                                          fizgig
                                          last edited by

                                          Also thinking out loud again. Even though the UVhelper script returns uv values as whatever unit the model is in (in my case, inches), it really is a unit-less value.

                                          Say the value is 0.5....

                                          I wonder if that refers to have the size of the picture dimension or half the size of the geometry that's being applied to.

                                          1 Reply Last reply Reply Quote 0
                                          • thomthomT Offline
                                            thomthom
                                            last edited by

                                            XYZ: 0,0,0 - UV: 0,0
                                            XYZ: 0,10,0 - UV: 0,0.5
                                            XYZ: 10,0,0 - UV: 0.5,0
                                            XYZ: 10,10,0 - UV: 0.5,0.5

                                            That would scale the texture one half time across the face.

                                            XYZ: 0,0,0 - UV: 0,0
                                            XYZ: 0,10,0 - UV: 0,2
                                            XYZ: 10,0,0 - UV: 2,0
                                            XYZ: 10,10,0 - UV: 2,2

                                            That would scale the texture two times across the face.

                                            Thomas Thomassen — SketchUp Monkey & Coding addict
                                            List of my plugins and link to the CookieWare fund

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

                                            Advertisement