Compartilhar via


UIViewController Construtores

Definição

Sobrecargas

UIViewController()

Construtor padrão que inicializa uma nova instância dessa classe sem parâmetros.

UIViewController(NSCoder)

Um construtor que inicializa o objeto dos dados armazenados no objeto unarchiver.

UIViewController(NSObjectFlag)

Construtor para chamar em classes derivadas para ignorar a inicialização e simplesmente alocar o objeto.

UIViewController(IntPtr)

Um construtor usado ao criar representações gerenciadas de objetos não gerenciados; Chamado pelo runtime.

UIViewController(String, NSBundle)

Um construtor usado ao criar um controlador de exibição usando as informações armazenadas no arquivo nib.

UIViewController()

Construtor padrão que inicializa uma nova instância dessa classe sem parâmetros.

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

Aplica-se a

UIViewController(NSCoder)

Um construtor que inicializa o objeto dos dados armazenados no objeto unarchiver.

[Foundation.Export("initWithCoder:")]
[ObjCRuntime.DesignatedInitializer]
public UIViewController (Foundation.NSCoder coder);
new UIKit.UIViewController : Foundation.NSCoder -> UIKit.UIViewController

Parâmetros

coder
NSCoder

O objeto unarchiver.

Atributos

Comentários

Esse construtor é fornecido para permitir que a classe seja inicializada de um unarchiver (por exemplo, durante a desserialização nib). Isso faz parte do NSCoding protocolo.

Se os desenvolvedores quiserem criar uma subclasse desse objeto e continuar a dar suporte à desserialização de um arquivo morto, eles deverão implementar um construtor com uma assinatura idêntica: pegar um único parâmetro do tipo NSCoder e decorá-lo com a declaração de atributo [Export("initWithCoder:"].

O estado desse objeto também pode ser serializado usando o método complementar EncodeTo.

Aplica-se a

UIViewController(NSObjectFlag)

Construtor para chamar em classes derivadas para ignorar a inicialização e simplesmente alocar o objeto.

protected UIViewController (Foundation.NSObjectFlag t);
new UIKit.UIViewController : Foundation.NSObjectFlag -> UIKit.UIViewController

Parâmetros

t
NSObjectFlag

Valor sentinela não utilizado, passe NSObjectFlag.Empty.

Comentários

Esse construtor deve ser chamado por classes derivadas quando eles constroem completamente o objeto no código gerenciado e apenas querem que o runtime aloque e inicialize o NSObject. Isso é necessário para implementar o processo de inicialização em duas etapas que Objective-C usa, a primeira etapa é executar a alocação de objeto, a segunda etapa é inicializar o objeto. Quando os desenvolvedores invocam o construtor que usa o NSObjectFlag.Empty, eles aproveitam um caminho direto que vai até NSObject para simplesmente alocar a memória do objeto e associar os objetos Objective-C e C#. A inicialização real do objeto cabe ao desenvolvedor.

Esse construtor normalmente é usado pelo gerador de associação para alocar o objeto, mas impede que a inicialização real ocorra. Depois que a alocação tiver ocorrido, o construtor precisará inicializar o objeto . Com construtores gerados pelo gerador de associação, isso significa que ele invoca manualmente um dos métodos "init" para inicializar o objeto.

É responsabilidade do desenvolvedor inicializar completamente o objeto se ele se encadear usando o caminho NSObjectFlag.Empty.

Em geral, se o construtor do desenvolvedor invocar a implementação base NSObjectFlag.Empty, ele deverá chamar um método objective-C init. Se esse não for o caso, os desenvolvedores deverão encadear o construtor adequado em sua classe.

O valor do argumento é ignorado e apenas garante que o único código executado seja a fase de construção é a alocação básica de NSObject e o registro de tipo de runtime. Normalmente, o encadeamento teria esta aparência:

//
// 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);
}

Aplica-se a

UIViewController(IntPtr)

Um construtor usado ao criar representações gerenciadas de objetos não gerenciados; Chamado pelo runtime.

protected internal UIViewController (IntPtr handle);
new UIKit.UIViewController : nativeint -> UIKit.UIViewController

Parâmetros

handle
IntPtr

nativeint

Ponteiro (identificador) para o objeto não gerenciado.

Comentários

Esse construtor é invocado pela infraestrutura de runtime (GetNSObject(IntPtr)) para criar uma nova representação gerenciada para um ponteiro para um objeto Objective-C não gerenciado. Os desenvolvedores não devem invocar esse método diretamente, em vez disso, devem chamar o método GetNSObject, pois ele impedirá que duas instâncias de um objeto gerenciado apontem para o mesmo objeto nativo.

Aplica-se a

UIViewController(String, NSBundle)

Um construtor usado ao criar um controlador de exibição usando as informações armazenadas no arquivo nib.

[Foundation.Export("initWithNibName:bundle:")]
[ObjCRuntime.DesignatedInitializer]
public UIViewController (string nibName, Foundation.NSBundle bundle);
new UIKit.UIViewController : string * Foundation.NSBundle -> UIKit.UIViewController

Parâmetros

nibName
String

O nome nib ou nulo.

Esse parâmetro pode ser null.

bundle
NSBundle

O pacote em que a pesquisa pela NIB ocorre, se você passar nulo, isso pesquisa o NIB no pacote principal.

Esse parâmetro pode ser null.

Atributos

Aplica-se a