Compartir a través de


MDLSubmesh Constructores

Definición

Sobrecargas

MDLSubmesh()

El constructor predeterminado inicializa una nueva instancia de esta clase.

MDLSubmesh(NSObjectFlag)

Constructor para llamar a las clases derivadas para omitir la inicialización y simplemente asignar el objeto.

MDLSubmesh(IntPtr)

Constructor utilizado al crear representaciones administradas de objetos no administrados; Llamado por el entorno de ejecución.

MDLSubmesh(MDLSubmesh, MDLIndexBitDepth, MDLGeometryType)

Crea un nuevo MDLSubmesh con los parámetros especificados.

MDLSubmesh(IMDLMeshBuffer, nuint, MDLIndexBitDepth, MDLGeometryType, MDLMaterial)
MDLSubmesh(String, IMDLMeshBuffer, nuint, MDLIndexBitDepth, MDLGeometryType, MDLMaterial)
MDLSubmesh(String, IMDLMeshBuffer, nuint, MDLIndexBitDepth, MDLGeometryType, MDLMaterial, MDLSubmeshTopology)

MDLSubmesh()

El constructor predeterminado inicializa una nueva instancia de esta clase.

[Foundation.Export("init")]
public MDLSubmesh ();
Atributos

Se aplica a

MDLSubmesh(NSObjectFlag)

Constructor para llamar a las clases derivadas para omitir la inicialización y simplemente asignar el objeto.

protected MDLSubmesh (Foundation.NSObjectFlag t);
new ModelIO.MDLSubmesh : Foundation.NSObjectFlag -> ModelIO.MDLSubmesh

Parámetros

t
NSObjectFlag

Valor de sentinel sin usar, pase NSObjectFlag.Empty.

Comentarios

Las clases derivadas deben llamar a este constructor cuando construyen completamente el objeto en código administrado y simplemente quieren que el entorno de ejecución asigne e inicialice el NSObject. Esto es necesario para implementar el proceso de inicialización en dos pasos que usa Objective-C, el primer paso es realizar la asignación de objetos, el segundo paso consiste en inicializar el objeto. Cuando los desarrolladores invocan al constructor que toma NSObjectFlag.Empty aprovechan una ruta de acceso directa que va hasta NSObject para asignar simplemente la memoria del objeto y enlazar los objetos Objective-C y C# juntos. La inicialización real del objeto es para el desarrollador.

Normalmente, el generador de enlaces usa este constructor para asignar el objeto, pero impide que se produzca la inicialización real. Una vez realizada la asignación, el constructor tiene que inicializar el objeto. Con los constructores generados por el generador de enlaces, esto significa que invoca manualmente uno de los métodos "init" para inicializar el objeto.

Es responsabilidad del desarrollador inicializar completamente el objeto si se encadenan mediante la ruta de acceso NSObjectFlag.Empty.

En general, si el constructor del desarrollador invoca la implementación base NSObjectFlag.Empty, debe llamar a un método init de Objective-C. Si no es así, los desarrolladores deben encadenar al constructor adecuado en su clase.

El valor del argumento se omite y simplemente garantiza que el único código que se ejecuta es la fase de construcción es la asignación básica de NSObject y el registro de tipo en tiempo de ejecución. Normalmente, el encadenamiento tendría este aspecto:

//
// The NSObjectFlag merely allocates the object and registers the
// C# class with the Objective-C runtime if necessary, but no actual
// initXxx method is invoked, that is done later in the constructor
//
// This is taken from Xamarin.iOS's source code:
//
[Export ("initWithFrame:")]
public UIView (System.Drawing.RectangleF frame) : base (NSObjectFlag.Empty)
{
// Invoke the init method now.
	var initWithFrame = new Selector ("initWithFrame:").Handle;
	if (IsDirectBinding)
		Handle = ObjCRuntime.Messaging.IntPtr_objc_msgSend_CGRect (this.Handle, initWithFrame, frame);
	else
		Handle = ObjCRuntime.Messaging.IntPtr_objc_msgSendSuper_CGRect (this.SuperHandle, initWithFrame, frame);
}

Se aplica a

MDLSubmesh(IntPtr)

Constructor utilizado al crear representaciones administradas de objetos no administrados; Llamado por el entorno de ejecución.

protected internal MDLSubmesh (IntPtr handle);
new ModelIO.MDLSubmesh : nativeint -> ModelIO.MDLSubmesh

Parámetros

handle
IntPtr

nativeint

Puntero (identificador) al objeto no administrado.

Comentarios

La infraestructura en tiempo de ejecución (GetNSObject(IntPtr)) invoca este constructor para crear una nueva representación administrada para un puntero a un objeto Objective-C no administrado. Los desarrolladores no deben invocar este método directamente, sino que deben llamar al método GetNSObject, ya que impedirá que dos instancias de un objeto administrado apunten al mismo objeto nativo.

Se aplica a

MDLSubmesh(MDLSubmesh, MDLIndexBitDepth, MDLGeometryType)

Crea un nuevo MDLSubmesh con los parámetros especificados.

[Foundation.Export("initWithMDLSubmesh:indexType:geometryType:")]
public MDLSubmesh (ModelIO.MDLSubmesh indexBuffer, ModelIO.MDLIndexBitDepth indexType, ModelIO.MDLGeometryType geometryType);
new ModelIO.MDLSubmesh : ModelIO.MDLSubmesh * ModelIO.MDLIndexBitDepth * ModelIO.MDLGeometryType -> ModelIO.MDLSubmesh

Parámetros

indexBuffer
MDLSubmesh
indexType
MDLIndexBitDepth
geometryType
MDLGeometryType
Atributos

Comentarios

Si o indexTypegeometryType no coinciden con el tipo de datos en indexBuffer, se crea un nuevo búfer y se rellena con datos convertidos.

Se aplica a

MDLSubmesh(IMDLMeshBuffer, nuint, MDLIndexBitDepth, MDLGeometryType, MDLMaterial)

[Foundation.Export("initWithIndexBuffer:indexCount:indexType:geometryType:material:")]
public MDLSubmesh (ModelIO.IMDLMeshBuffer indexBuffer, nuint indexCount, ModelIO.MDLIndexBitDepth indexType, ModelIO.MDLGeometryType geometryType, ModelIO.MDLMaterial material);
new ModelIO.MDLSubmesh : ModelIO.IMDLMeshBuffer * nuint * ModelIO.MDLIndexBitDepth * ModelIO.MDLGeometryType * ModelIO.MDLMaterial -> ModelIO.MDLSubmesh

Parámetros

indexBuffer
IMDLMeshBuffer
indexCount
System.System.UIntPtr System.unativeint
indexType
MDLIndexBitDepth
geometryType
MDLGeometryType
material
MDLMaterial

Se agregará.

Este parámetro puede ser null.

Atributos

Se aplica a

MDLSubmesh(String, IMDLMeshBuffer, nuint, MDLIndexBitDepth, MDLGeometryType, MDLMaterial)

[Foundation.Export("initWithName:indexBuffer:indexCount:indexType:geometryType:material:")]
public MDLSubmesh (string name, ModelIO.IMDLMeshBuffer indexBuffer, nuint indexCount, ModelIO.MDLIndexBitDepth indexType, ModelIO.MDLGeometryType geometryType, ModelIO.MDLMaterial material);
new ModelIO.MDLSubmesh : string * ModelIO.IMDLMeshBuffer * nuint * ModelIO.MDLIndexBitDepth * ModelIO.MDLGeometryType * ModelIO.MDLMaterial -> ModelIO.MDLSubmesh

Parámetros

name
String
indexBuffer
IMDLMeshBuffer
indexCount
System.System.UIntPtr System.unativeint
indexType
MDLIndexBitDepth
geometryType
MDLGeometryType
material
MDLMaterial

Se agregará.

Este parámetro puede ser null.

Atributos

Se aplica a

MDLSubmesh(String, IMDLMeshBuffer, nuint, MDLIndexBitDepth, MDLGeometryType, MDLMaterial, MDLSubmeshTopology)

[Foundation.Export("initWithName:indexBuffer:indexCount:indexType:geometryType:material:topology:")]
public MDLSubmesh (string name, ModelIO.IMDLMeshBuffer indexBuffer, nuint indexCount, ModelIO.MDLIndexBitDepth indexType, ModelIO.MDLGeometryType geometryType, ModelIO.MDLMaterial material, ModelIO.MDLSubmeshTopology topology);
new ModelIO.MDLSubmesh : string * ModelIO.IMDLMeshBuffer * nuint * ModelIO.MDLIndexBitDepth * ModelIO.MDLGeometryType * ModelIO.MDLMaterial * ModelIO.MDLSubmeshTopology -> ModelIO.MDLSubmesh

Parámetros

name
String
indexBuffer
IMDLMeshBuffer
indexCount
System.System.UIntPtr System.unativeint
indexType
MDLIndexBitDepth
geometryType
MDLGeometryType
material
MDLMaterial

Se agregará.

Este parámetro puede ser null.

topology
MDLSubmeshTopology

Se agregará.

Este parámetro puede ser null.

Atributos

Se aplica a