mcjShrinkWrapA for DS 4.5+ shrink wrap figures and objects - SAFE 2019 Update

135

Comments

  • mCasualmCasual Posts: 4,607
    edited July 2013

    Sheet of 5 rows?

    for the 4x4 primitive plane, 5 rows of vertices , each row is 5-vertices long

    in the case of the 64x64 cylinder / tube it's 65 rings, each ring is made of 64 vertices

    ----

    it's those rows and those rings that will be acting as rubber bands pressed against the wrapped character

    the bodycon dress for Aiko3 was made that way

    undisturbed.jpg
    600 x 1200 - 74K
    Post edited by mCasual on
  • patience55patience55 Posts: 7,006
    edited December 1969

    Okay, that makes sense.

    And that outfit looks cute too.

  • bighbigh Posts: 8,147
    edited December 1969

    Casual said:
    Sheet of 5 rows?

    for the 4x4 primitive plane, 5 rows of vertices , each row is 5-vertices long

    in the case of the 64x64 cylinder / tube it's 65 rings, each ring is made of 64 vertices

    ----

    it's those rows and those rings that will be acting as rubber bands pressed against the wrapped character

    the bodycon dress for Aiko3 was made that way

    sweet - did you make that - using this ?

  • mCasualmCasual Posts: 4,607
    edited December 1969

    bigh said:
    ...sweet - did you make that - using this ?

    i made the initial dress shell using a script like that yes

    i also re-generated the dress for the different Aiko3 morphs

    the presently published script only pushes the dress onto the body

    but the next version pulls it back as if it was elastic fabric

    020.jpg
    1280 x 720 - 437K
  • Eustace ScrubbEustace Scrubb Posts: 2,701
    edited December 1969

    Casual said:
    RAMWolff said:
    WOW... this is really getting better and better! COOL BEANS! :-)

    the part of the program that analyses the tube or sheet of cloth is written

    so you'll be able to use your own sheet or tubes, not just standardized ones issued by me


    So we couldn't use any old mesh, before? That's what I did wrong!

    :P

  • mCasualmCasual Posts: 4,607
    edited July 2013


    So we couldn't use any old mesh, before? That's what I did wrong!
    :P

    actually this version A allowed the use of any mesh

    example of things that could go wrong

    - the mcjCollider plugin is not installed

    - the mcjCollider node is not installed properly : to collide against a figure, select the figure's root node before creating the mcjCollider

    - if you load a scene containing a saved mcjCollider, the collider is no longer operational -- delete the mcjCollider node create a new one

    - the tube exceeds the collision area, so there's no collisions a all for one or more rings of the tube

    - the tube's "normals" ( which tell us what is the inside of the tube and what is the outside ) are inside-out : use the checkbox titled


    also, with this version, if you attempt to wrap 2 legs for example, the cloth between the legs will most likely not be draped like a skirt.

    this version of the script is better suited to shrink tubes against 1 leg, 1 arm, a torso, a neck, a head, it's not suited to make skirts

    Post edited by mCasual on
  • DAZ_BrianDAZ_Brian Posts: 345
    edited December 1969

    We appreciate everybody being thoughtful about this topic and carefully considering whether this is a violation of the DAZ EULA.

    Just to clarify.... this is clearly a "derived" work. The question is not whether the topology of the original figure is used... there is in this case a new mesh.. the Intellectual Property that is being derived from is the shape of the original figure.

    With that said, it is understood that almost ALL clothing made for a figure necessarily uses the shape. So using the shape is not necessarily against the EULA because there is a clause in the EULA that allows it. However, there are some caveats.

    The applicable part of the Eula is:

    Terms of Use. User may (i) access, use, copy and modify the Content in the creation and presentation of animations and renderings, and (ii) incorporate two dimensional images (including two dimensional images that simulate motion of three dimensional objects) derived from the Content in other works and publish, market, distribute, transfer, sell or sublicense such combined works; provided that User may not in any case: (a) separately publish, market, distribute, transfer, sell or sublicense any Content or any part thereof; or (b) publish, market, distribute, transfer, sell or sublicense renderings, animations, software applications, data or any other product from which any Content, or any part thereof, or any substantially similar version of the Content can be separately exported, or extracted into any re-distributable form or format. Subject to the foregoing limitations, and the rights, if any, of third parties in or to the objects represented by the Content, User may copy, distribute, and/or sell User’s animations and 2-D renderings derived from the Content. All other rights with respect to the Content and their use are reserved by DAZ and its PAs.

    Notwithstanding the foregoing, DAZ wishes to encourage user expansion of the catalog of Content available to users. Therefore, User may also access, use, copy, and modify the Content stored on such computers in the creation of one or more derived or additional works provided that:

    any derived or additional works are designed to require or encourage the use of Content available through the online DAZ store either by (i) requiring the use of such Content to function, or (ii) allowing only limited function when not used in conjunction with Content from the online DAZ store; and
    upon receipt of a written request from DAZ, User will immediately cease any and all distribution of the derived works User has created from the Content licensed from DAZ, if DAZ has determined, at its sole discretion, that (i) the derived work is substantially similar to or is a clone of existing Content; or (ii) the derived work fails to require the use of Content available through the online DAZ store.

    So the bottom line is that whether someone were to wrap the figure programmatically or by placing and adjusting the poly's manually the resulting work is by definition a "derived" work because it must necessarily conform to the original shape. That is not necessarily bad. DAZ encourages that because it fosters the sale of the original figure AND if it is sold on the DAZ store, DAZ AND the PA benefit through the sale of the content to the customer.

    DAZ does reserve the right to require the cessation of distribution if it determines "at its sole discretion" that it does not meet the requirements allowed for derivative works.

    In summary:
    It IS a derivative work
    It IS allowed (if it meets applicable requirements)
    The tool used to create the mesh is not in question and does not fall under the EULA because the EULA would only apply to the resultant derivative mesh/figure.

    Hope that helps.

  • mCasualmCasual Posts: 4,607
    edited December 1969

    .....

    The applicable part of the Eula is:
    .....

    thanks i added a note pointing to this post in the thread's top post

  • patience55patience55 Posts: 7,006
    edited December 1969

    Casual said:

    So we couldn't use any old mesh, before? That's what I did wrong!
    :P

    actually this version A allowed the use of any mesh

    example of things that could go wrong
    ... edit ...

    if you attempt to wrap 2 legs for example, the cloth between the legs will most likely not be draped like a skirt.

    I also had been trying the script with my own mesh ... and I love that description, "politically well put". hehehe ....

  • mCasualmCasual Posts: 4,607
    edited December 1969

    as you may know, the mcjCollider can be applied to more than 1 object

    so probably ( not tested ) one could do things like wrap something on top of ( character + underwear )

    netted.jpg
    1280 x 720 - 251K
  • mCasualmCasual Posts: 4,607
    edited July 2013

    figure 1 - ponder ponder ponder :)

    for the cube shape i guess there's not enough information to detemine what is a face and what is a hole

    so i'll either outlaw cube-tubes

    or treat them separately ... pick the first edge owned by 2 faces


    ---

    figure 2 : when i convert the face-based mesh into a network map, i also count the number of faces each vertex is implicated in

    oops i think that's not it yet ... uh .... maybe it is ... yeah it is ( it's not the number of caces a vertex is implicated in, it's the number of faces a network synapse is implicated in ( ok it's not a synapse it's a link to another vertex )

    shinghwah.gif
    395 x 512 - 238K
    whatsthelaw.jpg
    1600 x 800 - 139K
    Post edited by mCasual on
  • RAMWolffRAMWolff Posts: 10,220
    edited December 1969

    Nice Nice Nice!! :-)

  • TugpsxTugpsx Posts: 742
    edited December 1969

    Thanks again, as usual you provide very great tools to help enhance DAZ Studio. Thanks for sharing and continue on your quest to making the community a vibrant place to visit.

  • mCasualmCasual Posts: 4,607
    edited July 2013

    thinking about releasing a version ( maybe beta ) before the day ends

    note that the version with "spandex" effect will only accept standard tubes and planes

    by standard i mean a tube made of any number of rings of any length, but all rings are the same length

    in the case of planes, all columns and all rows have the same length


    as long as these rules are respected the tubes and planes can have any weird shape

    --

    figure 1 hyperstrappy shoes made with the help of mcjShrinkWrapB

    figure 2 the hyperstrappy shoes are not really complete - also shown here the Blender Cycles BSDF Anisotropic shader on the pole

    figure3 interpolating

    figure 4 - the portion of the program that repopulates a decimated ring ( i.e. a ring from which were removed vertices because the mcjCollider could not collide the to-be-wrapped object )

    figure 5 - the shrink phase now can interpolate positions of vertices when the mcjCollider misses the subjects

    ballbelt.jpg
    1024 x 769 - 82K
    repop.jpg
    678 x 616 - 38K
    wrappabilly.jpg
    777 x 777 - 65K
    500.jpg
    699 x 900 - 128K
    triplerainbow.jpg
    1920 x 1200 - 249K
    Post edited by mCasual on
  • patience55patience55 Posts: 7,006
    edited December 1969

    Oh this is getting better and better ... looking forward to giving it a whirl! :-)

  • mCasualmCasual Posts: 4,607
    edited July 2013

    Oh this is getting better and better ... looking forward to giving it a whirl! :-)

    thanks for your patience Patience :)

    i thought i could release it today, i made progress but it's not really ready

    well there's still a little chance i'll post a text version tonight ! :)

    --

    figure 1 : case when the shrink tube exceds the object to be wrapped, the tube gets tied at the center of the tube ring

    fig 2 : the new shrink ( does not include the convex-hull processing yet )

    fig 3 : for non-standard shrinkable meshes - dangling vertices repositionned based on nearest network neighbor

    fig 4 - for standard shrink tubes, interpolating dangling vertices based on neighboring vertices on the ring

    nonstandardtube.jpg
    618 x 800 - 127K
    17by22.jpg
    618 x 800 - 87K
    tokyo.jpg
    618 x 800 - 95K
    nohit.jpg
    830 x 620 - 82K
    Post edited by mCasual on
  • patience55patience55 Posts: 7,006
    edited December 1969

    Oh not to rush ... just when it's ready, I look forward to trying it out.

  • mCasualmCasual Posts: 4,607
    edited December 1969

    shrink wrapping was somewhat improved for non-standard tubes

    but still, getting good results means building custom tubes that are basically pre-shrunk

    so i'm thinking about ways to automatically pre-shrink tubes and/or make the mcjCollider use more 'intelligent'


    --
    an example of an issue: an mcjCollider ray, meant to shrink a tube around the toes misses the target, shoots between toes and the collision happens on Aiko5's hips

    gudtuvbes.jpg
    1280 x 720 - 139K
  • RAMWolffRAMWolff Posts: 10,220
    edited December 1969

    Good progress. IF anyone can figure this out it's you, that's for sure! :-)

  • Eustace ScrubbEustace Scrubb Posts: 2,701
    edited December 1969

    Casual said:
    shrink wrapping was somewhat improved for non-standard tubes

    but still, getting good results means building custom tubes that are basically pre-shrunk

    so i'm thinking about ways to automatically pre-shrink tubes and/or make the mcjCollider use more 'intelligent'


    --
    an example of an issue: an mcjCollider ray, meant to shrink a tube around the toes misses the target, shoots between toes and the collision happens on Aiko5's hips


    This would be caused by the normals of the tube/shrinkwrap/quicksuit not lining up perpendicular to the targeted mesh. How about a depth-to-mesh dial, such that if the collider does not find an appropriate shrink-target within , the wrap is shrunk only to and stops there? Or alternately (not mutually exclusively), the script checks in a 30-45º cone from the initial ray direction when it misses at and collides toward the nearest eligible mesh within range. If none is found, it then shrinks to the on the original azimuth, and carries on to the next vertex.

    Then again, this might be so time-consuming that it would be more efficient as a plug-in expanded from the mcjCollider algorithm....

  • mCasualmCasual Posts: 4,607
    edited July 2013

    .... depth-to-mesh dial ...

    for now the solution which didn't work too bad , goes like this:

    after shrinking vertices that could be positioned using collisions, ( lets call them glued )

    the dangling vertices are moved to the location of the nearest glued vertex

    ---

    but that's a post-processing solution,

    a pre-processing solution could detect roughly the bounds of the wrapped object, then shoot the collider rays in the center of that area, instead of shooting them perpendicular to the surface of the wrapper - or they could be shooting toward the center of the wrapper ring
    ( standard tubes being tubes made of a collection of equal-vertex-count rings )

    i'll probably give the option of using the default method which works fine most times, and the other slower methods for tricky cases

    izitgreen.jpg
    1600 x 900 - 95K
    Post edited by mCasual on
  • mCasualmCasual Posts: 4,607
    edited July 2013

    ah ha - i was using cheap single-face-based normals ... and it degrades the results so i'll fix that pronto

    nah ... they are quality normals ... i think

    so i have to find another fix

    ---

    maybe this -- when the collider misses the target completely, aim at the same facet as the nearest neighbor which had a successful shot

    aro.gif
    386 x 500 - 511K
    Post edited by mCasual on
  • RAMWolffRAMWolff Posts: 10,220
    edited December 1969

    I guess there is no way to put some sort of a collision script in there to keep things from overlapping like that??

  • mCasualmCasual Posts: 4,607
    edited July 2013

    RAMWolff said:
    I guess there is no way to put some sort of a collision script in there to keep things from overlapping like that??

    if we're dealing with a "standard" tube, ( one made of equal-length rings )

    and the "spandex" ( convex hull ) effect is used, then the overlaps/folds will be taken out

    ---

    another way would be to direct all collider rays at the center of the shrink ring, this way we avoid (most?) folds

    ---

    Figure 1 -- i implemented the "centroid" method, all the collider rays go from the periphery of the shrinkable rings toward the center of the ring
    , which is what you'd get with a perfectly circular tube. We don't get any folds/overlaps, the only drawback is we cant use the shape of the tube to influence the placement of the vertices.

    Figure 2 - using a more detailed shrink tube and a displacement map, 3Delight render

    studs.jpg
    386 x 500 - 58K
    centrois.jpg
    493 x 636 - 56K
    Post edited by mCasual on
  • RAMWolffRAMWolff Posts: 10,220
    edited December 1969

    My question to you at this point of your brilliance is...

    Can you make a script (that after you take 2 tubes for the arms, 2 tubes for the legs and one tube for the torso and one tube for the neck and use your script on them) can pull in and align and weld the points or vertices to make one solid bodysuit??

  • mCasualmCasual Posts: 4,607
    edited July 2013

    RAMWolff said:
    My question to you at this point of your brilliance is...

    Can you make a script (that after you take 2 tubes for the arms, 2 tubes for the legs and one tube for the torso and one tube for the neck and use your script on them) can pull in and align and weld the points or vertices to make one solid bodysuit??


    well i could but it's faster to do it "manually" i mean for me it would be :)

    think is i want to find time to make new Youtube Videos, like my North-By-Northwest in the Bobverse project which gathers dust since 2008

    bussed.jpg
    720 x 400 - 38K
    brownverse_007_kateexits.daz_.png
    91 x 91 - 12K
    Post edited by mCasual on
  • mCasualmCasual Posts: 4,607
    edited July 2013

    in some cases, collider rays would shoot right through the cracks between faces of the object being shrinkwrapped

    for example when wrapping a 8x8 xylinder around an 8x8 cylinder

    imcjShrinkWrapB will shoot a second collider ray mis-aligned by a tiny angle like 0.001 degrees

    that's enough to take care of the issue

    maybe someday this will be incorporated in mcjColleder

    chess.jpg
    618 x 800 - 130K
    Post edited by mCasual on
  • mCasualmCasual Posts: 4,607
    edited July 2013

    shrink wrapping test using a primitive-plane

    looks a bit spiderman'y but don't worry Amy wasn't harmed nor scared

    ---

    one issue i may address is: the script pushes the cloth onto the figure, then pulls it back toward the location it was "thrown from"
    but in many cases it would be better to pull it away perpendicular to the surface of the figure/object being wrapped

    sr3.jpg
    1200 x 1200 - 588K
    sr2.jpg
    618 x 800 - 249K
    sr.jpg
    618 x 800 - 213K
    Post edited by mCasual on
  • RAMWolffRAMWolff Posts: 10,220
    edited December 1969

    It's too bad you can't get the verts to even themselves out even if it pulls the squares edges up and inwards, esp with that sort of position.

  • mCasualmCasual Posts: 4,607
    edited July 2013

    RAMWolff said:
    It's too bad you can't get the verts to even themselves out even if it pulls the squares edges up and inwards, esp with that sort of position.

    the next step, the big new feature -- convex-hull , which is like a 2D spandex will do something like that

    Post edited by mCasual on
Sign In or Register to comment.