OutlineEffect.html 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <title>OutlineEffect - Three.js Docs</title>
  6. <meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
  7. <script src="../scripts/highlight.min.js"></script>
  8. <link type="text/css" rel="stylesheet" href="../styles/highlight-three.css">
  9. <link type="text/css" rel="stylesheet" href="../styles/page.css">
  10. </head>
  11. <body>
  12. <h1 translate="no">OutlineEffect</h1>
  13. <section>
  14. <header>
  15. <div class="class-description"><p>An outline effect for toon shaders.</p>
  16. <p>Note that this class can only be used with <a href="WebGLRenderer.html">WebGLRenderer</a>.
  17. When using <a href="WebGPURenderer.html">WebGPURenderer</a>, use <a href="ToonOutlinePassNode.html">ToonOutlinePassNode</a>.</p></div>
  18. <h2>Code Example</h2>
  19. <div translate="no"><pre><code class="language-js">const effect = new OutlineEffect( renderer );
  20. function render() {
  21. effect.render( scene, camera );
  22. }
  23. </code></pre></div>
  24. </header>
  25. <article>
  26. <h2 class="subsection-title">Import</h2>
  27. <p><span translate="no">OutlineEffect</span> is an addon, and must be imported explicitly, see <a href="https://threejs.org/manual/#en/installation" target="_blank" rel="noopener">Installation#Addons</a>.</p>
  28. <pre><code class="language-js">import { OutlineEffect } from 'three/addons/effects/OutlineEffect.js';</code></pre>
  29. <div class="container-overview">
  30. <h2>Constructor</h2>
  31. <h3 class="name name-method" id="OutlineEffect" translate="no">new <a href="#OutlineEffect">OutlineEffect</a><span class="signature">( renderer : <span class="param-type"><a href="WebGLRenderer.html">WebGLRenderer</a></span>, parameters : <span class="param-type"><a href="OutlineEffect.html#~Options">OutlineEffect~Options</a></span> )</span> </h3>
  32. <div class="method">
  33. <div class="description">
  34. <p>Constructs a new outline effect.</p>
  35. </div>
  36. <table class="params">
  37. <tbody>
  38. <tr>
  39. <td class="name">
  40. <strong>renderer</strong>
  41. </td>
  42. <td class="description last">
  43. <p>The renderer.</p>
  44. </td>
  45. </tr>
  46. <tr>
  47. <td class="name">
  48. <strong>parameters</strong>
  49. </td>
  50. <td class="description last">
  51. <p>The configuration parameter.</p>
  52. </td>
  53. </tr>
  54. </tbody>
  55. </table>
  56. </div>
  57. </div>
  58. <h2 class="subsection-title">Methods</h2>
  59. <h3 class="name name-method" id="render" translate="no">.<a href="#render">render</a><span class="signature">( scene : <span class="param-type"><a href="Object3D.html">Object3D</a></span>, camera : <span class="param-type"><a href="Camera.html">Camera</a></span> )</span> </h3>
  60. <div class="method">
  61. <div class="description">
  62. <p>When using this effect, this method should be called instead of the
  63. default <a href="WebGLRenderer.html#render">WebGLRenderer#render</a>.</p>
  64. </div>
  65. <table class="params">
  66. <tbody>
  67. <tr>
  68. <td class="name">
  69. <strong>scene</strong>
  70. </td>
  71. <td class="description last">
  72. <p>The scene to render.</p>
  73. </td>
  74. </tr>
  75. <tr>
  76. <td class="name">
  77. <strong>camera</strong>
  78. </td>
  79. <td class="description last">
  80. <p>The camera.</p>
  81. </td>
  82. </tr>
  83. </tbody>
  84. </table>
  85. </div>
  86. <h3 class="name name-method" id="renderOutline" translate="no">.<a href="#renderOutline">renderOutline</a><span class="signature">( scene : <span class="param-type"><a href="Object3D.html">Object3D</a></span>, camera : <span class="param-type"><a href="Camera.html">Camera</a></span> )</span> </h3>
  87. <div class="method">
  88. <div class="description">
  89. <p>This method can be used to render outlines in VR.</p>
  90. <pre><code class="language-js">const effect = new OutlineEffect( renderer );
  91. let renderingOutline = false;
  92. scene.onAfterRender = function () {
  93. if ( renderingOutline ) return;
  94. renderingOutline = true;
  95. effect.renderOutline( scene, camera );
  96. renderingOutline = false;
  97. };
  98. function render() {
  99. renderer.render( scene, camera );
  100. }
  101. </code></pre>
  102. </div>
  103. <table class="params">
  104. <tbody>
  105. <tr>
  106. <td class="name">
  107. <strong>scene</strong>
  108. </td>
  109. <td class="description last">
  110. <p>The scene to render.</p>
  111. </td>
  112. </tr>
  113. <tr>
  114. <td class="name">
  115. <strong>camera</strong>
  116. </td>
  117. <td class="description last">
  118. <p>The camera.</p>
  119. </td>
  120. </tr>
  121. </tbody>
  122. </table>
  123. </div>
  124. <h3 class="name name-method" id="setSize" translate="no">.<a href="#setSize">setSize</a><span class="signature">( width : <span class="param-type">number</span>, height : <span class="param-type">number</span> )</span> </h3>
  125. <div class="method">
  126. <div class="description">
  127. <p>Resizes the effect.</p>
  128. </div>
  129. <table class="params">
  130. <tbody>
  131. <tr>
  132. <td class="name">
  133. <strong>width</strong>
  134. </td>
  135. <td class="description last">
  136. <p>The width of the effect in logical pixels.</p>
  137. </td>
  138. </tr>
  139. <tr>
  140. <td class="name">
  141. <strong>height</strong>
  142. </td>
  143. <td class="description last">
  144. <p>The height of the effect in logical pixels.</p>
  145. </td>
  146. </tr>
  147. </tbody>
  148. </table>
  149. </div>
  150. <h2 class="subsection-title">Type Definitions</h2>
  151. <div class="member">
  152. <h3 class="name" id="~Options" translate="no">.<a href="#~Options">Options</a> </h3>
  153. <div class="description">
  154. <p>This type represents configuration settings of <code>OutlineEffect</code>.</p>
  155. </div>
  156. <table class="props">
  157. <tbody>
  158. <tr>
  159. <td class="name">
  160. <strong>defaultThickness</strong>
  161. <br>
  162. <span class="param-type">number</span>
  163. </td>
  164. <td class="description last">
  165. <p>The outline thickness.</p>
  166. <p>Default is <code>0.003</code>.</p>
  167. </td>
  168. </tr>
  169. <tr>
  170. <td class="name">
  171. <strong>defaultColor</strong>
  172. <br>
  173. <span class="param-type">Array.&lt;number></span>
  174. </td>
  175. <td class="description last">
  176. <p>The outline color.</p>
  177. <p>Default is <code>[0,0,0]</code>.</p>
  178. </td>
  179. </tr>
  180. <tr>
  181. <td class="name">
  182. <strong>defaultAlpha</strong>
  183. <br>
  184. <span class="param-type">number</span>
  185. </td>
  186. <td class="description last">
  187. <p>The outline alpha value.</p>
  188. <p>Default is <code>1</code>.</p>
  189. </td>
  190. </tr>
  191. <tr>
  192. <td class="name">
  193. <strong>defaultKeepAlive</strong>
  194. <br>
  195. <span class="param-type">boolean</span>
  196. </td>
  197. <td class="description last">
  198. <p>Whether to keep alive cached internal materials or not.</p>
  199. <p>Default is <code>false</code>.</p>
  200. </td>
  201. </tr>
  202. </tbody>
  203. </table>
  204. </div>
  205. <h2 class="subsection-title">Source</h2>
  206. <p>
  207. <a href="https://github.com/mrdoob/three.js/blob/master/examples/jsm/effects/OutlineEffect.js" translate="no" target="_blank" rel="noopener">examples/jsm/effects/OutlineEffect.js</a>
  208. </p>
  209. </article>
  210. </section>
  211. <script src="../scripts/linenumber.js"></script>
  212. <script src="../scripts/page.js"></script>
  213. </body>
  214. </html>
粤ICP备19079148号