Difference between revisions of "Documentation:Tutorial Section 3.6"

From POV-Wiki
Jump to navigation Jump to search
 
m (link repair after build error)
 
(11 intermediate revisions by 3 users not shown)
Line 7: Line 7:
 
<br>
 
<br>
 
<!--</wikitalk>--->
 
<!--</wikitalk>--->
===Using Multiple Layers of Fog===
+
<!--REMOVE--->===Using Atmospheric Effects===<!--THIS--->
<!--<indexentry "Fog, using multiple layers of">--->
+
<!--REMOVE--->====The Fog====<!--THIS--->
 +
=====Using Multiple Layers of Fog=====
 +
{{#indexentry:Fog, using multiple layers of}}
 
<p>It is possible to use several layers of fog by using more than one fog
 
<p>It is possible to use several layers of fog by using more than one fog
 
statement in your scene file. This is quite useful if you want to get nice
 
statement in your scene file. This is quite useful if you want to get nice
Line 43: Line 45:
 
</pre>
 
</pre>
  
<p>[[Image:TutImgMultifog.png|Using multiple layers of fog.]]</p>
+
<table class="centered" width="340px" cellpadding="0" cellspacing="10">
 +
<tr>
 +
  <td>
 +
    [[Image:TutImgMultifog.png|center|320px<!--center--->]]
 +
  </td>
 +
</tr>
 +
<tr>
 +
  <td>
 +
    <p class="caption">Using multiple layers of fog.</p>
 +
  </td>
 +
</tr>
 +
</table>
  
 
<p>You can combine constant density fogs, ground fogs, filtering fogs,
 
<p>You can combine constant density fogs, ground fogs, filtering fogs,
 
non-filtering fogs, fogs with a translucency threshold, etc.</p>
 
non-filtering fogs, fogs with a translucency threshold, etc.</p>
===Fog and Hollow Objects===
+
=====Fog and Hollow Objects=====
<!--<indexentry "Fog, hollow objects" "Hollow Objects, fog inside">--->
+
{{#indexentry:Fog, hollow objects}}
 +
{{#indexentry:Hollow Objects, fog inside}}
 
<p>Whenever you use the fog feature and the camera is inside a non-hollow
 
<p>Whenever you use the fog feature and the camera is inside a non-hollow
 
object you will not get any fog effects. For a detailed explanation why this
 
object you will not get any fog effects. For a detailed explanation why this
happens see &quot;<!--<linkto "Empty and Solid Objects">Empty and Solid Objects</linkto>--->[[Documentation:Reference Section 6#Empty and Solid Objects|Empty and Solid Objects]]&quot;.</p>
+
happens see [[Reference:Interior#Empty and Solid Objects|Empty and Solid Objects]].</p>
 
<p>
 
<p>
 
In order to avoid this problem you have to make all those objects hollow by
 
In order to avoid this problem you have to make all those objects hollow by
either making sure the camera is outside these objects (using the <code><!--<linkto "inverse">inverse</linkto>--->[[Documentation:Reference Section 4.5#Inverse|inverse]]</code>
+
either making sure the camera is outside these objects (using the <code>[[Reference:Inverse Object Modifier|inverse]]</code>
keyword) or by adding the <code><!--<linkto "hollow">hollow</linkto>--->[[Documentation:Reference Section 4.5#Hollow|hollow]]</code> to them (which is much easier).</p>
+
keyword) or by adding the <code>[[Reference:Hollow Object Modifier|hollow]]</code> to them (which is much easier).</p>
  
===The Rainbow===
+
====The Rainbow====
<!--<indexentry "Rainbow, the" "rainbow, tutorial">--->
+
{{#indexentry:Rainbow, the}}
<p>The <code><!--<linkto "rainbow">rainbow</linkto>--->[[Documentation:Reference Section 3.1#Rainbow|rainbow]]</code> feature can be used
+
{{#indexentry:rainbow, tutorial}}
 +
<p>The <code>[[Reference:Rainbow|rainbow]]</code> feature can be used
 
to create rainbows and maybe other more strange effects. The rainbow is a fog
 
to create rainbows and maybe other more strange effects. The rainbow is a fog
 
like effect that is restricted to a cone-like volume.</p>
 
like effect that is restricted to a cone-like volume.</p>
  
===Starting With a Simple Rainbow===
+
=====Starting With a Simple Rainbow=====
<!--<indexentry "Rainbow, simple">--->
+
{{#indexentry:Rainbow, simple}}
 
<p>The rainbow is specified with a lot of parameters: the angle under which
 
<p>The rainbow is specified with a lot of parameters: the angle under which
 
it is visible, the width of the color band, the direction of the incoming
 
it is visible, the width of the color band, the direction of the incoming
Line 70: Line 85:
 
the color map to be used.</p>
 
the color map to be used.</p>
 
<p>
 
<p>
The size and shape of the rainbow are determined by the <code><!--<linkto "angle">angle</linkto>--->[[Documentation:Reference Section 3.1#Rainbow|angle]]</code>
+
The size and shape of the rainbow are determined by the <code>[[Reference:Rainbow|angle]]</code>
and <code><!--<linkto "width">width</linkto>--->[[Documentation:Reference Section 3.1#Rainbow|width]]</code> keywords. The <code><!--<linkto "direction">direction</linkto>--->[[Documentation:Reference Section 3.1#Rainbow|width]]</code>
+
and <code>[[Reference:Rainbow|width]]</code> keywords. The <code>[[Reference:Rainbow|width]]</code>
 
keyword is used to set the direction of the incoming light, thus setting the
 
keyword is used to set the direction of the incoming light, thus setting the
 
rainbow's position. The rainbow is visible when the angle between the direction
 
rainbow's position. The rainbow is visible when the angle between the direction
Line 142: Line 157:
 
</pre>
 
</pre>
  
<p>Some irregularity is added to the color bands using the <code><!--<linkto "jitter">jitter</linkto>--->[[Documentation:Tutorial Section 3.8#Do Not Use Jitter Or Crand|jitter]]</code> keyword.</p>
+
<p>Some irregularity is added to the color bands using the <!--<linkto "jitter">jitter</linkto>---><code>[[Documentation:Tutorial Section 3.8#Do Not Use Jitter Or Crand|jitter]]</code> keyword.</p>
  
<p>[[Image:TutImgCrainbow.png|A colorful rainbow.]]</p>
+
<table class="centered" width="340px" cellpadding="0" cellspacing="10">
 +
<tr>
 +
  <td>
 +
    [[Image:TutImgCrainbow.png|center|320px<!--center--->]]
 +
  </td>
 +
</tr>
 +
<tr>
 +
  <td>
 +
    <p class="caption">A colorful rainbow.</p>
 +
  </td>
 +
</tr>
 +
</table>
  
 
<p>The rainbow in our sample is much too bright. You will never see a
 
<p>The rainbow in our sample is much too bright. You will never see a
Line 150: Line 176:
 
decreasing the RGB values in the color map.</p>
 
decreasing the RGB values in the color map.</p>
  
===Increasing the Rainbow's Translucency===
+
=====Increasing the Rainbow's Translucency=====
<!--<indexentry "Rainbow, increasing translucency of">--->
+
{{#indexentry:Rainbow, increasing translucency of}}
 
<p>The result we have so far looks much too bright. Just reducing the
 
<p>The result we have so far looks much too bright. Just reducing the
 
rainbow's color helps but it is much better to increase the
 
rainbow's color helps but it is much better to increase the
Line 185: Line 211:
 
make it softly blend into the background.</p>
 
make it softly blend into the background.</p>
  
<p>[[Image:TutImgRrainbow.png|A much more realistic rainbow.]]</p>
+
<table class="centered" width="340px" cellpadding="0" cellspacing="10">
 +
<tr>
 +
  <td>
 +
    [[Image:TutImgRrainbow.png|center|320px<!--center--->]]
 +
  </td>
 +
</tr>
 +
<tr>
 +
  <td>
 +
    <p class="caption">A much more realistic rainbow.</p>
 +
  </td>
 +
</tr>
 +
</table>
  
 
<p>The resulting image looks much more realistic than our first rainbow.</p>
 
<p>The resulting image looks much more realistic than our first rainbow.</p>
===Using a Rainbow Arc===
+
=====Using a Rainbow Arc=====
<!--<indexentry "Rainbow, using an arc">--->
+
{{#indexentry:Rainbow, using an arc}}
 
<p>Currently our rainbow has a circular shape, even though most of it is
 
<p>Currently our rainbow has a circular shape, even though most of it is
 
hidden below the ground plane. You can easily create a rainbow arc by using
 
hidden below the ground plane. You can easily create a rainbow arc by using
the <code><!--<linkto "arc_angle">arc_angle</linkto>--->[[Documentation:Reference Section 3.1#Rainbow|arc_angle]]</code> keyword with an angle below 360 degrees.</p>
+
the <code>[[Reference:Rainbow|arc_angle]]</code> keyword with an angle below 360 degrees.</p>
 
<p>
 
<p>
 
If you use <code>arc_angle 120</code> for example you will get a rainbow
 
If you use <code>arc_angle 120</code> for example you will get a rainbow
 
arc that abruptly vanishes at the arc's ends. This does not look good. To
 
arc that abruptly vanishes at the arc's ends. This does not look good. To
avoid this the <code><!--<linkto "falloff_angle">falloff_angle</linkto>--->[[Documentation:Reference Section 3.1#Rainbow|falloff_angle]]</code> keyword can be used to specify a
+
avoid this the <code>[[Reference:Rainbow|falloff_angle]]</code> keyword can be used to specify a
 
region where the arc smoothly blends into the background.</p>
 
region where the arc smoothly blends into the background.</p>
 
<p>
 
<p>
As explained in the rainbow's reference section (see
+
As explained in the rainbow's reference section (see [[Reference:Rainbow|Rainbow]]) the arc extends from -arc_angle/2 to arc_angle/2 while
&quot;<!--<linkto "Rainbow">Rainbow</linkto>--->[[Documentation:Reference Section 3.1#Rainbow|Rainbow]]&quot;) the arc extends from -arc_angle/2 to arc_angle/2 while
 
 
the blending takes place from -arc_angle/2 to -falloff_angle/2 and
 
the blending takes place from -arc_angle/2 to -falloff_angle/2 and
 
falloff_angle/2 to arc_angle/2. This is the reason why the <code>falloff_angle</code>
 
falloff_angle/2 to arc_angle/2. This is the reason why the <code>falloff_angle</code>
Line 234: Line 270:
 
the y-axis.</p>
 
the y-axis.</p>
  
<p>[[Image:TutImgArainbow.png|A rainbow arc.]]</p>
+
<table class="centered" width="340px" cellpadding="0" cellspacing="10">
 +
<tr>
 +
  <td>
 +
    [[Image:TutImgArainbow.png|center|320px<!--center--->]]
 +
  </td>
 +
</tr>
 +
<tr>
 +
  <td>
 +
    <p class="caption">A rainbow arc.</p>
 +
  </td>
 +
</tr>
 +
</table>
  
 
<p>We finally have a realistic looking rainbow arc.</p>
 
<p>We finally have a realistic looking rainbow arc.</p>
  
 
===Simple Media Tutorial===
 
===Simple Media Tutorial===
<!--<indexentry "media, tutorial">--->
+
{{#indexentry:media, tutorial}}
 
<p>Media in POV-Ray is a very versatile feature and can be used for a very
 
<p>Media in POV-Ray is a very versatile feature and can be used for a very
 
diverse set of special effects such as glows, smoke, dust, fog, etc. However, due to its versatility, media is not one of the easiest and simplest features of  
 
diverse set of special effects such as glows, smoke, dust, fog, etc. However, due to its versatility, media is not one of the easiest and simplest features of  
 
POV-Ray and often requires experience for getting things to look good.</p>
 
POV-Ray and often requires experience for getting things to look good.</p>
  
 
+
====Types of media====
===Types of media===
 
 
<p>There are three types of media in POV-Ray: Emitting, absorbing and
 
<p>There are three types of media in POV-Ray: Emitting, absorbing and
scattering. They have the following properties:  
+
scattering. They have the following properties:</p>
 
<ul>
 
<ul>
 
   <li>Emitting: This is an additive media, which is handled as if it only emits
 
   <li>Emitting: This is an additive media, which is handled as if it only emits
Line 264: Line 310:
 
media).</li>
 
media).</li>
 
</ul>
 
</ul>
</p>
 
  
 
<p>Emitting and absorbing medias are the simplest and thus fastest ones.  
 
<p>Emitting and absorbing medias are the simplest and thus fastest ones.  
Line 277: Line 322:
 
for smoke or fog with visible lightbeams and shadows.</p>
 
for smoke or fog with visible lightbeams and shadows.</p>
  
===Some media concepts===
+
====Some media concepts====
 
<p>Media can be global to the whole universe, or it can be contained by an  
 
<p>Media can be global to the whole universe, or it can be contained by an  
 
object. In the latter case the media is defined in the <code>interior</code>  
 
object. In the latter case the media is defined in the <code>interior</code>  
Line 294: Line 339:
 
various effects (such as smoke with certain shape). </p>
 
various effects (such as smoke with certain shape). </p>
  
 +
====Simple media examples====
  
===Simple media examples===
+
=====Emitting media=====
 
 
===Emitting media===
 
 
<p>Let's start with a very simple scene showing an emitting media using a  
 
<p>Let's start with a very simple scene showing an emitting media using a  
 
spherical density map. Emitting media is used with the <code>emission</code>  
 
spherical density map. Emitting media is used with the <code>emission</code>  
Line 332: Line 376:
 
</pre>
 
</pre>
  
<p>Note that the <code>spherical</code> pattern gets values from 0 in the outer  
+
<p class="Note"><strong>Note:</strong> The <code>spherical</code> pattern gets values from 0 in the outer  
 
surface of a unit sphere to 1 in the origin (that is, the density with the index  
 
surface of a unit sphere to 1 in the origin (that is, the density with the index  
 
value 1 will be the density at the center of the media).</p>
 
value 1 will be the density at the center of the media).</p>
Line 342: Line 386:
 
all in that location. </p>
 
all in that location. </p>
  
<p>Note that the density map colors are multiplied by the color given with the  
+
<p class="Note"><strong>Note: </strong>The density map colors are multiplied by the color given with the <code>emission</code> keyword; since 1 is used in this case, the density map colors are not affected.</p>
<code>emission</code> keyword; since 1 is used in this case, the density map  
 
colors are not affected.</p>
 
  
 
<p>Thus, this will give us a media with a bright white center which fades to  
 
<p>Thus, this will give us a media with a bright white center which fades to  
 
yellow and red at the outer limits of the unit sphere: </p>
 
yellow and red at the outer limits of the unit sphere: </p>
  
<p>[[Image:TutImgMediatut1.png|Simple emitting media example]]</p>
+
<table class="centered" width="340px" cellpadding="0" cellspacing="10">
 +
<tr>
 +
  <td>
 +
    [[Image:TutImgMediatut1.png|center|320px<!--center--->]]
 +
  </td>
 +
</tr>
 +
<tr>
 +
  <td>
 +
    <p class="caption">Simple emitting media example</p>
 +
  </td>
 +
</tr>
 +
</table>
  
 
<p>As you can see from the image, the emitting media is invisible against white  
 
<p>As you can see from the image, the emitting media is invisible against white  
Line 356: Line 409:
 
backgrounds. </p>
 
backgrounds. </p>
  
 
+
=====Absorbing media=====
===Absorbing media===
 
 
<p>Modifying the previous example to use absorbing media is rather simple:  
 
<p>Modifying the previous example to use absorbing media is rather simple:  
 
Simply change the <code>emission</code> keyword for <code>absorption</code>.  
 
Simply change the <code>emission</code> keyword for <code>absorption</code>.  
Line 377: Line 429:
 
</pre>
 
</pre>
  
<p>[[Image:TutImgMediatut2.png|Simple absorbing media example]] </p>
+
<table class="centered" width="340px" cellpadding="0" cellspacing="10">
 +
<tr>
 +
  <td>
 +
    [[Image:TutImgMediatut2.png|center|320px<!--center--->]]
 +
  </td>
 +
</tr>
 +
<tr>
 +
  <td>
 +
    <p class="caption">Simple absorbing media example</p>
 +
  </td>
 +
</tr>
 +
</table>
  
 
<p>The feature which we immediately notice in the image is that the media seems  
 
<p>The feature which we immediately notice in the image is that the media seems  
Line 387: Line 450:
 
density map will absorb all colors, thus resulting in a dark media. </p>
 
density map will absorb all colors, thus resulting in a dark media. </p>
  
<p>Note how this media has a shadow: light rays passing through the media are  
+
<p>See how this media has a shadow: light rays passing through the media are absorbed.</p>
absorbed.</p>
 
 
 
<p>Because of its substractive nature, absorbing media works well with light
 
backgrounds and not very well with dark ones.</p>
 
  
 +
<p>Because of its subtractive nature, absorbing media works well with light backgrounds and not very well with dark ones.</p>
  
===Scattering media===
+
=====Scattering media=====
 
<p>Since scattering media fully takes light sources into account we need to make  
 
<p>Since scattering media fully takes light sources into account we need to make  
 
a slightly more complex scene to see this. Let's modify the above example by  
 
a slightly more complex scene to see this. Let's modify the above example by  
Line 415: Line 475:
 
</pre>
 
</pre>
  
<p>[[Image:TutImgMediatut3.png|Simple scattering media example]]</p>
+
<table class="centered" width="340px" cellpadding="0" cellspacing="10">
 +
<tr>
 +
  <td>
 +
    [[Image:TutImgMediatut3.png|center|320px<!--center--->]]
 +
  </td>
 +
</tr>
 +
<tr>
 +
  <td>
 +
    <p class="caption">Simple scattering media example</p>
 +
  </td>
 +
</tr>
 +
</table>
  
 
<p>(The effect may look a bit unnatural for a fog effect because the media is  
 
<p>(The effect may look a bit unnatural for a fog effect because the media is  
Line 424: Line 495:
 
The first number inside the curly brackets is the scattering media type. In this  
 
The first number inside the curly brackets is the scattering media type. In this  
 
example we used scattering media type 1. A full list of scattering media types  
 
example we used scattering media type 1. A full list of scattering media types  
is given in the section <code><!--<linkto "scattering"> scattering </linkto>--->[[Documentation:Reference Section 6.1#Scattering| scattering ]]</code> of the Media reference.</p>  
+
is given in the section [[Reference:Media Types#Scattering|scattering]] of the Media reference.</p>  
  
 
<p>The second parameter is the overall color of the media, similar to the  
 
<p>The second parameter is the overall color of the media, similar to the  
Line 434: Line 505:
 
as when the media absorbs too much light.</p>  
 
as when the media absorbs too much light.</p>  
  
<p>Tip: If you are getting a really dense or dark scattering media, try  
+
<p><strong>Tip:</strong> If you are getting a really dense or dark scattering media, try  
 
different values for the color and the extinction value (usually values between  
 
different values for the color and the extinction value (usually values between  
 
0 and 1). It is usually enough to play with these two values to get the desired  
 
0 and 1). It is usually enough to play with these two values to get the desired  

Latest revision as of 17:04, 17 December 2016

This document is protected, so submissions, corrections and discussions should be held on this documents talk page.


Using Atmospheric Effects

The Fog

Using Multiple Layers of Fog

It is possible to use several layers of fog by using more than one fog statement in your scene file. This is quite useful if you want to get nice effects using turbulent ground fogs. You could add up several, differently colored fogs to create an eerie scene for example.

Just try the following example (fog6.pov).

  fog {
    distance 150
    color rgb<0.3, 0.5, 0.2>
    fog_type 2
    fog_offset 25
    fog_alt 1
    turbulence 0.1
    turb_depth 0.2
  }
  fog {
    distance 150
    color rgb<0.5, 0.1, 0.1>
    fog_type 2
    fog_offset 15
    fog_alt 4
    turbulence 0.2
    turb_depth 0.2
  }
  fog {
    distance 150
    color rgb<0.1, 0.1, 0.6>
    fog_type 2
    fog_offset 10
    fog_alt 2
  }
TutImgMultifog.png

Using multiple layers of fog.

You can combine constant density fogs, ground fogs, filtering fogs, non-filtering fogs, fogs with a translucency threshold, etc.

Fog and Hollow Objects

Whenever you use the fog feature and the camera is inside a non-hollow object you will not get any fog effects. For a detailed explanation why this happens see Empty and Solid Objects.

In order to avoid this problem you have to make all those objects hollow by either making sure the camera is outside these objects (using the inverse keyword) or by adding the hollow to them (which is much easier).

The Rainbow

The rainbow feature can be used to create rainbows and maybe other more strange effects. The rainbow is a fog like effect that is restricted to a cone-like volume.

Starting With a Simple Rainbow

The rainbow is specified with a lot of parameters: the angle under which it is visible, the width of the color band, the direction of the incoming light, the fog-like distance based particle density and last but not least the color map to be used.

The size and shape of the rainbow are determined by the angle and width keywords. The width keyword is used to set the direction of the incoming light, thus setting the rainbow's position. The rainbow is visible when the angle between the direction vector and the incident light direction is larger than angle-width/2 and smaller than angle+width/2.

The incoming light is the virtual light source that is responsible for the rainbow. There need not be a real light source to create the rainbow effect.

The rainbow is a fog-like effect, i.e. the rainbow's color is mixed with the background color based on the distance to the intersection point. If you choose small distance values the rainbow will be visible on objects, not just in the background. You can avoid this by using a very large distance value.

The color map is the crucial part of the rainbow since it contains all the colors that normally can be seen in a rainbow. The color of the innermost color band is taken from the color map entry 0 while the outermost band is take from entry 1. You should note that due to the limited color range any monitor can display it is impossible to create a real rainbow. There are just some colors that you cannot display.

The filter channel of the rainbow's color map is used in the same way as with fogs. It determines how much of the light passing through the rainbow is filtered by the color.

The following example shows a simple scene with a ground plane, three spheres and a somewhat exaggerated rainbow (rainbow1.pov).

  #include "colors.inc"
  camera {
    location <0, 20, -100>
    look_at <0, 25, 0>
    angle 80
  }
  background { color SkyBlue }
  plane { y, -10 pigment { color Green } }
  light_source { <100, 120, 40> color White }
  // declare rainbow's colors
  #declare r_violet1 = color rgbf<1.0, 0.5, 1.0, 1.0>;
  #declare r_violet2 = color rgbf<1.0, 0.5, 1.0, 0.8>;
  #declare r_indigo  = color rgbf<0.5, 0.5, 1.0, 0.8>;
  #declare r_blue    = color rgbf<0.2, 0.2, 1.0, 0.8>;
  #declare r_cyan    = color rgbf<0.2, 1.0, 1.0, 0.8>;
  #declare r_green   = color rgbf<0.2, 1.0, 0.2, 0.8>;
  #declare r_yellow  = color rgbf<1.0, 1.0, 0.2, 0.8>;
  #declare r_orange  = color rgbf<1.0, 0.5, 0.2, 0.8>;
  #declare r_red1    = color rgbf<1.0, 0.2, 0.2, 0.8>;
  #declare r_red2    = color rgbf<1.0, 0.2, 0.2, 1.0>;
  // create the rainbow
  rainbow {
    angle 42.5
    width 5
    distance 1.0e7
    direction <-0.2, -0.2, 1>
    jitter 0.01
    color_map {
      [0.000  color r_violet1]
      [0.100  color r_violet2]
      [0.214  color r_indigo]
      [0.328  color r_blue]
      [0.442  color r_cyan]
      [0.556  color r_green]
      [0.670  color r_yellow]
      [0.784  color r_orange]
      [0.900  color r_red1]
    }
  }

Some irregularity is added to the color bands using the jitter keyword.

TutImgCrainbow.png

A colorful rainbow.

The rainbow in our sample is much too bright. You will never see a rainbow like this in reality. You can decrease the rainbow's colors by decreasing the RGB values in the color map.

Increasing the Rainbow's Translucency

The result we have so far looks much too bright. Just reducing the rainbow's color helps but it is much better to increase the translucency of the rainbow because it is more realistic if the background is visible through the rainbow.

We can use the transmittance channel of the colors in the color map to specify a minimum translucency, just like we did with the fog. To get realistic results we have to use very large transmittance values as you can see in the following example (rainbow2.pov).

  rainbow {
    angle 42.5
    width 5
    distance 1.0e7
    direction <-0.2, -0.2, 1>
    jitter 0.01
    color_map {
      [0.000  color r_violet1 transmit 0.98]
      [0.100  color r_violet2 transmit 0.96]
      [0.214  color r_indigo  transmit 0.94]
      [0.328  color r_blue    transmit 0.92]
      [0.442  color r_cyan    transmit 0.90]
      [0.556  color r_green   transmit 0.92]
      [0.670  color r_yellow  transmit 0.94]
      [0.784  color r_orange  transmit 0.96]
      [0.900  color r_red1    transmit 0.98]
    }
  }

The transmittance values increase at the outer bands of the rainbow to make it softly blend into the background.

TutImgRrainbow.png

A much more realistic rainbow.

The resulting image looks much more realistic than our first rainbow.

Using a Rainbow Arc

Currently our rainbow has a circular shape, even though most of it is hidden below the ground plane. You can easily create a rainbow arc by using the arc_angle keyword with an angle below 360 degrees.

If you use arc_angle 120 for example you will get a rainbow arc that abruptly vanishes at the arc's ends. This does not look good. To avoid this the falloff_angle keyword can be used to specify a region where the arc smoothly blends into the background.

As explained in the rainbow's reference section (see Rainbow) the arc extends from -arc_angle/2 to arc_angle/2 while the blending takes place from -arc_angle/2 to -falloff_angle/2 and falloff_angle/2 to arc_angle/2. This is the reason why the falloff_angle has to be smaller or equal to the arc_angle.

In the following examples we use an 120 degrees arc with a 45 degree falloff region on both sides of the arc (rainbow3.pov).

  rainbow {
    angle 42.5
    width 5
    arc_angle 120
    falloff_angle 30
    distance 1.0e7
    direction <-0.2, -0.2, 1>
    jitter 0.01
    color_map {
      [0.000  color r_violet1 transmit 0.98]
      [0.100  color r_violet2 transmit 0.96]
      [0.214  color r_indigo  transmit 0.94]
      [0.328  color r_blue    transmit 0.92]
      [0.442  color r_cyan    transmit 0.90]
      [0.556  color r_green   transmit 0.92]
      [0.670  color r_yellow  transmit 0.94]
      [0.784  color r_orange  transmit 0.96]
      [0.900  color r_red1    transmit 0.98]
    }
  }

The arc angles are measured against the rainbows up direction which can be specified using the up keyword. By default the up direction is the y-axis.

TutImgArainbow.png

A rainbow arc.

We finally have a realistic looking rainbow arc.

Simple Media Tutorial

Media in POV-Ray is a very versatile feature and can be used for a very diverse set of special effects such as glows, smoke, dust, fog, etc. However, due to its versatility, media is not one of the easiest and simplest features of POV-Ray and often requires experience for getting things to look good.

Types of media

There are three types of media in POV-Ray: Emitting, absorbing and scattering. They have the following properties:

  • Emitting: This is an additive media, which is handled as if it only emits light (note: it does not emit light to its surroundings like a light_source does; this just describes how it affects the rays going through it). That is, the color of the media is added to the color of the ray passing through it. Light sources do not have any effect at all in it (ie. it does not affect shadows in any way).
  • Absorbing: This is a substractive media. This media substracts (absorbs) its coloration from the ray passing through it. Light sources are taken into account only in the shadow of the media (that is, absorbing media casts a shadow).
  • Scattering: This is the most advanced media type as it fully takes into account light passing through it. That is, this media is lit by light sources (and thus, for example, nearby objects can cast shadows into the scattering media).

Emitting and absorbing medias are the simplest and thus fastest ones. Emitting media can be used for things like glows, lasers, sparkles and similar light-emitting effects. Absorbing media can be used for things like smoke and fog (the difference between the fog feature of POV-Ray is that the density of an absorbing media can be modified by a pattern and the media can be contained inside an object).

Scattering media is the more advanced and slower type. It is somewhat similar to absorbing media except that it is fully lit by light sources. This can be used for smoke or fog with visible lightbeams and shadows.

Some media concepts

Media can be global to the whole universe, or it can be contained by an object. In the latter case the media is defined in the interior block of the object definition.

For an object to be able to contain media (or to allow media from other objects or the global media inside itself) it has to be defined as hollow (a common mistake is to forget adding this keyword). If an object with no media should not allow media inside itself (eg. a solid glass ball), then hollow should not be defined for that object.

If media is defined in the interior of an object or as a global media it will have a constant density throughout the object/universe. However, a density pattern can be specified for non-uniform media. Also all kinds of transformations can be applied to the media. This is specially useful for various effects (such as smoke with certain shape).

Simple media examples

Emitting media

Let's start with a very simple scene showing an emitting media using a spherical density map. Emitting media is used with the emission keyword followed by a color value. This color value tells the overall color of the media:

 global_settings { assumed_gamma 1 }
 background { rgb 1 }
 camera { location <3,4,-5>*.8 look_at 0 angle 35 }
 light_source { <20,40,10>, 1 }

 box // floor
 { <-1.5,-1.01,-1.5>, <1.5,-1.2,1.5>
   pigment { checker rgb 0.75, rgb 0.25 scale 0.2 }
 }

 sphere // transparent sphere containing media
 { 0,1 pigment { rgbt 1 } hollow
   interior
   { media
     { emission 1
       density
       { spherical density_map
         { [0 rgb 0]
           [0.4 rgb <1,0,0>]
           [0.8 rgb <1,1,0>]
           [1 rgb 1]
         }
       }
     }
  }
 }

Note: The spherical pattern gets values from 0 in the outer surface of a unit sphere to 1 in the origin (that is, the density with the index value 1 will be the density at the center of the media).

The color values in the density map tell what color the media is emitting at a certain point in the pattern. That is, for example when the pattern gets the value 0.4, the media will be completely red at that place. If the color is <0,0,0>, it means that the media does not emit any light at all in that location.

Note: The density map colors are multiplied by the color given with the emission keyword; since 1 is used in this case, the density map colors are not affected.

Thus, this will give us a media with a bright white center which fades to yellow and red at the outer limits of the unit sphere:

TutImgMediatut1.png

Simple emitting media example

As you can see from the image, the emitting media is invisible against white background. This is due to its additive nature (any color added to pure white gives pure white). In fact, emitting media gives usually best results for dark backgrounds.

Absorbing media

Modifying the previous example to use absorbing media is rather simple: Simply change the emission keyword for absorption. However, the colors we used above are not very illustrative for absorbing media, so let's change them a bit like this:

    media
    { absorption 1
      density
      { spherical density_map
        { [0 rgb 0]
          [0.4 rgb 0]
          [0.5 rgb <0,0.5,1>]
          [1 rgb <0,1,1>]
        }
      }
    }
TutImgMediatut2.png

Simple absorbing media example

The feature which we immediately notice in the image is that the media seems to be inverted from the colors specified in the density map: Blueish colors were specified in the map, but the image shows a reddish media. This is perfectly normal and to be expected from the substractive nature of absorbing media: The media actually absorbs the colors we specified in the density map. This means that for example specifying a white color (<1,1,1>) in the density map will absorb all colors, thus resulting in a dark media.

See how this media has a shadow: light rays passing through the media are absorbed.

Because of its subtractive nature, absorbing media works well with light backgrounds and not very well with dark ones.

Scattering media

Since scattering media fully takes light sources into account we need to make a slightly more complex scene to see this. Let's modify the above example by replacing the sphere with a box containing evenly distributed scattering media, and a cylinder which will cast a shadow onto the media:

 box
 { -1,1 pigment { rgbt 1 } hollow
   interior
   { media
     { scattering { 1, 0.5 }
     }
   }
 }
 cylinder
 { <0.9, -1, 0.7>, <0.9, 0.9, 0.7>, 0.5
   pigment { rgb <1, 0.8, 0.5> }
 }
TutImgMediatut3.png

Simple scattering media example

(The effect may look a bit unnatural for a fog effect because the media is contained inside a box and the cylinder is partially out of this box, but this is done to better visualize what is happening.)

The scattering keyword takes more parameters than the other two. The first number inside the curly brackets is the scattering media type. In this example we used scattering media type 1. A full list of scattering media types is given in the section scattering of the Media reference.

The second parameter is the overall color of the media, similar to the parameter of the other two media types.

An optional third parameter can be given with the extinction keyword inside the curly brackets. This keyword controls how fast the scattering media absorbs light and has to be used sometimes to get the desired effect, such as when the media absorbs too much light.

Tip: If you are getting a really dense or dark scattering media, try different values for the color and the extinction value (usually values between 0 and 1). It is usually enough to play with these two values to get the desired effect.


Using Ground Fog Multiple medias inside the same object


This document is protected, so submissions, corrections and discussions should be held on this documents talk page.