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

スクリプト言語

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

Matrix4x4.TRS

フィードバック

ありがとうございます

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

閉じる

送信に失敗しました

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

閉じる

キャンセル

マニュアルに切り替える
public static function TRS(pos: Vector3, q: Quaternion, s: Vector3): Matrix4x4;
public static Matrix4x4 TRS(Vector3 pos, Quaternion q, Vector3 s);

パラメーター

説明

移動、回転やスケーリングする行列を作成します。

返される行列は場所について、位置を pos 、 回転の向きを q 、スケールを s で修正します。

	// Translate, rotate and scale a mesh. Try varying
	// the parameters in the inspector while running
	// to see the effect they have.
	
	var translation: Vector3;
	var eulerAngles: Vector3;
	var scale = Vector3(1, 1, 1);
	
	
	private var mf: MeshFilter;
	private var origVerts: Vector3[];
	private var newVerts: Vector3[];
	
	
	function Start () {
		// Get the Mesh Filter component, save its original vertices
		// and make a new vertex array for processing.
		mf = GetComponent.<MeshFilter>();
		origVerts = mf.mesh.vertices;
		newVerts = new Vector3[origVerts.Length];
	}
	
	
	function Update () {
		// Set a Quaternion from the specified Euler angles.
		var rotation = Quaternion.Euler(eulerAngles.x, eulerAngles.y, eulerAngles.z);
		
		// Set the translation, rotation and scale parameters.
		var m = Matrix4x4.TRS(translation, rotation, scale);
		
		// For each vertex...
		for (var i = 0; i < origVerts.Length; i++) {
			// Apply the matrix to the vertex.
			newVerts[i] = m.MultiplyPoint3x4(origVerts[i]);
		}
		
		// Copy the transformed vertices back to the mesh.
		mf.mesh.vertices = newVerts;
	}
using UnityEngine;
using System.Collections;

public class ExampleClass : MonoBehaviour { public Vector3 translation; public Vector3 eulerAngles; public Vector3 scale = new Vector3(1, 1, 1); private MeshFilter mf; private Vector3[] origVerts; private Vector3[] newVerts; void Start() { mf = GetComponent<MeshFilter>(); origVerts = mf.mesh.vertices; newVerts = new Vector3[origVerts.Length]; } void Update() { Quaternion rotation = Quaternion.Euler(eulerAngles.x, eulerAngles.y, eulerAngles.z); Matrix4x4 m = Matrix4x4.TRS(translation, rotation, scale); int i = 0; while (i < origVerts.Length) { newVerts[i] = m.MultiplyPoint3x4(origVerts[i]); i++; } mf.mesh.vertices = newVerts; } }