fog.html 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. <!DOCTYPE html><html lang="fr"><head>
  2. <meta charset="utf-8">
  3. <title>Le brouillard</title>
  4. <meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
  5. <meta name="twitter:card" content="summary_large_image">
  6. <meta name="twitter:site" content="@threejs">
  7. <meta name="twitter:title" content="Three.js – Brouillard">
  8. <meta property="og:image" content="https://threejs.org/files/share.png">
  9. <link rel="shortcut icon" href="../../files/favicon_white.ico" media="(prefers-color-scheme: dark)">
  10. <link rel="shortcut icon" href="../../files/favicon.ico" media="(prefers-color-scheme: light)">
  11. <link rel="stylesheet" href="../resources/lesson.css">
  12. <link rel="stylesheet" href="../resources/lang.css">
  13. <script type="importmap">
  14. {
  15. "imports": {
  16. "three": "../../build/three.module.js"
  17. }
  18. }
  19. </script>
  20. </head>
  21. <body>
  22. <div class="container">
  23. <div class="lesson-title">
  24. <h1>Le brouillard</h1>
  25. </div>
  26. <div class="lesson">
  27. <div class="lesson-main">
  28. <p>Cet article fait partie d'une série consacrée à Three.js dont le premier article s'intitule <a href="fundamentals.html">Principes de base</a>.
  29. Si vous ne l'avez pas encore lu, vous devriez commencer par lui. Si, également, vous n'avez pas lu l'article concernant <a href="cameras.html">les caméras</a>, lisez-le avant de poursuivre.</p>
  30. <p>Le brouillard dans un moteur 3D est généralement un moyen d'atténuer les couleurs de la scène vers une couleur désirée en fonction de la distance par rapport à la caméra. Dans Three.js, vous pouvez ajouter du brouillard en créant un objet <a href="https://threejs.org/docs/#api/en/scenes/Fog"><code class="notranslate" translate="no">Fog</code></a> ou <a href="https://threejs.org/docs/#api/en/scenes/FogExp2"><code class="notranslate" translate="no">FogExp2</code></a> et en le définissant sur la propriété <a href="/docs/#api/en/scenes/Scene#fog"><code class="notranslate" translate="no">fog</code></a> de votre scène.</p>
  31. <p><a href="/docs/#api/en/scenes/Fog"><code class="notranslate" translate="no">Fog</code></a> permet de définir les paramètres <code class="notranslate" translate="no">near</code> et <code class="notranslate" translate="no">far</code> qui sont les distances par rapport à la caméra. Tout ce qui se trouve entre la caméra et <code class="notranslate" translate="no">near</code> n'est pas affecté par le brouillard.
  32. Ce qui est au-delà de <code class="notranslate" translate="no">far</code> est complètement dans le brouillard. Ce qui se trouve entre les deux, est interpolé entre la couleur du matériau et la couleur du brouillard.</p>
  33. <p>Il y a aussi <a href="/docs/#api/en/scenes/FogExp2"><code class="notranslate" translate="no">FogExp2</code></a> qui croît de façon exponentielle en fonction de la distance de la caméra.</p>
  34. <p>Pour utiliser <a href="/docs/#api/en/scenes/Fog"><code class="notranslate" translate="no">Fog</code></a>, suivez cet exemple :</p>
  35. <pre class="prettyprint showlinemods notranslate lang-js" translate="no">const scene = new THREE.Scene();
  36. {
  37. const color = 0xFFFFFF; // white
  38. const near = 10;
  39. const far = 100;
  40. scene.fog = new THREE.Fog(color, near, far);
  41. }
  42. </pre>
  43. <p>Pour utiliser <a href="/docs/#api/en/scenes/FogExp2"><code class="notranslate" translate="no">FogExp2</code></a>, suivez cet exemple :</p>
  44. <pre class="prettyprint showlinemods notranslate lang-js" translate="no">const scene = new THREE.Scene();
  45. {
  46. const color = 0xFFFFFF;
  47. const density = 0.1;
  48. scene.fog = new THREE.FogExp2(color, density);
  49. }
  50. </pre>
  51. <p><a href="/docs/#api/en/scenes/FogExp2"><code class="notranslate" translate="no">FogExp2</code></a> est le plus proche de la réalité, mais <a href="/docs/#api/en/scenes/Fog"><code class="notranslate" translate="no">Fog</code></a> est le plus souvent utilisé car il permet de choisir un endroit où appliquer le brouillard, afin de vous permettre d'afficher une scène claire jusqu'à une certaine distance, puis de passer à une autre couleur au-delà de cette distance.</p>
  52. <div class="spread">
  53. <div>
  54. <div data-diagram="fog" style="height: 300px;"></div>
  55. <div class="code">THREE.Fog</div>
  56. </div>
  57. <div>
  58. <div data-diagram="fogExp2" style="height: 300px;"></div>
  59. <div class="code">THREE.FogExp2</div>
  60. </div>
  61. </div>
  62. <p>Il est important de noter que le brouillard s'applique aux objets rendus lors du calcul sur chaque pixel de la couleur des objets. Cela signifie que si vous voulez que votre scène s'estompe avec une certaine couleur, vous devez définir le brouillard ainsi que la couleur d'arrière-plan avec la même couleur. La couleur d'arrière-plan est définie à l'aide de la propriété <a href="/docs/#api/en/scenes/Scene#background"><code class="notranslate" translate="no">scene.background</code></a>. Pour choisir une couleur d'arrière-plan, vous lui attachez une <a href="/docs/#api/en/math/Color"><code class="notranslate" translate="no">THREE.Color</code></a>. Comme ceci :</p>
  63. <pre class="prettyprint showlinemods notranslate lang-js" translate="no">scene.background = new THREE.Color('#F00'); // red
  64. </pre>
  65. <div class="spread">
  66. <div>
  67. <div data-diagram="fogBlueBackgroundRed" style="height: 300px;" class="border"></div>
  68. <div class="code">Brouillard bleu, arrière-plan rouge</div>
  69. </div>
  70. <div>
  71. <div data-diagram="fogBlueBackgroundBlue" style="height: 300px;" class="border"></div>
  72. <div class="code">Brouillard bleu, arrière-plan bleu</div>
  73. </div>
  74. </div>
  75. <p>Voici l'un de nos exemples précédents mais avec du brouillard activé. L'unique ajout se fait juste après avoir configuré la scène : nous ajoutons le brouillard et définissons la couleur d'arrière-plan de la scène.</p>
  76. <pre class="prettyprint showlinemods notranslate lang-js" translate="no">const scene = new THREE.Scene();
  77. +{
  78. + const near = 1;
  79. + const far = 2;
  80. + const color = 'lightblue';
  81. + scene.fog = new THREE.Fog(color, near, far);
  82. + scene.background = new THREE.Color(color);
  83. +}
  84. </pre>
  85. <p>Dans l'exemple ci-dessous, le <code class="notranslate" translate="no">near</code> de la caméra est à 0,1 et le <code class="notranslate" translate="no">far</code> à 5. La position z de la caméra est à 2. Les cubes mesurent 1 unité de large et à Z = 0. Les réglages du brouillard, <code class="notranslate" translate="no">near</code> = 1 et <code class="notranslate" translate="no">far</code> = 2. Ainsi, les cubes s'estompent juste autour de leur centre.</p>
  86. <p></p><div translate="no" class="threejs_example_container notranslate">
  87. <div><iframe class="threejs_example notranslate" translate="no" style=" " src="/manual/examples/resources/editor.html?url=/manual/examples/fog.html"></iframe></div>
  88. <a class="threejs_center" href="/manual/examples/fog.html" target="_blank">Cliquer ici pour ouvrir dans une fenêtre séparée.</a>
  89. </div>
  90. <p></p>
  91. <p>Mettons à jour notre <a href="https://github.com/georgealways/lil-gui">lil-gui</a> pour jouer avec le brouillard. Lil-gui prend un objet et une propriété et crée automatiquement une interface de contrôle pour cette propriété. Nous pourrions simplement le laisser modifier les propriétés <code class="notranslate" translate="no">near</code> et <code class="notranslate" translate="no">far</code> du brouillard, mais il est impossible que <code class="notranslate" translate="no">near</code> soit supérieur à <code class="notranslate" translate="no">far</code>. Assurons-nous de cela.</p>
  92. <pre class="prettyprint showlinemods notranslate lang-js" translate="no">// On utilise cette classe pour passer à lil-gui.
  93. // Quand lil-gui modifie near ou far :
  94. // - near n'est jamais strictement supérieur à far
  95. // - far n'est jamais strictement inférieur à near
  96. class FogGUIHelper {
  97. constructor(fog) {
  98. this.fog = fog;
  99. }
  100. get near() {
  101. return this.fog.near;
  102. }
  103. set near(v) {
  104. this.fog.near = v;
  105. this.fog.far = Math.max(this.fog.far, v);
  106. }
  107. get far() {
  108. return this.fog.far;
  109. }
  110. set far(v) {
  111. this.fog.far = v;
  112. this.fog.near = Math.min(this.fog.near, v);
  113. }
  114. }
  115. </pre>
  116. <p>On peut l'ajouter comme ceci :</p>
  117. <pre class="prettyprint showlinemods notranslate lang-js" translate="no">{
  118. const near = 1;
  119. const far = 2;
  120. const color = 'lightblue';
  121. scene.fog = new THREE.Fog(color, near, far);
  122. scene.background = new THREE.Color(color);
  123. +
  124. + const fogGUIHelper = new FogGUIHelper(scene.fog);
  125. + gui.add(fogGUIHelper, 'near', near, far).listen();
  126. + gui.add(fogGUIHelper, 'far', near, far).listen();
  127. }
  128. </pre>
  129. <p>Les paramètres <code class="notranslate" translate="no">near</code> et <code class="notranslate" translate="no">far</code> définissent les valeurs minimales et maximales pour ajuster le brouillard. Ils sont définis lors de la configuration de la caméra.</p>
  130. <p>Le <code class="notranslate" translate="no">.listen()</code> à la fin des 2 lignes, dit à lil-gui <em>d'écouter</em>
  131. les changements. Ainsi, que nous changions <code class="notranslate" translate="no">near</code> ou <code class="notranslate" translate="no">far</code>, lil-gui mettra automatiquement à jour les deux propriétés pour nous.</p>
  132. <p>Il peut également être agréable de pouvoir changer la couleur du brouillard, mais comme mentionné ci-dessus, nous devons synchroniser la couleur du brouillard et la couleur de l'arrière-plan. Ajoutons donc une autre propriété <em>virtuelle</em> à notre helper qui définira les deux couleurs lorsque lil-gui la manipule.</p>
  133. <p>lil-gui peut manipuler les couleurs de 4 façons différentes : - Sous la forme d'une chaîne hexadécimale à 6 chiffres (ex : <code class="notranslate" translate="no">#112233</code>); - Sous la forme HSL (ex : <code class="notranslate" translate="no">{h: 60, s: 1, v: }</code>); -
  134. En tant que tableau RGB (ex : <code class="notranslate" translate="no">[255, 128, 64]</code>); - Ou finalement, comme un tableau RGBA (ex : <code class="notranslate" translate="no">[127, 200, 75, 0.3]</code>).</p>
  135. <p>Il est plus simple d'utiliser la première solution, la version chaîne hexadécimale, ainsi
  136. lil-gui ne manipule qu'une seule valeur. Heureusement, <a href="/docs/#api/en/math/Color"><code class="notranslate" translate="no">THREE.Color</code></a>
  137. a une méthode pour cela : <a href="/docs/#api/en/math/Color#getHexString"><code class="notranslate" translate="no">getHexString</code></a> qui permet d'obtenir une telle chaîne, il suffit juste d'ajouter un '#' au début.</p>
  138. <pre class="prettyprint showlinemods notranslate lang-js" translate="no">/// On utilise cette classe pour passer à lil-gui
  139. // Quand il manipule near ou far
  140. // near n'est jamais &gt; far et far n'est jamais &lt; near
  141. +// Aussi, lorsque lil-gui manipule la couleur, nous allons
  142. +// mettre à jour les couleurs du brouillard et de l'arrière-plan.
  143. class FogGUIHelper {
  144. * constructor(fog, backgroundColor) {
  145. this.fog = fog;
  146. + this.backgroundColor = backgroundColor;
  147. }
  148. get near() {
  149. return this.fog.near;
  150. }
  151. set near(v) {
  152. this.fog.near = v;
  153. this.fog.far = Math.max(this.fog.far, v);
  154. }
  155. get far() {
  156. return this.fog.far;
  157. }
  158. set far(v) {
  159. this.fog.far = v;
  160. this.fog.near = Math.min(this.fog.near, v);
  161. }
  162. + get color() {
  163. + return `#${this.fog.color.getHexString()}`;
  164. + }
  165. + set color(hexString) {
  166. + this.fog.color.set(hexString);
  167. + this.backgroundColor.set(hexString);
  168. + }
  169. }
  170. </pre>
  171. <p>Ensuite, nous appelons <code class="notranslate" translate="no">gui.addColor</code> pour ajouter une couleur à notre propriété virtuelle :</p>
  172. <pre class="prettyprint showlinemods notranslate lang-js" translate="no">{
  173. const near = 1;
  174. const far = 2;
  175. const color = 'lightblue';
  176. scene.fog = new THREE.Fog(color, near, far);
  177. scene.background = new THREE.Color(color);
  178. * const fogGUIHelper = new FogGUIHelper(scene.fog, scene.background);
  179. gui.add(fogGUIHelper, 'near', near, far).listen();
  180. gui.add(fogGUIHelper, 'far', near, far).listen();
  181. + gui.addColor(fogGUIHelper, 'color');
  182. }
  183. </pre>
  184. <p></p><div translate="no" class="threejs_example_container notranslate">
  185. <div><iframe class="threejs_example notranslate" translate="no" style=" " src="/manual/examples/resources/editor.html?url=/manual/examples/fog-gui.html"></iframe></div>
  186. <a class="threejs_center" href="/manual/examples/fog-gui.html" target="_blank">Cliquer ici pour ouvrir dans une fenêtre séparée.</a>
  187. </div>
  188. <p></p>
  189. <p>Vous pouvez voir qu'un réglage <code class="notranslate" translate="no">near</code> à 1.9 et <code class="notranslate" translate="no">far</code> à 2.0 donne une transition très nette entre non embué et complètement dans le brouillard. <code class="notranslate" translate="no">near</code> = 1.1 et <code class="notranslate" translate="no">far</code> = 2.9 devrait être la meilleure configuration étant donné que nos cubes tournent à 2 unités de la caméra.</p>
  190. <p>Une dernière chose ! Il existe une propriété <a href="/docs/#api/en/materials/Material#fog">fog</a> pour savoir si les objets rendus avec ce matériau sont affectés ou non par le brouillard. La valeur par défaut est <code class="notranslate" translate="no">true</code> pour la plupart des matériaux. Voici deux exemples illustrant cette volonté de désactiver le brouillard : imaginez que vous créez un simulateur de véhicule 3D avec une vue depuis le siège du conducteur (cockpit). Vous ne voulez pas qu'il y ait de brouillard à l'intérieur du véhicule. Prenons un second exemple : une maison avec un épais brouillard à l'extérieur. Disons que pour commencer, le brouillard est réglé pour commencer à 2 mètres (near = 2) et être total à 4 mètres (far = 4). Les pièces et la maison faisant plus de 4 mètres, il vous faudra donc définir les matériaux utilisés à l'intérieur de la maison pour qu'il n'y ait pas de brouillard, sinon, cela donnerait l'aspect non désiré suivant :</p>
  191. <div class="spread">
  192. <div>
  193. <div data-diagram="fogHouseAll" style="height: 300px;" class="border"></div>
  194. <div class="code">fog à true sur tous les objets.</div>
  195. </div>
  196. </div>
  197. <p>Remarquez que les murs et le plafond au fond de la pièce sont dans le brouillard. En désactivant le brouillard sur les matériaux de la maison, on résout ce problème.</p>
  198. <div class="spread">
  199. <div>
  200. <div data-diagram="fogHouseInsideNoFog" style="height: 300px;" class="border"></div>
  201. <div class="code">fog à true uniquement sur les matériaux extérieurs de la maison.</div>
  202. </div>
  203. </div>
  204. <p><canvas id="c"></canvas></p>
  205. <script type="module" src="../resources/threejs-fog.js"></script>
  206. </div>
  207. </div>
  208. </div>
  209. <script src="../resources/prettify.js"></script>
  210. <script src="../resources/lesson.js"></script>
  211. </body></html>