GLKTextureLoader Constructores
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Sobrecargas
GLKTextureLoader() |
Constructor predeterminado que inicializa una nueva instancia de esta clase sin parámetros. |
GLKTextureLoader(NSOpenGLContext) | |
GLKTextureLoader(NSObjectFlag) |
Constructor para llamar a en clases derivadas para omitir la inicialización y simplemente asignar el objeto. |
GLKTextureLoader(EAGLSharegroup) |
Crea un GLKTextureLoader para un EAGLSharegroup, que se usa para la carga asincrónica de texturas. |
GLKTextureLoader(IntPtr) |
Constructor utilizado al crear representaciones administradas de objetos no administrados; Lo llama el tiempo de ejecución. |
GLKTextureLoader()
Constructor predeterminado que inicializa una nueva instancia de esta clase sin parámetros.
[Foundation.Export("init")]
public GLKTextureLoader ();
- Atributos
Se aplica a
GLKTextureLoader(NSOpenGLContext)
[Foundation.Export("initWithShareContext:")]
public GLKTextureLoader (AppKit.NSOpenGLContext context);
new GLKit.GLKTextureLoader : AppKit.NSOpenGLContext -> GLKit.GLKTextureLoader
Parámetros
- context
- NSOpenGLContext
- Atributos
Se aplica a
GLKTextureLoader(NSObjectFlag)
Constructor para llamar a en clases derivadas para omitir la inicialización y simplemente asignar el objeto.
protected GLKTextureLoader (Foundation.NSObjectFlag t);
new GLKit.GLKTextureLoader : Foundation.NSObjectFlag -> GLKit.GLKTextureLoader
Parámetros
Valor centinela 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 tiempo de ejecución asigne e inicialice el objeto 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 es 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 hasta 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 este no es el caso, 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 del tipo en tiempo de ejecución. Normalmente, el encadenamiento tendría el siguiente 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
GLKTextureLoader(EAGLSharegroup)
Crea un GLKTextureLoader para un EAGLSharegroup, que se usa para la carga asincrónica de texturas.
[Foundation.Export("initWithSharegroup:")]
public GLKTextureLoader (OpenGLES.EAGLSharegroup sharegroup);
new GLKit.GLKTextureLoader : OpenGLES.EAGLSharegroup -> GLKit.GLKTextureLoader
Parámetros
- sharegroup
- EAGLSharegroup
Compartir contexto donde se cargarán las texturas.
Devoluciones
nativeint
- Atributos
Se aplica a
GLKTextureLoader(IntPtr)
Constructor utilizado al crear representaciones administradas de objetos no administrados; Lo llama el tiempo de ejecución.
protected internal GLKTextureLoader (IntPtr handle);
new GLKit.GLKTextureLoader : nativeint -> GLKit.GLKTextureLoader
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.