UITableViewCell Constructors
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Overloads
| Name | Description |
|---|---|
| UITableViewCell() |
Creates a new UITableViewCell with default values. |
| UITableViewCell(CGRect) | |
| UITableViewCell(NSCoder) |
A constructor that initializes the object from the data stored in the unarchiver object. |
| UITableViewCell(NSObjectFlag) |
Constructor to call on derived classes to skip initialization and merely allocate the object. |
| UITableViewCell(NativeHandle) |
A constructor used when creating managed representations of unmanaged objects. Called by the runtime. |
| UITableViewCell(UITableViewCellStyle, NSString) | |
| UITableViewCell(UITableViewCellStyle, String) |
Create a table cell with the given style and reuse identifier. |
UITableViewCell()
Creates a new UITableViewCell with default values.
[Foundation.Export("init")]
[ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)]
public UITableViewCell();
- Attributes
Applies to
UITableViewCell(CGRect)
[Foundation.Export("initWithFrame:")]
[ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)]
public UITableViewCell(CoreGraphics.CGRect frame);
[<Foundation.Export("initWithFrame:")>]
[<ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)>]
new UIKit.UITableViewCell : CoreGraphics.CGRect -> UIKit.UITableViewCell
Parameters
- frame
- CGRect
- Attributes
Applies to
UITableViewCell(NSCoder)
A constructor that initializes the object from the data stored in the unarchiver object.
[Foundation.Export("initWithCoder:")]
[ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)]
[ObjCRuntime.DesignatedInitializer]
public UITableViewCell(Foundation.NSCoder coder);
[<Foundation.Export("initWithCoder:")>]
[<ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)>]
[<ObjCRuntime.DesignatedInitializer>]
new UIKit.UITableViewCell : Foundation.NSCoder -> UIKit.UITableViewCell
Parameters
- coder
- NSCoder
The unarchiver object.
- Attributes
Remarks
This constructor is provided to allow the class to be initialized from an unarchiver (for example, during NIB deserialization). This is part of the NSCoding protocol.
If developers want to create a subclass of this object and continue to support deserialization from an archive, they should implement a constructor with an identical signature: taking a single parameter of type NSCoder and decorate it with the [Export("initWithCoder:"] attribute.
The state of this object can also be serialized by using the EncodeTo(NSCoder) companion method.
Applies to
UITableViewCell(NSObjectFlag)
Constructor to call on derived classes to skip initialization and merely allocate the object.
[ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)]
protected UITableViewCell(Foundation.NSObjectFlag t);
[<ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)>]
new UIKit.UITableViewCell : Foundation.NSObjectFlag -> UIKit.UITableViewCell
Parameters
Unused sentinel value, pass NSObjectFlag.Empty.
- Attributes
Remarks
This constructor should be called by derived classes when they completely construct the object in managed code and merely want the runtime to allocate and initialize the NSObject. This is required to implement the two-step initialization process that Objective-C uses, the first step is to perform the object allocation, the second step is to initialize the object. When developers invoke this constructor, they take advantage of a direct path that goes all the way up to NSObject to merely allocate the object's memory and bind the Objective-C and C# objects together. The actual initialization of the object is up to the developer.
This constructor is typically used by the binding generator to allocate the object, but prevent the actual initialization to take place. Once the allocation has taken place, the constructor has to initialize the object. With constructors generated by the binding generator this means that it manually invokes one of the "init" methods to initialize the object.
It is the developer's responsibility to completely initialize the object if they chain up using this constructor chain.
In general, if the developer's constructor invokes the corresponding base implementation, then it should also call an Objective-C init method. If this is not the case, developers should instead chain to the proper constructor in their class.
The argument value is ignored and merely ensures that the only code that is executed is the construction phase is the basic NSObject allocation and runtime type registration. Typically the chaining would look like this:
//
// The NSObjectFlag constructor merely allocates the object and registers the C# class with the Objective-C runtime if necessary.
// No actual initXxx method is invoked, that is done later in the constructor
//
// This is taken from the iOS SDK's source code for the UIView class:
//
[Export ("initWithFrame:")]
public UIView (CGRect 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);
}
}
Applies to
UITableViewCell(NativeHandle)
A constructor used when creating managed representations of unmanaged objects. Called by the runtime.
[ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)]
protected internal UITableViewCell(ObjCRuntime.NativeHandle handle);
[<ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)>]
new UIKit.UITableViewCell : ObjCRuntime.NativeHandle -> UIKit.UITableViewCell
Parameters
- handle
- NativeHandle
Pointer (handle) to the unmanaged object.
- Attributes
Remarks
This constructor is invoked by the runtime infrastructure (GetNSObject(IntPtr)) to create a new managed representation for a pointer to an unmanaged Objective-C object. Developers should not invoke this method directly, instead they should call GetNSObject(IntPtr) as it will prevent two instances of a managed object pointing to the same native object.
Applies to
UITableViewCell(UITableViewCellStyle, NSString)
[Foundation.Export("initWithStyle:reuseIdentifier:")]
[ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)]
[ObjCRuntime.DesignatedInitializer]
public UITableViewCell(UIKit.UITableViewCellStyle style, Foundation.NSString? reuseIdentifier);
[<Foundation.Export("initWithStyle:reuseIdentifier:")>]
[<ObjCRuntime.BindingImpl(ObjCRuntime.BindingImplOptions.GeneratedCode | ObjCRuntime.BindingImplOptions.Optimizable)>]
[<ObjCRuntime.DesignatedInitializer>]
new UIKit.UITableViewCell : UIKit.UITableViewCellStyle * Foundation.NSString -> UIKit.UITableViewCell
Parameters
- style
- UITableViewCellStyle
- reuseIdentifier
- NSString
- Attributes
Applies to
UITableViewCell(UITableViewCellStyle, String)
Create a table cell with the given style and reuse identifier.
public UITableViewCell(UIKit.UITableViewCellStyle style, string reuseIdentifier);
new UIKit.UITableViewCell : UIKit.UITableViewCellStyle * string -> UIKit.UITableViewCell
Parameters
- style
- UITableViewCellStyle
The style to use for this cell.
- reuseIdentifier
- String
A string used to identify the cell object if it should be reused for mutiple rows in a table view. Pass null if the object should not be reused. The same reuse identifier string should be used for all cells that use the same class and layout.
Remarks
The reuse identifier is associated with all cells (rows) in a table view that have the same layout (irrespective of their content) and can therefore be used interchangeably. The GetCell(UITableView, NSIndexPath) implementation calls DequeueReusableCell(NSString) with a specific reuse identifier string to obtain a cached cell object with a particular layout to use as the basis for the row being constructed for viewing.
To produce a layout different to those built-in to UITableViewCell, create a custom cell. To set the row height of each cell differently, implement GetHeightForRow(UITableView, NSIndexPath).