MFMailComposeViewController

Struct MFMailComposeViewController 

Source
pub struct MFMailComposeViewController { /* private fields */ }
Available on crate features MFMailComposeViewController and objc2-ui-kit only.
Expand description

The MFMailComposeViewController class provides an interface for editing and sending email.

The MFMailComposeViewController class manages all user interaction. The client needs to set the recipient or recipients. The client may also set the subject and the body of the message. Attachments may be added, if so desired. After setup, the client needs to only display the view.

The provided delegate will be informed of the user's composition completion and how they chose to complete the operation.

Prior to use, clients should verify the user has set up the device for sending email via +[MFMailComposeViewController canSendMail] .

See also Apple’s documentation

Implementations§

Source§

impl MFMailComposeViewController

Source

pub unsafe fn canSendMail(mtm: MainThreadMarker) -> bool

Returns YES if the user has set up the device for sending email.

The client may continue to set the recipients and content if the return value was YES . If NO was the result, the client has a couple options. It may choose to simply notify the user of the inability to send mail, or it may issue a “mailto” URL via -[UIApplication openURL:] .

Source

pub unsafe fn mailComposeDelegate( &self, ) -> Option<Retained<ProtocolObject<dyn MFMailComposeViewControllerDelegate>>>

This property is the delegate for the MFMailComposeViewControllerDelegate method callbacks.

Source

pub unsafe fn setMailComposeDelegate( &self, mail_compose_delegate: Option<&ProtocolObject<dyn MFMailComposeViewControllerDelegate>>, )

Setter for mailComposeDelegate.

This is a weak property.

Source

pub unsafe fn setSubject(&self, subject: &NSString)

This method sets the Subject header for the email message.

This method will set the Subject header for the email message. This should be called prior to display. Newlines are removed from the parameter.

After the view has been presented to the user, this method will no longer change the value.

Parameter subject: A NSString specifying the message’s Subject header.

Source

pub unsafe fn setToRecipients(&self, to_recipients: Option<&NSArray<NSString>>)

This method sets the To header for the email message to the specified email addresses.

This method will set the To header for the email message. This should be called prior to display.

Recipient addresses should be specified as per RFC5322.

After the view has been presented to the user, this method will no longer change the value.

Parameter toRecipients: A NSArray of NSString instances specifying the email addresses of recipients.

Source

pub unsafe fn setCcRecipients(&self, cc_recipients: Option<&NSArray<NSString>>)

This method sets the CC header for the email message to the specified email addresses.

This method will set the CC header for the email message. This should be called prior to display.

Recipient addresses should be specified as per RFC5322.

After the view has been presented to the user, this method will no longer change the value.

Parameter ccRecipients: A NSArray of NSString instances specifying the email addresses of recipients.

Source

pub unsafe fn setBccRecipients( &self, bcc_recipients: Option<&NSArray<NSString>>, )

This method sets the BCC header for the email message to the specified email addresses.

This method will set the BCC header for the email message. This should be called prior to display.

Recipient addresses should be specified as per RFC5322.

After the view has been presented to the user, this method will no longer change the value.

Parameter bccRecipients: A NSArray of NSString instances specifying the email addresses of recipients.

Source

pub unsafe fn setMessageBody_isHTML(&self, body: &NSString, is_html: bool)

This method sets the body of the email message to the specified content.

This method will set the body of the email message. This should be called prior to display. The user’s signature, if specified, will be added after the body content.

Parameter body: A NSString containing the body contents of the email message.

Parameter isHTML: A boolean value indicating if the body argument is to be interpreted as HTML content.

Source

pub unsafe fn addAttachmentData_mimeType_fileName( &self, attachment: &NSData, mime_type: &NSString, filename: &NSString, )

This method adds the specified attachment to the email message.

This method adds the specified attachment to the email message. This should be called prior to display. Attachments will be appended to the end of the message.

Parameter attachment: NSData containing the contents of the attachment. Must not be nil .

Parameter mimeType: NSString specifying the MIME type for the attachment, as specified by the IANA (http://www.iana.org/assignments/media-types/). Must not be nil .

Parameter filename: NSString specifying the intended filename for the attachment. This is displayed below the attachment’s icon if the attachment is not decoded when displayed. Must not be nil .

Source

pub unsafe fn setPreferredSendingEmailAddress(&self, email_address: &NSString)

This method sets the preferred sending account of the email message.

This method will set the sending account of the message to the specified email address if the user has an account with such an address set up. If there is no account with such an address, the default account will be used instead. The sending email address should be specified as per RFC5322. After the view has been presented to the user, this method will no longer change the value.

Parameter emailAddress: A NSString specifying the preferred email address used to send this message.

Source

pub unsafe fn insertCollaborationItemProvider_completionHandler( &self, item_provider: &NSItemProvider, completion_handler: &DynBlock<dyn Fn(Bool)>, )

Available on crate feature block2 only.

Parameter itemProvider: specifying the intended content for collaboration

Returns YES if the item provider was added to the composition successfully.

If the return value is YES, the itemProvider was added to the composition. The itemProvider must be non-nil.

Source§

impl MFMailComposeViewController

Methods declared on superclass UINavigationController.

Source

pub unsafe fn initWithNavigationBarClass_toolbarClass( this: Allocated<Self>, navigation_bar_class: Option<&AnyClass>, toolbar_class: Option<&AnyClass>, ) -> Retained<Self>

§Safety
  • navigation_bar_class probably has further requirements.
  • toolbar_class probably has further requirements.
Source

pub unsafe fn initWithRootViewController( this: Allocated<Self>, root_view_controller: &UIViewController, ) -> Retained<Self>

Source

pub unsafe fn initWithNibName_bundle( this: Allocated<Self>, nib_name_or_nil: Option<&NSString>, nib_bundle_or_nil: Option<&NSBundle>, ) -> Retained<Self>

Source

pub unsafe fn initWithCoder( this: Allocated<Self>, a_decoder: &NSCoder, ) -> Option<Retained<Self>>

§Safety

a_decoder possibly has further requirements.

Source§

impl MFMailComposeViewController

Methods declared on superclass NSObject.

Source

pub unsafe fn init(this: Allocated<Self>) -> Retained<Self>

Source

pub unsafe fn new(mtm: MainThreadMarker) -> Retained<Self>

Methods from Deref<Target = UINavigationController>§

Source

pub fn pushViewController_animated( &self, view_controller: &UIViewController, animated: bool, )

Source

pub fn popViewControllerAnimated( &self, animated: bool, ) -> Option<Retained<UIViewController>>

Source

pub fn popToViewController_animated( &self, view_controller: &UIViewController, animated: bool, ) -> Option<Retained<NSArray<UIViewController>>>

Source

pub fn popToRootViewControllerAnimated( &self, animated: bool, ) -> Option<Retained<NSArray<UIViewController>>>

Source

pub fn topViewController(&self) -> Option<Retained<UIViewController>>

Source

pub fn visibleViewController(&self) -> Option<Retained<UIViewController>>

Source

pub fn viewControllers(&self) -> Retained<NSArray<UIViewController>>

Source

pub fn setViewControllers(&self, view_controllers: &NSArray<UIViewController>)

Setter for viewControllers.

This is copied when set.

Source

pub fn setViewControllers_animated( &self, view_controllers: &NSArray<UIViewController>, animated: bool, )

Source

pub fn isNavigationBarHidden(&self) -> bool

Source

pub fn setNavigationBarHidden(&self, navigation_bar_hidden: bool)

Source

pub fn setNavigationBarHidden_animated(&self, hidden: bool, animated: bool)

Source

pub fn isToolbarHidden(&self) -> bool

Source

pub fn setToolbarHidden(&self, toolbar_hidden: bool)

Setter for isToolbarHidden.

Source

pub fn setToolbarHidden_animated(&self, hidden: bool, animated: bool)

Source

pub fn delegate( &self, ) -> Option<Retained<ProtocolObject<dyn UINavigationControllerDelegate>>>

Source

pub unsafe fn setDelegate( &self, delegate: Option<&ProtocolObject<dyn UINavigationControllerDelegate>>, )

Setter for delegate.

This is a weak property.

Source

pub unsafe fn showViewController_sender( &self, vc: &UIViewController, sender: Option<&AnyObject>, )

§Safety

sender should be of the correct type.

Source

pub fn hidesBarsWhenKeyboardAppears(&self) -> bool

When the keyboard appears, the navigation controller’s navigationBar toolbar will be hidden. The bars will remain hidden when the keyboard dismisses, but a tap in the content area will show them.

Source

pub fn setHidesBarsWhenKeyboardAppears( &self, hides_bars_when_keyboard_appears: bool, )

Source

pub fn hidesBarsOnSwipe(&self) -> bool

When the user swipes, the navigation controller’s navigationBar & toolbar will be hidden (on a swipe up) or shown (on a swipe down). The toolbar only participates if it has items.

Source

pub fn setHidesBarsOnSwipe(&self, hides_bars_on_swipe: bool)

Setter for hidesBarsOnSwipe.

Source

pub fn hidesBarsWhenVerticallyCompact(&self) -> bool

When the UINavigationController’s vertical size class is compact, hide the UINavigationBar and UIToolbar. Unhandled taps in the regions that would normally be occupied by these bars will reveal the bars.

Source

pub fn setHidesBarsWhenVerticallyCompact( &self, hides_bars_when_vertically_compact: bool, )

Source

pub fn hidesBarsOnTap(&self) -> bool

When the user taps, the navigation controller’s navigationBar & toolbar will be hidden or shown, depending on the hidden state of the navigationBar. The toolbar will only be shown if it has items to display.

Source

pub fn setHidesBarsOnTap(&self, hides_bars_on_tap: bool)

Setter for hidesBarsOnTap.

Methods from Deref<Target = UIViewController>§

Source

pub fn hidesBottomBarWhenPushed(&self) -> bool

Source

pub fn setHidesBottomBarWhenPushed(&self, hides_bottom_bar_when_pushed: bool)

Source

pub fn navigationController(&self) -> Option<Retained<UINavigationController>>

Source

pub fn loadView(&self)

Source

pub fn loadViewIfNeeded(&self)

Source

pub fn viewWillUnload(&self)

👎Deprecated
Source

pub fn viewDidUnload(&self)

👎Deprecated
Source

pub fn viewDidLoad(&self)

Source

pub fn isViewLoaded(&self) -> bool

Source

pub fn nibName(&self) -> Option<Retained<NSString>>

👎Deprecated: Loading Interface Builder products will not be supported in a future version of visionOS.
Source

pub fn nibBundle(&self) -> Option<Retained<NSBundle>>

👎Deprecated: Loading Interface Builder products will not be supported in a future version of visionOS.
Source

pub unsafe fn performSegueWithIdentifier_sender( &self, identifier: &NSString, sender: Option<&AnyObject>, )

👎Deprecated: Loading Interface Builder products will not be supported in a future version of visionOS.
§Safety

sender should be of the correct type.

Source

pub unsafe fn shouldPerformSegueWithIdentifier_sender( &self, identifier: &NSString, sender: Option<&AnyObject>, ) -> bool

👎Deprecated: Loading Interface Builder products will not be supported in a future version of visionOS.
§Safety

sender should be of the correct type.

Source

pub unsafe fn canPerformUnwindSegueAction_fromViewController_sender( &self, action: Sel, from_view_controller: &UIViewController, sender: Option<&AnyObject>, ) -> bool

👎Deprecated: Loading Interface Builder products will not be supported in a future version of visionOS.
§Safety
  • action must be a valid selector.
  • sender should be of the correct type.
Source

pub unsafe fn canPerformUnwindSegueAction_fromViewController_withSender( &self, action: Sel, from_view_controller: &UIViewController, sender: &AnyObject, ) -> bool

👎Deprecated
§Safety
  • action must be a valid selector.
  • sender should be of the correct type.
Source

pub unsafe fn viewControllerForUnwindSegueAction_fromViewController_withSender( &self, action: Sel, from_view_controller: &UIViewController, sender: Option<&AnyObject>, ) -> Option<Retained<UIViewController>>

👎Deprecated
§Safety
  • action must be a valid selector.
  • sender should be of the correct type.
Source

pub fn viewWillAppear(&self, animated: bool)

Called when the view is about to made visible, before it is added to the hierarchy. Because the view is not yet in the hierarchy at the time this method is called, it is too early in the appearance transition for many usages. Prefer -viewIsAppearing: instead of this method when possible. Only use this method when its exact timing before the appearance transition starts running is desired, such as to set up an alongside animation with a transition coordinator, or as a counterpart for paired code in a viewWillDisappear/viewDidDisappear callback that does not rely on the view or view controller’s trait collection or the view hierarchy.

Source

pub fn viewIsAppearing(&self, animated: bool)

Called when the view is becoming visible at the beginning of the appearance transition, after it has been added to the hierarchy and been laid out by its superview. This method is very similar to -viewWillAppear: and is always called shortly afterwards (so changes made in either callback will be visible to the user at the same time), but unlike -viewWillAppear:, at the time when -viewIsAppearing: is called all of the following are valid for the view controller and its own view:

  • View controller and view’s trait collection
  • View’s superview chain and window
  • View’s geometry (e.g. frame/bounds, safe area insets, layout margins) Choose this method instead of -viewWillAppear: by default, as it is a direct replacement that provides equivalent or superior behavior in nearly all cases.
Source

pub fn viewDidAppear(&self, animated: bool)

Called after the view has fully transitioned to visible, when any transition animations have completed.

Source

pub fn viewWillDisappear(&self, animated: bool)

Called when the view is about to be dismissed, covered, or otherwise hidden.

Source

pub fn viewDidDisappear(&self, animated: bool)

Called after the view has fully been dismissed, covered, or otherwise hidden, when any transition animations have completed.

Source

pub fn setNeedsUpdateProperties(&self)

Call to manually request a properties update for the view controller. Multiple requests may be coalesced into a single update alongside the next layout pass.

Source

pub fn updateProperties(&self)

Override point for subclasses to update properties of this view controller or its view. Never call this method directly; use setNeedsUpdateProperties to schedule an update.

Source

pub fn updatePropertiesIfNeeded(&self)

Forces an immediate properties update for this view controller and its view, including any view controllers and views in this subtree.

Source

pub fn viewWillLayoutSubviews(&self)

Source

pub fn viewDidLayoutSubviews(&self)

Source

pub fn title(&self) -> Option<Retained<NSString>>

Source

pub fn setTitle(&self, title: Option<&NSString>)

Setter for title.

This is copied when set.

Source

pub fn didReceiveMemoryWarning(&self)

Source

pub fn parentViewController(&self) -> Option<Retained<UIViewController>>

Source

pub fn modalViewController(&self) -> Option<Retained<UIViewController>>

👎Deprecated
Source

pub fn presentedViewController(&self) -> Option<Retained<UIViewController>>

Source

pub fn presentingViewController(&self) -> Option<Retained<UIViewController>>

Source

pub fn definesPresentationContext(&self) -> bool

Source

pub fn setDefinesPresentationContext(&self, defines_presentation_context: bool)

Source

pub fn providesPresentationContextTransitionStyle(&self) -> bool

Source

pub fn setProvidesPresentationContextTransitionStyle( &self, provides_presentation_context_transition_style: bool, )

Source

pub fn restoresFocusAfterTransition(&self) -> bool

Source

pub fn setRestoresFocusAfterTransition( &self, restores_focus_after_transition: bool, )

Source

pub fn focusGroupIdentifier(&self) -> Option<Retained<NSString>>

The identifier of the focus group that this view controller belongs to. If this is nil, the view controller inherits the focus group of its parent focus environment.

Source

pub fn setFocusGroupIdentifier(&self, focus_group_identifier: Option<&NSString>)

Setter for focusGroupIdentifier.

This is copied when set.

Source

pub fn interactionActivityTrackingBaseName(&self) -> Option<Retained<NSString>>

The base name for tracking user interactions as activities hosted by this view controller.

Source

pub fn setInteractionActivityTrackingBaseName( &self, interaction_activity_tracking_base_name: Option<&NSString>, )

Setter for interactionActivityTrackingBaseName.

This is copied when set.

Source

pub fn isBeingPresented(&self) -> bool

Source

pub fn isBeingDismissed(&self) -> bool

Source

pub fn isMovingToParentViewController(&self) -> bool

Source

pub fn isMovingFromParentViewController(&self) -> bool

Source

pub fn presentModalViewController_animated( &self, modal_view_controller: &UIViewController, animated: bool, )

👎Deprecated
Source

pub fn dismissModalViewControllerAnimated(&self, animated: bool)

👎Deprecated
Source

pub fn modalTransitionStyle(&self) -> UIModalTransitionStyle

Source

pub fn setModalTransitionStyle( &self, modal_transition_style: UIModalTransitionStyle, )

Source

pub fn modalPresentationStyle(&self) -> UIModalPresentationStyle

Source

pub fn setModalPresentationStyle( &self, modal_presentation_style: UIModalPresentationStyle, )

Source

pub fn modalPresentationCapturesStatusBarAppearance(&self) -> bool

Source

pub fn setModalPresentationCapturesStatusBarAppearance( &self, modal_presentation_captures_status_bar_appearance: bool, )

Source

pub fn disablesAutomaticKeyboardDismissal(&self) -> bool

Source

pub fn wantsFullScreenLayout(&self) -> bool

👎Deprecated
Source

pub fn setWantsFullScreenLayout(&self, wants_full_screen_layout: bool)

👎Deprecated
Source

pub fn extendedLayoutIncludesOpaqueBars(&self) -> bool

Source

pub fn setExtendedLayoutIncludesOpaqueBars( &self, extended_layout_includes_opaque_bars: bool, )

Source

pub fn automaticallyAdjustsScrollViewInsets(&self) -> bool

👎Deprecated: Use UIScrollView’s contentInsetAdjustmentBehavior instead
Source

pub fn setAutomaticallyAdjustsScrollViewInsets( &self, automatically_adjusts_scroll_view_insets: bool, )

👎Deprecated: Use UIScrollView’s contentInsetAdjustmentBehavior instead
Source

pub fn prefersStatusBarHidden(&self) -> bool

👎Deprecated: Has no effect on visionOS
Source

pub fn setNeedsStatusBarAppearanceUpdate(&self)

Source

pub unsafe fn targetViewControllerForAction_sender( &self, action: Sel, sender: Option<&AnyObject>, ) -> Option<Retained<UIViewController>>

§Safety
  • action must be a valid selector.
  • sender should be of the correct type.
Source

pub unsafe fn showViewController_sender( &self, vc: &UIViewController, sender: Option<&AnyObject>, )

§Safety

sender should be of the correct type.

Source

pub unsafe fn showDetailViewController_sender( &self, vc: &UIViewController, sender: Option<&AnyObject>, )

§Safety

sender should be of the correct type.

Source

pub fn setNeedsUserInterfaceAppearanceUpdate(&self)

Source

pub fn shouldAutorotate(&self) -> bool

👎Deprecated: Update supported interface orientations and call setNeedsUpdateOfSupportedInterfaceOrientations to indicate a change.
Source

pub fn setNeedsUpdateOfSupportedInterfaceOrientations(&self)

Notifies the view controller that a change occurred that affects supported interface orientations or the preferred interface orientation for presentation. By default, this will animate any changes to orientation. To perform a non-animated update, call within [UIView performWithoutAnimation:].

Source

pub fn isEditing(&self) -> bool

Source

pub fn setEditing(&self, editing: bool)

Setter for isEditing.

Source

pub fn setEditing_animated(&self, editing: bool, animated: bool)

Source

pub fn childViewControllers(&self) -> Retained<NSArray<UIViewController>>

Source

pub fn addChildViewController(&self, child_controller: &UIViewController)

Source

pub fn removeFromParentViewController(&self)

Source

pub fn beginAppearanceTransition_animated( &self, is_appearing: bool, animated: bool, )

Source

pub fn endAppearanceTransition(&self)

Source

pub fn childViewControllerForStatusBarStyle( &self, ) -> Option<Retained<UIViewController>>

👎Deprecated: Has no effect on visionOS
Source

pub fn childViewControllerForStatusBarHidden( &self, ) -> Option<Retained<UIViewController>>

👎Deprecated: Has no effect on visionOS
Source

pub fn setOverrideTraitCollection_forChildViewController( &self, collection: Option<&UITraitCollection>, child_view_controller: &UIViewController, )

👎Deprecated: Use the traitOverrides property on the child view controller instead
Source

pub fn overrideTraitCollectionForChildViewController( &self, child_view_controller: &UIViewController, ) -> Option<Retained<UITraitCollection>>

👎Deprecated: Use the traitOverrides property on the child view controller instead
Source

pub fn childViewControllerForUserInterfaceStyle( &self, ) -> Option<Retained<UIViewController>>

Source

pub fn automaticallyForwardAppearanceAndRotationMethodsToChildViewControllers( &self, ) -> bool

👎Deprecated
Source

pub fn shouldAutomaticallyForwardRotationMethods(&self) -> bool

👎Deprecated: Manually forward viewWillTransitionToSize:withTransitionCoordinator: if necessary
Source

pub fn shouldAutomaticallyForwardAppearanceMethods(&self) -> bool

Source

pub fn willMoveToParentViewController(&self, parent: Option<&UIViewController>)

Source

pub fn didMoveToParentViewController(&self, parent: Option<&UIViewController>)

Source

pub fn restorationIdentifier(&self) -> Option<Retained<NSString>>

Source

pub fn setRestorationIdentifier( &self, restoration_identifier: Option<&NSString>, )

Setter for restorationIdentifier.

This is copied when set.

Source

pub unsafe fn encodeRestorableStateWithCoder(&self, coder: &NSCoder)

§Safety

coder possibly has further requirements.

Source

pub unsafe fn decodeRestorableStateWithCoder(&self, coder: &NSCoder)

§Safety

coder possibly has further requirements.

Source

pub fn applicationFinishedRestoringState(&self)

Source

pub fn updateViewConstraints(&self)

Source

pub fn viewRespectsSystemMinimumLayoutMargins(&self) -> bool

Source

pub fn setViewRespectsSystemMinimumLayoutMargins( &self, view_respects_system_minimum_layout_margins: bool, )

Source

pub fn viewLayoutMarginsDidChange(&self)

Source

pub fn viewSafeAreaInsetsDidChange(&self)

Source

pub fn performsActionsWhilePresentingModally(&self) -> bool

Determines whether the receiver continues to respond to actions while it is presenting a view controller modally.

Defaults to YES. You can change the default return value by providing a value for UIViewControllerPerformsActionsWhilePresentingModally in your Info.plist file.

Source

pub fn extensionContext(&self) -> Option<Retained<NSExtensionContext>>

Source

pub fn isModalInPresentation(&self) -> bool

Source

pub fn setModalInPresentation(&self, modal_in_presentation: bool)

Source

pub fn unregisterForPreviewingWithContext( &self, previewing: &ProtocolObject<dyn UIViewControllerPreviewing>, )

👎Deprecated: UIViewControllerPreviewing is deprecated. Please use UIContextMenuInteraction.
Source

pub fn childViewControllerForScreenEdgesDeferringSystemGestures( &self, ) -> Option<Retained<UIViewController>>

Source

pub fn setNeedsUpdateOfScreenEdgesDeferringSystemGestures(&self)

Source

pub fn childViewControllerForHomeIndicatorAutoHidden( &self, ) -> Option<Retained<UIViewController>>

Source

pub fn prefersHomeIndicatorAutoHidden(&self) -> bool

Source

pub fn setNeedsUpdateOfHomeIndicatorAutoHidden(&self)

Source

pub fn childViewControllerForPointerLock( &self, ) -> Option<Retained<UIViewController>>

Source

pub fn prefersPointerLocked(&self) -> bool

Source

pub fn setNeedsUpdateOfPrefersPointerLocked(&self)

Source

pub fn setNeedsUpdateContentUnavailableConfiguration(&self)

Requests the view update its content unavailable configuration for its current state. This method is called automatically when the view’s contentUnavailableConfigurationState may have changed, as well as in other circumstances where an update may be required. Multiple requests may be coalesced into a single update at the appropriate time.

Source

pub fn childViewControllerForInterfaceOrientationLock( &self, ) -> Option<Retained<UIViewController>>

Override to return a child view controller or nil. If non-nil, that view controller’s preference for interface orientation lock will be used. If nil, self is used. Whenever the return value changes, call setNeedsUpdateOfPrefersInterfaceOrientationLocked().

Source

pub fn prefersInterfaceOrientationLocked(&self) -> bool

Whether this view controller prefers the scene’s interface orientation to be locked when shown. The default is NO. Note that this preference may or may not be honored. See UIWindowScene.Geometry for the current state of interface orientation lock.

Source

pub fn setNeedsUpdateOfPrefersInterfaceOrientationLocked(&self)

Call whenever the view controller’s preference for interface orientation lock has changed

Source

pub fn previewActionItems( &self, ) -> Retained<NSArray<ProtocolObject<dyn UIPreviewActionItem>>>

👎Deprecated: UIViewControllerPreviewing is deprecated. Please use UIContextMenuInteraction.
Source

pub fn traitOverrides(&self) -> Retained<ProtocolObject<dyn UITraitOverrides>>

Source

pub fn updateTraitsIfNeeded(&self)

Forces an immediate trait update for this view controller and its view, including any view controllers and views in this subtree. Any trait change callbacks are sent synchronously.

Source

pub fn preferredContainerBackgroundStyle(&self) -> UIContainerBackgroundStyle

Source

pub fn childViewControllerForPreferredContainerBackgroundStyle( &self, ) -> Option<Retained<UIViewController>>

Source

pub fn setNeedsUpdateOfPreferredContainerBackgroundStyle(&self)

Methods from Deref<Target = UIResponder>§

Source

pub fn nextResponder(&self) -> Option<Retained<UIResponder>>

Source

pub fn canBecomeFirstResponder(&self) -> bool

Source

pub fn becomeFirstResponder(&self) -> bool

Source

pub fn canResignFirstResponder(&self) -> bool

Source

pub fn resignFirstResponder(&self) -> bool

Source

pub fn isFirstResponder(&self) -> bool

Source

pub unsafe fn canPerformAction_withSender( &self, action: Sel, sender: Option<&AnyObject>, ) -> bool

§Safety
  • action must be a valid selector.
  • sender should be of the correct type.
Source

pub unsafe fn targetForAction_withSender( &self, action: Sel, sender: Option<&AnyObject>, ) -> Option<Retained<AnyObject>>

§Safety
  • action must be a valid selector.
  • sender should be of the correct type.
Source

pub fn undoManager(&self) -> Option<Retained<NSUndoManager>>

Source

pub fn editingInteractionConfiguration( &self, ) -> UIEditingInteractionConfiguration

Source

pub fn textInputContextIdentifier(&self) -> Option<Retained<NSString>>

Source

pub fn reloadInputViews(&self)

Source

pub fn userActivity(&self) -> Option<Retained<NSUserActivity>>

Source

pub fn setUserActivity(&self, user_activity: Option<&NSUserActivity>)

Setter for userActivity.

Source

pub fn updateUserActivityState(&self, activity: &NSUserActivity)

Source

pub fn restoreUserActivityState(&self, activity: &NSUserActivity)

Source

pub unsafe fn captureTextFromCamera(&self, sender: Option<&AnyObject>)

§Safety

sender should be of the correct type.

Methods from Deref<Target = NSObject>§

Source

pub fn doesNotRecognizeSelector(&self, sel: Sel) -> !

Handle messages the object doesn’t recognize.

See Apple’s documentation for details.

Methods from Deref<Target = AnyObject>§

Source

pub fn class(&self) -> &'static AnyClass

Dynamically find the class of this object.

§Panics

May panic if the object is invalid (which may be the case for objects returned from unavailable init/new methods).

§Example

Check that an instance of NSObject has the precise class NSObject.

use objc2::ClassType;
use objc2::runtime::NSObject;

let obj = NSObject::new();
assert_eq!(obj.class(), NSObject::class());
Source

pub unsafe fn get_ivar<T>(&self, name: &str) -> &T
where T: Encode,

👎Deprecated: this is difficult to use correctly, use Ivar::load instead.

Use Ivar::load instead.

§Safety

The object must have an instance variable with the given name, and it must be of type T.

See Ivar::load_ptr for details surrounding this.

Source

pub fn downcast_ref<T>(&self) -> Option<&T>
where T: DowncastTarget,

Attempt to downcast the object to a class of type T.

This is the reference-variant. Use Retained::downcast if you want to convert a retained object to another type.

§Mutable classes

Some classes have immutable and mutable variants, such as NSString and NSMutableString.

When some Objective-C API signature says it gives you an immutable class, it generally expects you to not mutate that, even though it may technically be mutable “under the hood”.

So using this method to convert a NSString to a NSMutableString, while not unsound, is generally frowned upon unless you created the string yourself, or the API explicitly documents the string to be mutable.

See Apple’s documentation on mutability and on isKindOfClass: for more details.

§Generic classes

Objective-C generics are called “lightweight generics”, and that’s because they aren’t exposed in the runtime. This makes it impossible to safely downcast to generic collections, so this is disallowed by this method.

You can, however, safely downcast to generic collections where all the type-parameters are AnyObject.

§Panics

This works internally by calling isKindOfClass:. That means that the object must have the instance method of that name, and an exception will be thrown (if CoreFoundation is linked) or the process will abort if that is not the case. In the vast majority of cases, you don’t need to worry about this, since both root objects NSObject and NSProxy implement this method.

§Examples

Cast an NSString back and forth from NSObject.

use objc2::rc::Retained;
use objc2_foundation::{NSObject, NSString};

let obj: Retained<NSObject> = NSString::new().into_super();
let string = obj.downcast_ref::<NSString>().unwrap();
// Or with `downcast`, if we do not need the object afterwards
let string = obj.downcast::<NSString>().unwrap();

Try (and fail) to cast an NSObject to an NSString.

use objc2_foundation::{NSObject, NSString};

let obj = NSObject::new();
assert!(obj.downcast_ref::<NSString>().is_none());

Try to cast to an array of strings.

use objc2_foundation::{NSArray, NSObject, NSString};

let arr = NSArray::from_retained_slice(&[NSObject::new()]);
// This is invalid and doesn't type check.
let arr = arr.downcast_ref::<NSArray<NSString>>();

This fails to compile, since it would require enumerating over the array to ensure that each element is of the desired type, which is a performance pitfall.

Downcast when processing each element instead.

use objc2_foundation::{NSArray, NSObject, NSString};

let arr = NSArray::from_retained_slice(&[NSObject::new()]);

for elem in arr {
    if let Some(data) = elem.downcast_ref::<NSString>() {
        // handle `data`
    }
}

Trait Implementations§

Source§

impl AsRef<AnyObject> for MFMailComposeViewController

Source§

fn as_ref(&self) -> &AnyObject

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<MFMailComposeViewController> for MFMailComposeViewController

Source§

fn as_ref(&self) -> &Self

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<NSObject> for MFMailComposeViewController

Source§

fn as_ref(&self) -> &NSObject

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<UINavigationController> for MFMailComposeViewController

Source§

fn as_ref(&self) -> &UINavigationController

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<UIResponder> for MFMailComposeViewController

Source§

fn as_ref(&self) -> &UIResponder

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<UIViewController> for MFMailComposeViewController

Source§

fn as_ref(&self) -> &UIViewController

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl Borrow<AnyObject> for MFMailComposeViewController

Source§

fn borrow(&self) -> &AnyObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<NSObject> for MFMailComposeViewController

Source§

fn borrow(&self) -> &NSObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<UINavigationController> for MFMailComposeViewController

Source§

fn borrow(&self) -> &UINavigationController

Immutably borrows from an owned value. Read more
Source§

impl Borrow<UIResponder> for MFMailComposeViewController

Source§

fn borrow(&self) -> &UIResponder

Immutably borrows from an owned value. Read more
Source§

impl Borrow<UIViewController> for MFMailComposeViewController

Source§

fn borrow(&self) -> &UIViewController

Immutably borrows from an owned value. Read more
Source§

impl ClassType for MFMailComposeViewController

Source§

const NAME: &'static str = "MFMailComposeViewController"

The name of the Objective-C class that this type represents. Read more
Source§

type Super = UINavigationController

The superclass of this class. Read more
Source§

type ThreadKind = <<MFMailComposeViewController as ClassType>::Super as ClassType>::ThreadKind

Whether the type can be used from any thread, or from only the main thread. Read more
Source§

fn class() -> &'static AnyClass

Get a reference to the Objective-C class that this type represents. Read more
Source§

fn as_super(&self) -> &Self::Super

Get an immutable reference to the superclass.
Source§

impl Debug for MFMailComposeViewController

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Deref for MFMailComposeViewController

Source§

type Target = UINavigationController

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl Hash for MFMailComposeViewController

Source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Message for MFMailComposeViewController

Source§

fn retain(&self) -> Retained<Self>
where Self: Sized,

Increment the reference count of the receiver. Read more
Source§

impl NSCoding for MFMailComposeViewController

Source§

unsafe fn encodeWithCoder(&self, coder: &NSCoder)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn initWithCoder( this: Allocated<Self>, coder: &NSCoder, ) -> Option<Retained<Self>>
where Self: Sized + Message,

Safety Read more
Source§

impl NSObjectProtocol for MFMailComposeViewController

Source§

fn isEqual(&self, other: Option<&AnyObject>) -> bool
where Self: Sized + Message,

Check whether the object is equal to an arbitrary other object. Read more
Source§

fn hash(&self) -> usize
where Self: Sized + Message,

An integer that can be used as a table address in a hash table structure. Read more
Source§

fn isKindOfClass(&self, cls: &AnyClass) -> bool
where Self: Sized + Message,

Check if the object is an instance of the class, or one of its subclasses. Read more
Source§

fn is_kind_of<T>(&self) -> bool
where T: ClassType, Self: Sized + Message,

👎Deprecated: use isKindOfClass directly, or cast your objects with AnyObject::downcast_ref
Check if the object is an instance of the class type, or one of its subclasses. Read more
Source§

fn isMemberOfClass(&self, cls: &AnyClass) -> bool
where Self: Sized + Message,

Check if the object is an instance of a specific class, without checking subclasses. Read more
Source§

fn respondsToSelector(&self, aSelector: Sel) -> bool
where Self: Sized + Message,

Check whether the object implements or inherits a method with the given selector. Read more
Source§

fn conformsToProtocol(&self, aProtocol: &AnyProtocol) -> bool
where Self: Sized + Message,

Check whether the object conforms to a given protocol. Read more
Source§

fn description(&self) -> Retained<NSObject>
where Self: Sized + Message,

A textual representation of the object. Read more
Source§

fn debugDescription(&self) -> Retained<NSObject>
where Self: Sized + Message,

A textual representation of the object to use when debugging. Read more
Source§

fn isProxy(&self) -> bool
where Self: Sized + Message,

Check whether the receiver is a subclass of the NSProxy root class instead of the usual NSObject. Read more
Source§

fn retainCount(&self) -> usize
where Self: Sized + Message,

The reference count of the object. Read more
Source§

impl PartialEq for MFMailComposeViewController

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl RefEncode for MFMailComposeViewController

Source§

const ENCODING_REF: Encoding = <UINavigationController as ::objc2::RefEncode>::ENCODING_REF

The Objective-C type-encoding for a reference of this type. Read more
Source§

impl UIContentContainer for MFMailComposeViewController

Source§

impl UIFocusEnvironment for MFMailComposeViewController

Source§

fn preferredFocusEnvironments( &self, ) -> Retained<NSArray<ProtocolObject<dyn UIFocusEnvironment>>>
where Self: Sized + Message,

The preferred focus environments define where to search for the default focused item in an environment, such as when focus updates programmatically. Starting from the target environment, each preferred focus environment is recursively searched in the order of the array until an eligible, focusable item is found. Preferred focus environments can include focusable and non-focusable items, in addition to non-item environments. Returning an empty array is equivalent to returning an array containing only ‘self’.
Source§

fn parentFocusEnvironment( &self, ) -> Option<Retained<ProtocolObject<dyn UIFocusEnvironment>>>
where Self: Sized + Message,

The parent focus environment of this environment, or nil if no parent exists. NOTE: If you implement this method, you must return a non-nil value for parent focus environment, otherwise your focus environment will not participate in focus interactions.
Source§

fn focusItemContainer( &self, ) -> Option<Retained<ProtocolObject<dyn UIFocusItemContainer>>>
where Self: Sized + Message,

The container of any child focus items in this focus environment, or nil if no container exists.
Source§

fn setNeedsFocusUpdate(&self)
where Self: Sized + Message,

Marks this environment as needing a focus update, which if accepted will attempt to reset focus to this environment, or one of its preferred focus environments, on the next update cycle. If this environment does not currently contain the focused item, then calling this method has no effect. If a parent of this environment is also requesting focus, then this environment’s request is rejected in favor of the parent’s. NOTE: If you provide your own implementation, it must call [[UIFocusSystem focusSystemForEnvironment:self] requestFocusUpdateToEnvironment:self];
Source§

fn updateFocusIfNeeded(&self)
where Self: Sized + Message,

Forces focus to be updated immediately. If there is an environment that has requested a focus update via -setNeedsFocusUpdate, and the request was accepted, then focus will be updated to that environment or one of its preferred focus environments. NOTE: If you provide your own implementation, it must call [[UIFocusSystem focusSystemForEnvironment:self] updateFocusIfNeeded];.
Source§

fn shouldUpdateFocusInContext(&self, context: &UIFocusUpdateContext) -> bool
where Self: Sized + Message,

Asks whether the system should allow a focus update to occur.
Source§

fn soundIdentifierForFocusUpdateInContext( &self, context: &UIFocusUpdateContext, ) -> Option<Retained<NSString>>
where Self: Sized + Message,

Specifies an identifier corresponding to a sound that should be played for a focus update. Return UIFocusSoundIdentifierNone to opt out of sounds, UIFocusSoundIdentifierDefault for the system default sounds, a previously registered identifier for a custom sound, or nil to defer the decision to the parent.
Source§

fn focusGroupIdentifier(&self) -> Option<Retained<NSString>>
where Self: Sized + Message,

The identifier of the focus group that this view belongs to. If this is nil, subviews inherit their superview’s focus group.
Source§

impl UIResponderStandardEditActions for MFMailComposeViewController

Source§

unsafe fn cut(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn copy(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn paste(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn pasteAndMatchStyle(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn pasteAndGo(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn pasteAndSearch(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn newFromPasteboard(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn select(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn selectAll(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn delete(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn makeTextWritingDirectionLeftToRight(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn makeTextWritingDirectionRightToLeft(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn toggleBoldface(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn toggleItalics(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn toggleUnderline(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn increaseSize(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn decreaseSize(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn alignLeft(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn alignCenter(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn alignJustified(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn alignRight(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn find(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn findAndReplace(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn findNext(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn findPrevious(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn useSelectionForFind(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn print(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn rename(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn duplicate(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn move(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn export(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn toggleSidebar(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn toggleInspector(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn performClose(&self, sender: Option<&AnyObject>)
where Self: Sized + Message,

Safety Read more
Source§

unsafe fn showWritingTools(&self, sender: &AnyObject)
where Self: Sized + Message,

Safety Read more
Source§

impl UITraitEnvironment for MFMailComposeViewController

Source§

fn traitCollection(&self) -> Retained<UITraitCollection>
where Self: Sized + Message,

Source§

fn traitCollectionDidChange( &self, previous_trait_collection: Option<&UITraitCollection>, )
where Self: Sized + Message,

👎Deprecated: Use the trait change registration APIs declared in the UITraitChangeObservable protocol
To be overridden as needed to provide custom behavior when the environment’s traits change.
Source§

impl DowncastTarget for MFMailComposeViewController

Source§

impl Eq for MFMailComposeViewController

Source§

impl UIAppearanceContainer for MFMailComposeViewController

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<'a, T> MainThreadOnly for T
where T: ClassType<ThreadKind = dyn MainThreadOnly + 'a> + ?Sized,

Source§

fn mtm(&self) -> MainThreadMarker

Get a MainThreadMarker from the main-thread-only object. Read more
Source§

fn alloc(mtm: MainThreadMarker) -> Allocated<Self>
where Self: Sized + ClassType,

Allocate a new instance of the class on the main thread. Read more
Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> AutoreleaseSafe for T
where T: ?Sized,