1<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 2<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja" lang="ja"> 3<!-- InstanceBegin template="/Templates/default_template.dwt" codeOutsideHTMLIsLocked="false" --> 4<head> 5<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 6<meta http-equiv="Content-Style-Type" content="text/css" /> 7<!-- InstanceBeginEditable name="CSS の相対パス指定" --> 8<link href="../../../common/manual.css" rel="stylesheet" type="text/css" /> 9<!-- InstanceEndEditable --> 10<!-- InstanceBeginEditable name="ページのタイトル" --> 11<title>フラグメントライティング</title> 12<!-- InstanceEndEditable --> 13</head> 14<body> 15<div> 16 <div class="body"> <!-- InstanceBeginEditable name="本文のタイトル" --> 17 <h1>フラグメントライティング</h1> 18 <!-- InstanceEndEditable --> <!-- InstanceBeginEditable name="本文" --> 19 <p>ここでは、フラグメントライティングについて説明します。</p> 20 <p>フラグメントライティングの計算式など詳細については、別途用意されている「CTR-グラフィックス入門」を参照してください。</p> 21 <h2>フラグメントライティングとは</h2> 22 <p>頂点処理から出力された情報に対して、フラグメント単位で陰影付けを行う処理のことです。</p> 23 <p>参照テーブルを使用することで、複雑なライティング表現ができます。</p> 24 <p>図 1 法線ベクトルを補間した頂点シェーダーからの入力値に対し、フラグメント単位に陰影をつけたイメージ</p> 25 <img class="user_guide_chart" src="assets/material_pipeline_fragmentshader.png" alt="フラグメントシェーダの流れ"/> 26 <p class="new_hint">補足:<br /> 27 フラグメントライティングのクオリティはポリゴン密度の影響を受けません。</p> 28 <p>フラグメントライティングは、「頂点処理から入力された情報」をもとにして、「ライトとマテリアルの設定からライティングの計算」を行い、プライマリカラーとセカンダリカラーの 2 種類のカラーを出力します。</p> 29 <p>図 2 プライマリカラーとセカンダリカラーを出力するまでの流れ</p> 30 <img class="user_guide_chart" src="assets/fragment_lighting_light_color.png" alt="フラグメントライティング"/> 31 <h3>プライマリーカラーとセカンダリーカラー</h3> 32 <img class="user_guide_chart" src="assets/fragment_lighting_light_color2.png" alt="フラグメントライティング"/> 33 <h2>フラグメントライティングの設定</h2> 34 <p>ここでは、フラグメント単位のライティングを行う際のライトとマテリアルの設定について説明します。</p> 35 <h3>ライトの設定</h3> 36 <p>表 1 ライトの種類ごとの設定項目</p> 37 <table> 38 <thead> 39 <tr> 40 <th>カテゴリ</th> 41 <th>項目</th> 42 <th>説明</th> 43 </tr> 44 </thead> 45 <tbody> 46 <tr> 47 <th rowspan="4" class="bgcolor_g">ライトの色</th> 48 <th>アンビエントカラー<br /> 49 ( 環境光 )</th> 50 <td>マテリアルのアンビエントカラーに影響を与える、ライトの色とアルファ値です。フラグメントライトで設定します。</td> 51 </tr> 52 <tr> 53 <th>ディフューズカラー<br /> 54 ( 拡散光 )</th> 55 <td>マテリアルのディフューズカラーに影響を与える、ライトの色とアルファ値です。フラグメントライトで設定します。</td> 56 </tr> 57 <tr> 58 <th>スペキュラーカラー 0<br /> 59 ( 鏡面光 0 )</th> 60 <td>マテリアルのスペキュラーカラー 0 に影響を与える、ライト の色とアルファ値です。フラグメントライトで設定します。</td> 61 </tr> 62 <tr> 63 <th>スペキュラーカラー 1<br /> 64 ( 鏡面光 1 )</th> 65 <td>マテリアルのスペキュラーカラー 1 に影響を与える、 ライト の色とアルファ値です。フラグメントライトで設定します。</td> 66 </tr> 67 <tr> 68 <th rowspan="2" class="bgcolor_y">ライトの姿勢</th> 69 <th>位置</th> 70 <td>ライトの位置です。フラグメントライトにおいて、ワールド座標系で設定します。</td> 71 </tr> 72 <tr> 73 <th>方向</th> 74 <td>ライトの方向です。フラグメントライトにおいて、ワールド座標系で設定します。アニメーションのついているノードと階層を組むことで、上位の階層から値を受け継ぐことができます。</td> 75 </tr> 76 <tr> 77 <th rowspan="2" class="bgcolor_r">ライトの減衰率</th> 78 <th>距離減衰</th> 79 <td>光の届く距離を減衰率で指定します。ポイントライトとスポットライトで使用します。</td> 80 </tr> 81 <tr> 82 <th>スポットライト減衰</th> 83 <td>光の届く範囲を参照テーブルを用いた減衰率で指定します。スポットライトで使用します。</td> 84 </tr> 85 <tr> 86 <th class="bgcolor_b">ハイライトの調整</th> 87 <th>ジオメトリックファクタ</th> 88 <td>スペキュラーの入り方を調整します。マテリアルの設定において、有効 / 無効を決めます。</td> 89 </tr> 90 </tbody> 91 </table> 92 <a name="fragment_light_type" id="fragment_light_type"></a> 93<h4>使用できるライトの種類</h4> 94 <p>図 3 フラグメントライトで使用できるライトの種類と各ライトの光の照射</p> 95 <img class="user_guide_chart" src="assets/fragment_lighting_light_type.png" alt="ライトの種類"/> 96 <p class="new_hint">補足:<br /> 97 使用するライトを増やすとフラグメントの処理負荷が大きくなります。</p> 98 <h4>アンビエントライト</h4> 99 <p><em>アンビエントライト</em>は、ポリゴンモデル全体を均一に照らすライトです。そのため、ライトの方向や減衰などのパラメータはありません。</p> 100 <h3>マテリアルの設定</h3> 101 <p>表 2 マテリアルごとに設定できる項目</p> 102 <table> 103 <thead> 104 <tr> 105 <th>カテゴリ</th> 106 <th>項目</th> 107 <th>説明</th> 108 </tr> 109 </thead> 110 <tbody> 111 <tr> 112 <th rowspan="5" class="bgcolor_g">マテリアルの色</th> 113 <th>エミッションカラー<br /> 114 ( 放射色 )</th> 115 <td>物体を全体的に明るくする色です。マテリアルで設定します。</td> 116 </tr> 117 <tr> 118 <th>アンビエントカラー<br /> 119 ( 環境色 )</th> 120 <td>物体の陰側を表現する色です。マテリアルで設定します。</td> 121 </tr> 122 <tr> 123 <th>ディフューズカラー<br /> 124 ( 拡散色 )</th> 125 <td>物体表面の質感を表現する色です。マテリアルで設定します。</td> 126 </tr> 127 <tr> 128 <th>スペキュラーカラー 0<br /> 129 ( 鏡面色 0 )</th> 130 <td>物体のハイライトを表現する色です。マテリアルで設定します。</td> 131 </tr> 132 <tr> 133 <th>スペキュラーカラー 1<br /> 134 ( 鏡面色 1 )</th> 135 <td>物体のハイライトを表現する色です。マテリアルで設定します。</td> 136 </tr> 137 <tr> 138 <th class="bgcolor_y">シーン全体の環境光</th> 139 <th>グローバルアンビエントカラー</th> 140 <td>シーンに配置された複数の物体全体をなじませる、環境光を表現する色です。フラグメントライトで設定します。</td> 141 </tr> 142 <tr> 143 <th rowspan="4" class="bgcolor_r">ハイライトの制御</th> 144 <th>分布 0</th> 145 <td>参照テーブルを使用することで、スペキュラーカラー 0 のハイライト形状を制御します。</td> 146 </tr> 147 <tr> 148 <th>分布 1</th> 149 <td>参照テーブルを使用することで、スペキュラーカラー 1 のハイライト形状を制御します。</td> 150 </tr> 151 <tr> 152 <th>反射</th> 153 <td>参照テーブルを使用することで、スペキュラーカラーの色を R 、 G 、 B 、 各成分ごとに制御します。</td> 154 </tr> 155 <tr> 156 <th>フレネル</th> 157 <td>参照テーブルを使用することで、スペキュラーのアルファ成分を制御します。</td> 158 </tr> 159 </tbody> 160 </table> 161 <h4>マテリアルカラー</h4> 162 <p>マテリアルカラーとは、フラグメントライティングの計算に必要なポリゴンモデルのカラーです。 </p> 163 <p>5 種類のカラーを設定できます。</p> 164 <p>図 4 左上方向から光があてられた球体モデル</p> 165 <img class="user_guide_chart" src="assets/fragment_lighting_material_color.png" alt="マテリアルカラーの部位"/> 166 <p>上図は、左上方向から光があてられた球体モデルで、各マテリアルカラーが反映される場所を示したものです。</p> 167 <a name="geometric_factor" id="geometric_factor"></a> 168 <h4>ジオメトリファクタ</h4> 169 <p>ジオメトリファクタとは、スペキュラーの見え方を調整する為の機能です。</p> 170 <p>この機能を使用することにより、スペキュラーが視線方向に対して正面に入るときは弱く、側面に入るときは強く見えます。</p> 171 <p>「ジオメトリファクタ 0 はスペキュラーカラー 0」 に「ジオメトリファクタ 1 はスペキュラーカラー 1」 に対して影響します。</p> 172 <p>図 5 ジオメトリファクタの機能を使用したときと使用しないときの見え方の違い</p> 173 <img class="user_guide_chart" src="assets/fragment_lighting_geometric_factor.png" alt="ジオメトリックファクタ"/> <a name="distribution" id="distribution"></a> 174 <h4>分布 ( スペキュラー成分の形状 )</h4> 175 <p>分布とは、セカンダリカラーの計算として、スペキュラーの形状に変化を与える要素です。</p> 176 <p>分布の設定は参照テーブルを使って行います。</p> 177 <p>分布 0 はスペキュラーカラー 0 に、分布 1 はスペキュラーカラー 1 に対して影響します。 </p> 178 <p>図 6 参照テーブルを使用したスペキュラー形状の制御</p> 179 <img class="user_guide_chart" src="assets/fragment_lighting_distribution.png" alt="分布"/> <a name="reflection" id="reflection"></a> 180 <h4>反射</h4> 181 <p>反射とは、セカンダリカラーの計算として、スペキュラーの色を制御する要素です。</p> 182 <p>反射の設定は参照テーブルを使って行います。</p> 183 <p>図 7 参照テーブルを使用したスペキュラーカラーの制御</p> 184 <img class="user_guide_chart" src="assets/fragment_lighting_reflection.png" alt="反射"/> 185 <h4>フレネル</h4> 186 <p>フレネルとは、セカンダリカラーの計算として、マテリアルの透明度 ( アルファ値 ) を制御する要素です。</p> 187 <p>フレネルの設定は参照テーブルを使って行います。</p> 188 <p>図 8 フレネルによる表現</p> 189 <img class="user_guide_chart" src="assets/fragment_lighting_fresnel.png" alt="フレネル"/> <!-- InstanceEndEditable --> </div> 190 <div class="footer" /> 191</div> 192</body> 193<!-- InstanceEnd --> 194</html> 195