Version: 5.3 (switch to 5.4b)
言語English
  • C#
  • JS

スクリプト言語

好きな言語を選択してください。選択した言語でスクリプトコードが表示されます。

TerrainData.GetDetailLayer

フィードバック

ありがとうございます

この度はドキュメントの品質向上のためにご意見・ご要望をお寄せいただき、誠にありがとうございます。頂いた内容をドキュメントチームで確認し、必要に応じて修正を致します。

閉じる

送信に失敗しました

なんらかのエラーが発生したため送信が出来ませんでした。しばらく経ってから<a>もう一度送信</a>してください。ドキュメントの品質向上のために時間を割いて頂き誠にありがとうございます。

閉じる

キャンセル

マニュアルに切り替える
public function GetDetailLayer(xBase: int, yBase: int, width: int, height: int, layer: int): int[,];
public int[,] GetDetailLayer(int xBase, int yBase, int width, int height, int layer);

パラメーター

説明

特定のポイントでの、詳細オブジェクトの密度が格納されている 2 次元配列を返します

Terrain システムは詳細なレイヤーの密度マップを使用します。各マップは基本的に 各ピクセル値が手続き的に地形領域に配置される詳細オブジェクトの数を表すグレースケールイメージです。それはピクセルに対応します。いくつかの異なる詳細の型を使用する可能性があるため、 マップは ”レイヤー" に配置されます。 - レイヤーの配列のインデックスは( Paint Details ツールが選ばれているとき) Terrain インスペクターで定義されている詳細のタイプの順序によって決定されます。

	// Set all pixels in a detail map below a certain threshold to zero.
	function DetailMapCutoff(t: Terrain, threshold: float) {
		// Get all of layer zero.
		var map = t.terrainData.GetDetailLayer(0, 0, t.terrainData.detailWidth, t.terrainData.detailHeight, 0);
		
		// For each pixel in the detail map...
		for (var y = 0; y < t.terrainData.detailHeight; y++) {
			for (var x = 0; x < t.terrainData.detailWidth; x++) {
				// If the pixel value is below the threshold then
				// set it to zero.
				if (map[x, y] < threshold) {
					map[x, y] = 0.0;
				}
			}
		}
		
		// Assign the modified map back.
		t.terrainData.SetDetailLayer(0, 0, 0, map);
	}