How to prevent z-fighting in OpenSCAD?How to remove internal part of a hex gridAre there any “best” or at...

a sore throat vs a strep throat vs strep throat

How do I reattach a shelf to the wall when it ripped out of the wall?

Which big number is bigger?

Coordinate my way to the name of the (video) game

On The Origin of Dissonant Chords

"You've called the wrong number" or "You called the wrong number"

can anyone help me with this awful query plan?

Function pointer with named arguments?

Multiple options vs single option UI

How to write a column outside the braces in a matrix?

How would 10 generations of living underground change the human body?

Re-entry to Germany after vacation using blue card

Is the claim "Employers won't employ people with no 'social media presence'" realistic?

Don’t seats that recline flat defeat the purpose of having seatbelts?

Elements that can bond to themselves?

How can I print the prosodic symbols in LaTeX?

How exactly does Hawking radiation decrease the mass of black holes?

Minor Revision with suggestion of an alternative proof by reviewer

Why did some of my point & shoot film photos come back with one third light white or orange?

How to not starve gigantic beasts

Are there physical dangers to preparing a prepared piano?

"The cow" OR "a cow" OR "cows" in this context

Constructions of PRF (Pseudo Random Function)

What are the steps to solving this definite integral?



How to prevent z-fighting in OpenSCAD?


How to remove internal part of a hex gridAre there any “best” or at least “common” practices to handle allowances in OpenSCAD code?OpenSCAD library for empty space/holesHow to specify rotation origin in openscadOpenSCAD editor font is unreadableOpenSCAD 2018 Command lineOpenSCAD “not valid 2-manifold” useful informationWhy is 2 / -2 / 2 equal to -2 in OpenSCAD? (Mathematical Order of Operations)













2












$begingroup$


Z-fighting is a 3D rendering artifact of coplanar surfaces (means, triangles are located in exactly the same plane, and overlap).



It can happen in OpenSCAD's preview mode when doing a difference() or union() operation. In case of difference(), the rendering artifacts can prevent seeing into a hole in the object. The "compile and render" mode in OpenSCAD does not have z-fighting issues, but it can take some time to render an object.



How best to avoid z-fighting?



If the answer involves changes to the code, I would love to see an idiomatic answer / established convention of OpenSCAD coders, if that exists.










share|improve this question









New contributor




tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.







$endgroup$

















    2












    $begingroup$


    Z-fighting is a 3D rendering artifact of coplanar surfaces (means, triangles are located in exactly the same plane, and overlap).



    It can happen in OpenSCAD's preview mode when doing a difference() or union() operation. In case of difference(), the rendering artifacts can prevent seeing into a hole in the object. The "compile and render" mode in OpenSCAD does not have z-fighting issues, but it can take some time to render an object.



    How best to avoid z-fighting?



    If the answer involves changes to the code, I would love to see an idiomatic answer / established convention of OpenSCAD coders, if that exists.










    share|improve this question









    New contributor




    tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.







    $endgroup$















      2












      2








      2





      $begingroup$


      Z-fighting is a 3D rendering artifact of coplanar surfaces (means, triangles are located in exactly the same plane, and overlap).



      It can happen in OpenSCAD's preview mode when doing a difference() or union() operation. In case of difference(), the rendering artifacts can prevent seeing into a hole in the object. The "compile and render" mode in OpenSCAD does not have z-fighting issues, but it can take some time to render an object.



      How best to avoid z-fighting?



      If the answer involves changes to the code, I would love to see an idiomatic answer / established convention of OpenSCAD coders, if that exists.










      share|improve this question









      New contributor




      tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.







      $endgroup$




      Z-fighting is a 3D rendering artifact of coplanar surfaces (means, triangles are located in exactly the same plane, and overlap).



      It can happen in OpenSCAD's preview mode when doing a difference() or union() operation. In case of difference(), the rendering artifacts can prevent seeing into a hole in the object. The "compile and render" mode in OpenSCAD does not have z-fighting issues, but it can take some time to render an object.



      How best to avoid z-fighting?



      If the answer involves changes to the code, I would love to see an idiomatic answer / established convention of OpenSCAD coders, if that exists.







      openscad






      share|improve this question









      New contributor




      tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      share|improve this question









      New contributor




      tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this question




      share|improve this question








      edited 1 hour ago







      tanius













      New contributor




      tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked 5 hours ago









      taniustanius

      1435




      1435




      New contributor




      tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






















          1 Answer
          1






          active

          oldest

          votes


















          3












          $begingroup$

          The general advice in the OpenSCAD community is to "extend your cuts and embed your joins" (source). Not just because of the rendering artifacts but also because z-fighting can cause unexpected errors during STL export.



          So you would change the dimensions of your objects very slightly (0.01 mm works fine) so that:




          • for a union(), there is overlap volume between the parts

          • for a difference(), the intersector has volume both inside and outside of the intersected part


          Now you could adjust both the size and position of your parts to keep the mathematically exact dimensions for the resulting part. But I found that for the purposes of 3D printing, such accuracy is not worth it because it complicates the formulas so much.



          Instead, I adjust either position or size of a part, depending on what is simpler in each case. A measure in the final design will be off by 0.01 mm, which does not matter.



          And I keep the 0.01 mm offset in a variable called nothing (picked that up somewhere and liked it …). This keeps the calculations intuitively understandable.



          Example



          To create a cylinder and cut a hole to half of its depth, it would do this:



          //!OpenSCAD
          nothing=0.01;
          height=40;

          difference(){
          cylinder(h=height, r=20, center=true);

          translate([0, 0, height/4 + nothing])
          cylinder(h=height/2, r=15, center=true);
          }


          Now the hole is nothing=0.01 less deep than half of the cylinder – that's the inaccuracy I accept.



          (Note: You can try the above code online by copy & pasting it into OpenJSCAD. Include the magic comment in the first line to switch it to OpenSCAD syntax.)






          share|improve this answer










          New contributor




          tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.






          $endgroup$









          • 1




            $begingroup$
            Your answer is the one I'd post for this question. You add the parameter "nothing" while I use "addabit = 0.1" for most z actions.
            $endgroup$
            – fred_dot_u
            2 hours ago












          Your Answer








          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "640"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          noCode: true, onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });






          tanius is a new contributor. Be nice, and check out our Code of Conduct.










          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2f3dprinting.stackexchange.com%2fquestions%2f9794%2fhow-to-prevent-z-fighting-in-openscad%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          3












          $begingroup$

          The general advice in the OpenSCAD community is to "extend your cuts and embed your joins" (source). Not just because of the rendering artifacts but also because z-fighting can cause unexpected errors during STL export.



          So you would change the dimensions of your objects very slightly (0.01 mm works fine) so that:




          • for a union(), there is overlap volume between the parts

          • for a difference(), the intersector has volume both inside and outside of the intersected part


          Now you could adjust both the size and position of your parts to keep the mathematically exact dimensions for the resulting part. But I found that for the purposes of 3D printing, such accuracy is not worth it because it complicates the formulas so much.



          Instead, I adjust either position or size of a part, depending on what is simpler in each case. A measure in the final design will be off by 0.01 mm, which does not matter.



          And I keep the 0.01 mm offset in a variable called nothing (picked that up somewhere and liked it …). This keeps the calculations intuitively understandable.



          Example



          To create a cylinder and cut a hole to half of its depth, it would do this:



          //!OpenSCAD
          nothing=0.01;
          height=40;

          difference(){
          cylinder(h=height, r=20, center=true);

          translate([0, 0, height/4 + nothing])
          cylinder(h=height/2, r=15, center=true);
          }


          Now the hole is nothing=0.01 less deep than half of the cylinder – that's the inaccuracy I accept.



          (Note: You can try the above code online by copy & pasting it into OpenJSCAD. Include the magic comment in the first line to switch it to OpenSCAD syntax.)






          share|improve this answer










          New contributor




          tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.






          $endgroup$









          • 1




            $begingroup$
            Your answer is the one I'd post for this question. You add the parameter "nothing" while I use "addabit = 0.1" for most z actions.
            $endgroup$
            – fred_dot_u
            2 hours ago
















          3












          $begingroup$

          The general advice in the OpenSCAD community is to "extend your cuts and embed your joins" (source). Not just because of the rendering artifacts but also because z-fighting can cause unexpected errors during STL export.



          So you would change the dimensions of your objects very slightly (0.01 mm works fine) so that:




          • for a union(), there is overlap volume between the parts

          • for a difference(), the intersector has volume both inside and outside of the intersected part


          Now you could adjust both the size and position of your parts to keep the mathematically exact dimensions for the resulting part. But I found that for the purposes of 3D printing, such accuracy is not worth it because it complicates the formulas so much.



          Instead, I adjust either position or size of a part, depending on what is simpler in each case. A measure in the final design will be off by 0.01 mm, which does not matter.



          And I keep the 0.01 mm offset in a variable called nothing (picked that up somewhere and liked it …). This keeps the calculations intuitively understandable.



          Example



          To create a cylinder and cut a hole to half of its depth, it would do this:



          //!OpenSCAD
          nothing=0.01;
          height=40;

          difference(){
          cylinder(h=height, r=20, center=true);

          translate([0, 0, height/4 + nothing])
          cylinder(h=height/2, r=15, center=true);
          }


          Now the hole is nothing=0.01 less deep than half of the cylinder – that's the inaccuracy I accept.



          (Note: You can try the above code online by copy & pasting it into OpenJSCAD. Include the magic comment in the first line to switch it to OpenSCAD syntax.)






          share|improve this answer










          New contributor




          tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.






          $endgroup$









          • 1




            $begingroup$
            Your answer is the one I'd post for this question. You add the parameter "nothing" while I use "addabit = 0.1" for most z actions.
            $endgroup$
            – fred_dot_u
            2 hours ago














          3












          3








          3





          $begingroup$

          The general advice in the OpenSCAD community is to "extend your cuts and embed your joins" (source). Not just because of the rendering artifacts but also because z-fighting can cause unexpected errors during STL export.



          So you would change the dimensions of your objects very slightly (0.01 mm works fine) so that:




          • for a union(), there is overlap volume between the parts

          • for a difference(), the intersector has volume both inside and outside of the intersected part


          Now you could adjust both the size and position of your parts to keep the mathematically exact dimensions for the resulting part. But I found that for the purposes of 3D printing, such accuracy is not worth it because it complicates the formulas so much.



          Instead, I adjust either position or size of a part, depending on what is simpler in each case. A measure in the final design will be off by 0.01 mm, which does not matter.



          And I keep the 0.01 mm offset in a variable called nothing (picked that up somewhere and liked it …). This keeps the calculations intuitively understandable.



          Example



          To create a cylinder and cut a hole to half of its depth, it would do this:



          //!OpenSCAD
          nothing=0.01;
          height=40;

          difference(){
          cylinder(h=height, r=20, center=true);

          translate([0, 0, height/4 + nothing])
          cylinder(h=height/2, r=15, center=true);
          }


          Now the hole is nothing=0.01 less deep than half of the cylinder – that's the inaccuracy I accept.



          (Note: You can try the above code online by copy & pasting it into OpenJSCAD. Include the magic comment in the first line to switch it to OpenSCAD syntax.)






          share|improve this answer










          New contributor




          tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.






          $endgroup$



          The general advice in the OpenSCAD community is to "extend your cuts and embed your joins" (source). Not just because of the rendering artifacts but also because z-fighting can cause unexpected errors during STL export.



          So you would change the dimensions of your objects very slightly (0.01 mm works fine) so that:




          • for a union(), there is overlap volume between the parts

          • for a difference(), the intersector has volume both inside and outside of the intersected part


          Now you could adjust both the size and position of your parts to keep the mathematically exact dimensions for the resulting part. But I found that for the purposes of 3D printing, such accuracy is not worth it because it complicates the formulas so much.



          Instead, I adjust either position or size of a part, depending on what is simpler in each case. A measure in the final design will be off by 0.01 mm, which does not matter.



          And I keep the 0.01 mm offset in a variable called nothing (picked that up somewhere and liked it …). This keeps the calculations intuitively understandable.



          Example



          To create a cylinder and cut a hole to half of its depth, it would do this:



          //!OpenSCAD
          nothing=0.01;
          height=40;

          difference(){
          cylinder(h=height, r=20, center=true);

          translate([0, 0, height/4 + nothing])
          cylinder(h=height/2, r=15, center=true);
          }


          Now the hole is nothing=0.01 less deep than half of the cylinder – that's the inaccuracy I accept.



          (Note: You can try the above code online by copy & pasting it into OpenJSCAD. Include the magic comment in the first line to switch it to OpenSCAD syntax.)







          share|improve this answer










          New contributor




          tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.









          share|improve this answer



          share|improve this answer








          edited 1 hour ago





















          New contributor




          tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.









          answered 5 hours ago









          taniustanius

          1435




          1435




          New contributor




          tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.





          New contributor





          tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.






          tanius is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.








          • 1




            $begingroup$
            Your answer is the one I'd post for this question. You add the parameter "nothing" while I use "addabit = 0.1" for most z actions.
            $endgroup$
            – fred_dot_u
            2 hours ago














          • 1




            $begingroup$
            Your answer is the one I'd post for this question. You add the parameter "nothing" while I use "addabit = 0.1" for most z actions.
            $endgroup$
            – fred_dot_u
            2 hours ago








          1




          1




          $begingroup$
          Your answer is the one I'd post for this question. You add the parameter "nothing" while I use "addabit = 0.1" for most z actions.
          $endgroup$
          – fred_dot_u
          2 hours ago




          $begingroup$
          Your answer is the one I'd post for this question. You add the parameter "nothing" while I use "addabit = 0.1" for most z actions.
          $endgroup$
          – fred_dot_u
          2 hours ago










          tanius is a new contributor. Be nice, and check out our Code of Conduct.










          draft saved

          draft discarded


















          tanius is a new contributor. Be nice, and check out our Code of Conduct.













          tanius is a new contributor. Be nice, and check out our Code of Conduct.












          tanius is a new contributor. Be nice, and check out our Code of Conduct.
















          Thanks for contributing an answer to 3D Printing Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          Use MathJax to format equations. MathJax reference.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2f3dprinting.stackexchange.com%2fquestions%2f9794%2fhow-to-prevent-z-fighting-in-openscad%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Can't compile dgruyter and caption packagesLaTeX templates/packages for writing a patent specificationLatex...

          Schneeberg (Smreczany) Bibliografia | Menu...

          IEEEtran - How to include ORCID in TeX/PDF with PdfLatexIs there a standard way to include ORCID in TeX /...