Поделиться через


INMessage Конструкторы

Определение

Перегрузки

INMessage(NSCoder)

Конструктор, который инициализирует объект из данных, хранящихся в объекте unarchiver.

INMessage(NSObjectFlag)

Конструктор для вызова производных классов для пропуска инициализации и просто выделения объекта.

INMessage(IntPtr)

Конструктор, используемый при создании управляемых представлений неуправляемых объектов; Вызывается средой выполнения.

INMessage(String, String, NSDate, INPerson, INPerson[])

Создает объект сообщения с указанными сведениями.

INMessage(String, String, String, NSDate, INPerson, INPerson[], INMessageType)

Создает объект сообщения с указанными сведениями.

INMessage(String, String, String, NSDate, INPerson, INPerson[], INSpeakableString, INMessageType)

Создает объект сообщения с указанными сведениями.

INMessage(NSCoder)

Конструктор, который инициализирует объект из данных, хранящихся в объекте unarchiver.

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

Параметры

coder
NSCoder

Объект unarchiver.

Атрибуты

Комментарии

Этот конструктор предоставляется для инициализации класса из неархиватора (например, во время десериализации NIB). Это часть NSCoding протокола.

Если разработчики хотят создать подкласс этого объекта и продолжать поддерживать десериализацию из архива, они должны реализовать конструктор с идентичной сигнатурой: взяв один параметр типа NSCoder и дополнив его объявлением атрибута [Export("initWithCoder:"].

Состояние этого объекта также можно сериализовать с помощью вспомогательного метода EncodeTo.

Применяется к

INMessage(NSObjectFlag)

Конструктор для вызова производных классов для пропуска инициализации и просто выделения объекта.

protected INMessage (Foundation.NSObjectFlag t);
new Intents.INMessage : Foundation.NSObjectFlag -> Intents.INMessage

Параметры

t
NSObjectFlag

Неиспользуемое значение sentinel, передайте NSObjectFlag.Empty.

Комментарии

Этот конструктор должен вызываться производными классами, когда они полностью создают объект в управляемом коде и просто хотят, чтобы среда выполнения выделила и инициализировала NSObject. Это необходимо для реализации двухфакторного процесса инициализации, который использует Objective-C. Первый шаг — выделение объекта, второй шаг — инициализация объекта. Когда разработчики вызывают конструктор, который принимает NSObjectFlag.Empty, они используют прямой путь вплоть до NSObject, чтобы просто выделить память объекта и связать объекты Objective-C и C# вместе. Фактическая инициализация объекта выполняется разработчиком.

Этот конструктор обычно используется генератором привязки для выделения объекта, но предотвращает фактическую инициализацию. После выделения конструктор должен инициализировать объект . При использовании конструкторов, созданных генератором привязки, это означает, что он вручную вызывает один из методов init для инициализации объекта.

Разработчик несет ответственность за полную инициализацию объекта, если они связаны с использованием пути NSObjectFlag.Empty.

Как правило, если конструктор разработчика вызывает базовую реализацию NSObjectFlag.Empty, он должен вызывать метод инициализации Objective-C. Если это не так, разработчики должны вместо этого привязать к соответствующему конструктору в своем классе.

Значение аргумента игнорируется и просто гарантирует, что единственным выполняемым кодом является этап построения, является базовое выделение NSObject и регистрация типа среды выполнения. Обычно цепочка выглядит следующим образом:

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

Применяется к

INMessage(IntPtr)

Конструктор, используемый при создании управляемых представлений неуправляемых объектов; Вызывается средой выполнения.

protected internal INMessage (IntPtr handle);
new Intents.INMessage : nativeint -> Intents.INMessage

Параметры

handle
IntPtr

nativeint

Указатель (дескриптор) на неуправляемый объект.

Комментарии

Этот конструктор вызывается инфраструктурой среды выполнения (GetNSObject(IntPtr)) для создания нового управляемого представления указателя на неуправляемый объект Objective-C. Разработчики не должны вызывать этот метод напрямую, вместо этого они должны вызывать метод GetNSObject, так как это не позволит двум экземплярам управляемого объекта указывать на один и тот же собственный объект.

Применяется к

INMessage(String, String, NSDate, INPerson, INPerson[])

Создает объект сообщения с указанными сведениями.

[Foundation.Export("initWithIdentifier:content:dateSent:sender:recipients:")]
public INMessage (string identifier, string content, Foundation.NSDate dateSent, Intents.INPerson sender, Intents.INPerson[] recipients);
new Intents.INMessage : string * string * Foundation.NSDate * Intents.INPerson * Intents.INPerson[] -> Intents.INMessage

Параметры

identifier
String
content
String

Будет добавлено.

Этот параметр может иметь значение null.

dateSent
NSDate

Будет добавлено.

Этот параметр может иметь значение null.

sender
INPerson

Будет добавлено.

Этот параметр может иметь значение null.

recipients
INPerson[]

Будет добавлено.

Этот параметр может иметь значение null.

Атрибуты

Применяется к

INMessage(String, String, String, NSDate, INPerson, INPerson[], INMessageType)

Создает объект сообщения с указанными сведениями.

[Foundation.Export("initWithIdentifier:conversationIdentifier:content:dateSent:sender:recipients:messageType:")]
[ObjCRuntime.Introduced(ObjCRuntime.PlatformName.WatchOS, 4, 0, ObjCRuntime.PlatformArchitecture.All, null)]
[ObjCRuntime.Introduced(ObjCRuntime.PlatformName.MacOSX, 10, 13, ObjCRuntime.PlatformArchitecture.Arch64, null)]
[ObjCRuntime.Introduced(ObjCRuntime.PlatformName.iOS, 11, 0, ObjCRuntime.PlatformArchitecture.All, null)]
public INMessage (string identifier, string conversationIdentifier, string content, Foundation.NSDate dateSent, Intents.INPerson sender, Intents.INPerson[] recipients, Intents.INMessageType messageType);
new Intents.INMessage : string * string * string * Foundation.NSDate * Intents.INPerson * Intents.INPerson[] * Intents.INMessageType -> Intents.INMessage

Параметры

identifier
String
conversationIdentifier
String

Будет добавлено.

Этот параметр может иметь значение null.

content
String

Будет добавлено.

Этот параметр может иметь значение null.

dateSent
NSDate

Будет добавлено.

Этот параметр может иметь значение null.

sender
INPerson

Будет добавлено.

Этот параметр может иметь значение null.

recipients
INPerson[]

Будет добавлено.

Этот параметр может иметь значение null.

messageType
INMessageType
Атрибуты

Применяется к

INMessage(String, String, String, NSDate, INPerson, INPerson[], INSpeakableString, INMessageType)

Создает объект сообщения с указанными сведениями.

[Foundation.Export("initWithIdentifier:conversationIdentifier:content:dateSent:sender:recipients:groupName:messageType:")]
[ObjCRuntime.DesignatedInitializer]
[ObjCRuntime.Introduced(ObjCRuntime.PlatformName.WatchOS, 4, 0, ObjCRuntime.PlatformArchitecture.All, null)]
[ObjCRuntime.Introduced(ObjCRuntime.PlatformName.MacOSX, 10, 13, ObjCRuntime.PlatformArchitecture.Arch64, null)]
[ObjCRuntime.Introduced(ObjCRuntime.PlatformName.iOS, 11, 0, ObjCRuntime.PlatformArchitecture.All, null)]
public INMessage (string identifier, string conversationIdentifier, string content, Foundation.NSDate dateSent, Intents.INPerson sender, Intents.INPerson[] recipients, Intents.INSpeakableString groupName, Intents.INMessageType messageType);
new Intents.INMessage : string * string * string * Foundation.NSDate * Intents.INPerson * Intents.INPerson[] * Intents.INSpeakableString * Intents.INMessageType -> Intents.INMessage

Параметры

identifier
String
conversationIdentifier
String

Будет добавлено.

Этот параметр может иметь значение null.

content
String

Будет добавлено.

Этот параметр может иметь значение null.

dateSent
NSDate

Будет добавлено.

Этот параметр может иметь значение null.

sender
INPerson

Будет добавлено.

Этот параметр может иметь значение null.

recipients
INPerson[]

Будет добавлено.

Этот параметр может иметь значение null.

groupName
INSpeakableString

Будет добавлено.

Этот параметр может иметь значение null.

messageType
INMessageType
Атрибуты

Применяется к