mesh | 描画する Mesh |
submeshIndex | 描画するメッシュのサブセット。これはいくつかのマテリアルで構成されるメッシュにのみ適用されます。 |
material | 使用する Material |
matrices | The array of object transformation matrices. |
count | The number of instances to be drawn. |
properties | Additional material properties to apply. See MaterialPropertyBlock. |
castShadows | メッシュはシャドウをキャストする必要があるか。 |
receiveShadows | メッシュはシャドウをレシーブする必要があるか。 |
layer | 使用する Layer |
camera | If null (default), the mesh will be drawn in all cameras. Otherwise it will be drawn in the given camera only. |
Draw the same mesh multiple times using GPU instancing.
Similar to Graphics.DrawMesh, this function draws meshes for one frame without the overhead of creating unnecessary game objects.
Use this function in situations where you want to draw the same mesh for a particular amount of times using an instanced shader. Meshes are not further culled by the view frustum or baked occluders, nor sorted for transparency or z efficiency.
The transformation matrix of each instance of the mesh should be packed into the matrices
array. You can specify the number of instances to draw, or by default it is the length of the matrices
array. Other per-instance data, if required by the shader, should be provided by creating arrays on the MaterialPropertyBlock argument using SetFloatArray, SetVectorArray and SetMatrixArray.
Note: You can only draw a maximum of 1023 instances at once.
InvalidOperationException will be thrown if the current platform doesn't support this API (i.e. if GPU instancing is not available). See SystemInfo.supportsInstancing.
関連項目: DrawMesh.