TVCaptionButtonView

Struct TVCaptionButtonView 

Source
pub struct TVCaptionButtonView { /* private fields */ }
Available on crate features TVCaptionButtonView and TVLockupView only.
Expand description

TVCaptionButtonView is a button-like lockup view with a caption (or a footer), which itself consists of a title and a subtitle.

The caption button view can have either a content image or content text. The system adds it to a floating view with a knock-out effect. When in focus, the floating view will scale up in the .leading, .top., and .trailing directions by a fixed amount determined by the system. Overriding .focusSizeIncrease has no visible effect.

See also Apple’s documentation

Implementations§

Source§

impl TVCaptionButtonView

Source

pub unsafe fn motionDirection(&self) -> TVCaptionButtonViewMotionDirection

Source

pub unsafe fn setMotionDirection( &self, motion_direction: TVCaptionButtonViewMotionDirection, )

Setter for motionDirection.

Source

pub unsafe fn contentImage(&self) -> Option<Retained<UIImage>>

The content image

If a contentText exists, setting contentImage will remove it and take its place. By default, the system creates a template image from the alpha values in the source image. To prevent system coloring, provide the source image with UIImageRenderingModeAlwaysOriginal.

Source

pub unsafe fn setContentImage(&self, content_image: Option<&UIImage>)

Setter for contentImage.

Source

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

The content text

If a contentImage exists, setting contentText will remove it and take its place.

Source

pub unsafe fn setContentText(&self, content_text: Option<&NSString>)

Setter for contentText.

This is copied when set.

Source

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

The title text

Source

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

Setter for title.

This is copied when set.

Source

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

The subtitle text

Source

pub unsafe fn setSubtitle(&self, subtitle: Option<&NSString>)

Setter for subtitle.

This is copied when set.

Source§

impl TVCaptionButtonView

Methods declared on superclass UIControl.

Source

pub unsafe fn initWithFrame( this: Allocated<Self>, frame: CGRect, ) -> Retained<Self>

Available on crate feature objc2-core-foundation only.
Source

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

§Safety

coder possibly has further requirements.

Source

pub unsafe fn initWithFrame_primaryAction( this: Allocated<Self>, frame: CGRect, primary_action: Option<&UIAction>, ) -> Retained<Self>

Available on crate feature objc2-core-foundation only.

Initializes the control and adds primaryAction for the UIControlEventPrimaryActionTriggered control event. Subclasses of UIControl may alter or add behaviors around the usage of primaryAction, see subclass documentation of this initializer for additional information.

Source§

impl TVCaptionButtonView

Methods declared on superclass UIView.

Source

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

Source§

impl TVCaptionButtonView

Methods declared on superclass NSObject.

Source

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

Methods from Deref<Target = TVLockupView>§

Source

pub unsafe fn contentView(&self) -> Retained<UIView>

The container view where subviews are added.

Clients should add their subviews to the contentView. Views added directly to the lockup view have undefined behaviors.

Source

pub unsafe fn contentSize(&self) -> CGSize

Available on crate feature objc2-core-foundation only.

The size of the content

Clients can use this to explicitly set the size of the content. Default results in system default contentSize.

Source

pub unsafe fn setContentSize(&self, content_size: CGSize)

Available on crate feature objc2-core-foundation only.

Setter for contentSize.

Source

pub unsafe fn headerView(&self) -> Option<Retained<TVLockupHeaderFooterView>>

Available on crate feature TVLockupHeaderFooterView only.

The optional header and footer views.

Subclass TVLockupHeaderFooterView for additional customization.

Source

pub unsafe fn setHeaderView( &self, header_view: Option<&TVLockupHeaderFooterView>, )

Available on crate feature TVLockupHeaderFooterView only.

Setter for headerView.

Source

pub unsafe fn footerView(&self) -> Option<Retained<TVLockupHeaderFooterView>>

Available on crate feature TVLockupHeaderFooterView only.
Source

pub unsafe fn setFooterView( &self, footer_view: Option<&TVLockupHeaderFooterView>, )

Available on crate feature TVLockupHeaderFooterView only.

Setter for footerView.

Source

pub unsafe fn contentViewInsets(&self) -> NSDirectionalEdgeInsets

The spacing between the content view and its sibling and parent views

.top and .bottom are spaces between the contentView and headerView and footerView, respectively. .leading and .trailing are between contentView and the lockup view itself. Use negative values for positive spacing.

Source

pub unsafe fn setContentViewInsets( &self, content_view_insets: NSDirectionalEdgeInsets, )

Setter for contentViewInsets.

Source

pub unsafe fn focusSizeIncrease(&self) -> NSDirectionalEdgeInsets

The size increase when the lockup view or its subview is in focus

The amount by which headerView and footerView will move when the lockup view or its subview is in focus. Use negative values for positive increase.

Source

pub unsafe fn setFocusSizeIncrease( &self, focus_size_increase: NSDirectionalEdgeInsets, )

Setter for focusSizeIncrease.

Methods from Deref<Target = UIControl>§

Source

pub fn isEnabled(&self) -> bool

Source

pub fn setEnabled(&self, enabled: bool)

Setter for isEnabled.

Source

pub fn isSelected(&self) -> bool

Source

pub fn setSelected(&self, selected: bool)

Setter for isSelected.

Source

pub fn isHighlighted(&self) -> bool

Source

pub fn setHighlighted(&self, highlighted: bool)

Setter for isHighlighted.

Source

pub fn contentVerticalAlignment(&self) -> UIControlContentVerticalAlignment

Source

pub fn setContentVerticalAlignment( &self, content_vertical_alignment: UIControlContentVerticalAlignment, )

Source

pub fn contentHorizontalAlignment(&self) -> UIControlContentHorizontalAlignment

Source

pub fn setContentHorizontalAlignment( &self, content_horizontal_alignment: UIControlContentHorizontalAlignment, )

Source

pub fn effectiveContentHorizontalAlignment( &self, ) -> UIControlContentHorizontalAlignment

Source

pub fn state(&self) -> UIControlState

Source

pub fn isTracking(&self) -> bool

Source

pub fn isTouchInside(&self) -> bool

Source

pub unsafe fn addTarget_action_forControlEvents( &self, target: Option<&AnyObject>, action: Sel, control_events: UIControlEvents, )

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

pub unsafe fn removeTarget_action_forControlEvents( &self, target: Option<&AnyObject>, action: Option<Sel>, control_events: UIControlEvents, )

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

pub fn addAction_forControlEvents( &self, action: &UIAction, control_events: UIControlEvents, )

Adds the UIAction to a given event. UIActions are uniqued based on their identifier, and subsequent actions with the same identifier replace previously added actions. You may add multiple UIActions for corresponding controlEvents, and you may add the same action to multiple controlEvents.

Source

pub fn removeAction_forControlEvents( &self, action: &UIAction, control_events: UIControlEvents, )

Removes the action from the set of passed control events.

Source

pub fn removeActionForIdentifier_forControlEvents( &self, action_identifier: &NSString, control_events: UIControlEvents, )

Removes the action with the provided identifier from the set of passed control events.

Source

pub fn performPrimaryAction(&self)

Performs the control’s primary action.

Source

pub fn allTargets(&self) -> Retained<NSSet>

Source

pub fn allControlEvents(&self) -> UIControlEvents

Source

pub unsafe fn actionsForTarget_forControlEvent( &self, target: Option<&AnyObject>, control_event: UIControlEvents, ) -> Option<Retained<NSArray<NSString>>>

§Safety

target should be of the correct type.

Source

pub fn sendAction(&self, action: &UIAction)

Like -sendAction:to:forEvent:, this method is called by -sendActionsForControlEvents:. You may override this method to observe or modify behavior. If you override this method, you should call super precisely once to dispatch the action, or not call super to suppress sending that action.

Source

pub fn sendActionsForControlEvents(&self, control_events: UIControlEvents)

send all actions associated with the given control events

Source

pub fn isContextMenuInteractionEnabled(&self) -> bool

Specifies if the context menu interaction is enabled. NO by default.

Source

pub fn setContextMenuInteractionEnabled( &self, context_menu_interaction_enabled: bool, )

Source

pub fn showsMenuAsPrimaryAction(&self) -> bool

If the contextMenuInteraction is the primary action of the control, invoked on touch-down. NO by default.

Source

pub fn setShowsMenuAsPrimaryAction(&self, shows_menu_as_primary_action: bool)

Source

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

Assigning a value to this property causes the tool tip to be displayed for the view. Setting the property to nil cancels the display of the tool tip for the view.

Source

pub fn setToolTip(&self, tool_tip: Option<&NSString>)

Setter for toolTip.

This is copied when set.

Source

pub fn isSymbolAnimationEnabled(&self) -> bool

Whether or not symbol animations are enabled for this control. The default value varies depending on the control.

Source

pub fn setSymbolAnimationEnabled(&self, symbol_animation_enabled: bool)

Methods from Deref<Target = UIView>§

Source

pub fn isUserInteractionEnabled(&self) -> bool

Source

pub fn setUserInteractionEnabled(&self, user_interaction_enabled: bool)

Source

pub fn tag(&self) -> isize

Source

pub fn setTag(&self, tag: isize)

Setter for tag.

Source

pub fn canBecomeFocused(&self) -> bool

Source

pub fn isFocused(&self) -> bool

Source

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

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

Source

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

Setter for focusGroupIdentifier.

This is copied when set.

Source

pub fn focusGroupPriority(&self) -> isize

The priority this item has in its focus group. The higher the priority, the more likely it is to get picked when focus moves into this group. Note: this method can only be used to increase an item’s priority, not decrease it. For example if an item is currently selected, the actual priority of this item will be determined by MAX(focusGroupPriority, UIFocusGroupPrioritySelected).

Source

pub fn setFocusGroupPriority(&self, focus_group_priority: isize)

Setter for focusGroupPriority.

Source

pub fn semanticContentAttribute(&self) -> UISemanticContentAttribute

Source

pub fn setSemanticContentAttribute( &self, semantic_content_attribute: UISemanticContentAttribute, )

Source

pub fn frame(&self) -> CGRect

Source

pub fn setFrame(&self, frame: CGRect)

Setter for frame.

Source

pub fn bounds(&self) -> CGRect

Source

pub fn setBounds(&self, bounds: CGRect)

Setter for bounds.

Source

pub fn center(&self) -> CGPoint

Source

pub fn setCenter(&self, center: CGPoint)

Setter for center.

Source

pub fn transform(&self) -> CGAffineTransform

Source

pub fn setTransform(&self, transform: CGAffineTransform)

Setter for transform.

Source

pub fn contentScaleFactor(&self) -> f64

Source

pub fn setContentScaleFactor(&self, content_scale_factor: f64)

Setter for contentScaleFactor.

Source

pub fn anchorPoint(&self) -> CGPoint

Source

pub fn setAnchorPoint(&self, anchor_point: CGPoint)

Setter for anchorPoint.

Source

pub fn isMultipleTouchEnabled(&self) -> bool

Source

pub fn setMultipleTouchEnabled(&self, multiple_touch_enabled: bool)

Source

pub fn isExclusiveTouch(&self) -> bool

Source

pub fn setExclusiveTouch(&self, exclusive_touch: bool)

Setter for isExclusiveTouch.

Source

pub fn convertPoint_toView( &self, point: CGPoint, view: Option<&UIView>, ) -> CGPoint

Source

pub fn convertPoint_fromView( &self, point: CGPoint, view: Option<&UIView>, ) -> CGPoint

Source

pub fn convertRect_toView(&self, rect: CGRect, view: Option<&UIView>) -> CGRect

Source

pub fn convertRect_fromView( &self, rect: CGRect, view: Option<&UIView>, ) -> CGRect

Source

pub fn autoresizesSubviews(&self) -> bool

Source

pub fn setAutoresizesSubviews(&self, autoresizes_subviews: bool)

Setter for autoresizesSubviews.

Source

pub fn autoresizingMask(&self) -> UIViewAutoresizing

Source

pub fn setAutoresizingMask(&self, autoresizing_mask: UIViewAutoresizing)

Setter for autoresizingMask.

Source

pub fn sizeThatFits(&self, size: CGSize) -> CGSize

Source

pub fn sizeToFit(&self)

Source

pub fn superview(&self) -> Option<Retained<UIView>>

Source

pub fn subviews(&self) -> Retained<NSArray<UIView>>

Source

pub fn removeFromSuperview(&self)

Source

pub fn insertSubview_atIndex(&self, view: &UIView, index: isize)

Source

pub fn exchangeSubviewAtIndex_withSubviewAtIndex( &self, index1: isize, index2: isize, )

Source

pub fn addSubview(&self, view: &UIView)

Source

pub fn insertSubview_belowSubview( &self, view: &UIView, sibling_subview: &UIView, )

Source

pub fn insertSubview_aboveSubview( &self, view: &UIView, sibling_subview: &UIView, )

Source

pub fn bringSubviewToFront(&self, view: &UIView)

Source

pub fn sendSubviewToBack(&self, view: &UIView)

Source

pub fn didAddSubview(&self, subview: &UIView)

Source

pub fn willRemoveSubview(&self, subview: &UIView)

Source

pub fn willMoveToSuperview(&self, new_superview: Option<&UIView>)

Source

pub fn didMoveToSuperview(&self)

Source

pub fn didMoveToWindow(&self)

Source

pub fn isDescendantOfView(&self, view: &UIView) -> bool

Source

pub fn viewWithTag(&self, tag: isize) -> Option<Retained<UIView>>

Source

pub fn setNeedsUpdateProperties(&self)

Call to manually request a properties update for the view. 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. Never call this method directly; use setNeedsUpdateProperties to schedule an update.

Source

pub fn updatePropertiesIfNeeded(&self)

Forces an immediate properties update for this view (and its view controller, if applicable) and any subviews, including any view controllers or views in its subtree.

Source

pub fn setNeedsLayout(&self)

Source

pub fn layoutIfNeeded(&self)

Source

pub fn layoutSubviews(&self)

Source

pub fn layoutMargins(&self) -> UIEdgeInsets

Source

pub fn setLayoutMargins(&self, layout_margins: UIEdgeInsets)

Setter for layoutMargins.

Source

pub fn directionalLayoutMargins(&self) -> NSDirectionalEdgeInsets

Source

pub fn setDirectionalLayoutMargins( &self, directional_layout_margins: NSDirectionalEdgeInsets, )

Source

pub fn preservesSuperviewLayoutMargins(&self) -> bool

Source

pub fn setPreservesSuperviewLayoutMargins( &self, preserves_superview_layout_margins: bool, )

Source

pub fn insetsLayoutMarginsFromSafeArea(&self) -> bool

Source

pub fn setInsetsLayoutMarginsFromSafeArea( &self, insets_layout_margins_from_safe_area: bool, )

Source

pub fn layoutMarginsDidChange(&self)

Source

pub fn safeAreaInsets(&self) -> UIEdgeInsets

Source

pub fn safeAreaInsetsDidChange(&self)

Source

pub fn layoutMarginsGuide(&self) -> Retained<UILayoutGuide>

Source

pub fn readableContentGuide(&self) -> Retained<UILayoutGuide>

This content guide provides a layout area that you can use to place text and related content whose width should generally be constrained to a size that is easy for the user to read. This guide provides a centered region that you can place content within to get this behavior for this view.

Source

pub fn safeAreaLayoutGuide(&self) -> Retained<UILayoutGuide>

Source

pub fn drawRect(&self, rect: CGRect)

Source

pub fn setNeedsDisplay(&self)

Source

pub fn setNeedsDisplayInRect(&self, rect: CGRect)

Source

pub fn clipsToBounds(&self) -> bool

Source

pub fn setClipsToBounds(&self, clips_to_bounds: bool)

Setter for clipsToBounds.

Source

pub fn backgroundColor(&self) -> Option<Retained<UIColor>>

Source

pub fn setBackgroundColor(&self, background_color: Option<&UIColor>)

Setter for backgroundColor.

This is copied when set.

Source

pub fn alpha(&self) -> f64

Source

pub fn setAlpha(&self, alpha: f64)

Setter for alpha.

Source

pub fn isOpaque(&self) -> bool

Source

pub fn setOpaque(&self, opaque: bool)

Setter for isOpaque.

Source

pub fn clearsContextBeforeDrawing(&self) -> bool

Source

pub fn setClearsContextBeforeDrawing(&self, clears_context_before_drawing: bool)

Source

pub fn isHidden(&self) -> bool

Source

pub fn setHidden(&self, hidden: bool)

Setter for isHidden.

Source

pub fn contentMode(&self) -> UIViewContentMode

Source

pub fn setContentMode(&self, content_mode: UIViewContentMode)

Setter for contentMode.

Source

pub fn contentStretch(&self) -> CGRect

👎Deprecated
Source

pub fn setContentStretch(&self, content_stretch: CGRect)

👎Deprecated

Setter for contentStretch.

Source

pub fn maskView(&self) -> Option<Retained<UIView>>

Source

pub fn setMaskView(&self, mask_view: Option<&UIView>)

Setter for maskView.

Source

pub fn tintColor(&self) -> Option<Retained<UIColor>>

Source

pub unsafe fn setTintColor(&self, tint_color: Option<&UIColor>)

Setter for tintColor.

§Safety

tint_color might not allow None.

Source

pub fn tintAdjustmentMode(&self) -> UIViewTintAdjustmentMode

Source

pub fn setTintAdjustmentMode( &self, tint_adjustment_mode: UIViewTintAdjustmentMode, )

Setter for tintAdjustmentMode.

Source

pub fn tintColorDidChange(&self)

Source

pub fn updateConstraintsIfNeeded(&self)

Source

pub fn updateConstraints(&self)

Source

pub fn needsUpdateConstraints(&self) -> bool

Source

pub fn setNeedsUpdateConstraints(&self)

Source

pub fn translatesAutoresizingMaskIntoConstraints(&self) -> bool

Source

pub fn setTranslatesAutoresizingMaskIntoConstraints( &self, translates_autoresizing_mask_into_constraints: bool, )

Source

pub fn alignmentRectForFrame(&self, frame: CGRect) -> CGRect

Source

pub fn frameForAlignmentRect(&self, alignment_rect: CGRect) -> CGRect

Source

pub fn alignmentRectInsets(&self) -> UIEdgeInsets

Source

pub fn viewForBaselineLayout(&self) -> Retained<UIView>

👎Deprecated: Override -viewForFirstBaselineLayout or -viewForLastBaselineLayout as appropriate, instead
Source

pub fn viewForFirstBaselineLayout(&self) -> Retained<UIView>

Source

pub fn viewForLastBaselineLayout(&self) -> Retained<UIView>

Source

pub fn intrinsicContentSize(&self) -> CGSize

Source

pub fn invalidateIntrinsicContentSize(&self)

Source

pub fn systemLayoutSizeFittingSize(&self, target_size: CGSize) -> CGSize

Source

pub fn layoutGuides(&self) -> Retained<NSArray<UILayoutGuide>>

Source

pub fn addLayoutGuide(&self, layout_guide: &UILayoutGuide)

Source

pub fn removeLayoutGuide(&self, layout_guide: &UILayoutGuide)

Source

pub fn hasAmbiguousLayout(&self) -> bool

Source

pub fn exerciseAmbiguityInLayout(&self)

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 snapshotViewAfterScreenUpdates( &self, after_updates: bool, ) -> Option<Retained<UIView>>

Source

pub fn resizableSnapshotViewFromRect_afterScreenUpdates_withCapInsets( &self, rect: CGRect, after_updates: bool, cap_insets: UIEdgeInsets, ) -> Option<Retained<UIView>>

Source

pub fn drawViewHierarchyInRect_afterScreenUpdates( &self, rect: CGRect, after_updates: bool, ) -> bool

Source

pub fn appliedContentSizeCategoryLimitsDescription(&self) -> Retained<NSString>

Will return a string with a log of all the superviews of this view, alongside with what content size category each view has and if that view has limits applied. This is for debugging purposes only.

Source

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

Source

pub fn updateTraitsIfNeeded(&self)

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

Source

pub fn effectiveRadiusForCorner(&self, corner: UIRectCorner) -> f64

Returns the effective radius for the given corner, calculated using the view’s current cornerConfiguration.

When invoked within UIView.layoutSubviews(), UIView.updateProperties(), or UIViewController.updateProperties() automatic invalidation will occur if the effective radius changes. If more than one corner is provided, the returned radius represents the maximum effective radius of those corners.

  • Parameter corner: The corner.
  • Returns: The effective radius.

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 inputView(&self) -> Option<Retained<UIView>>

Source

pub fn inputAccessoryView(&self) -> Option<Retained<UIView>>

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 TVCaptionButtonView

Source§

fn as_ref(&self) -> &AnyObject

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

impl AsRef<NSObject> for TVCaptionButtonView

Source§

fn as_ref(&self) -> &NSObject

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

impl AsRef<TVCaptionButtonView> for TVCaptionButtonView

Source§

fn as_ref(&self) -> &Self

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

impl AsRef<TVLockupView> for TVCaptionButtonView

Source§

fn as_ref(&self) -> &TVLockupView

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

impl AsRef<UIControl> for TVCaptionButtonView

Source§

fn as_ref(&self) -> &UIControl

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

impl AsRef<UIResponder> for TVCaptionButtonView

Source§

fn as_ref(&self) -> &UIResponder

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

impl AsRef<UIView> for TVCaptionButtonView

Source§

fn as_ref(&self) -> &UIView

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

impl Borrow<AnyObject> for TVCaptionButtonView

Source§

fn borrow(&self) -> &AnyObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<NSObject> for TVCaptionButtonView

Source§

fn borrow(&self) -> &NSObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<TVLockupView> for TVCaptionButtonView

Source§

fn borrow(&self) -> &TVLockupView

Immutably borrows from an owned value. Read more
Source§

impl Borrow<UIControl> for TVCaptionButtonView

Source§

fn borrow(&self) -> &UIControl

Immutably borrows from an owned value. Read more
Source§

impl Borrow<UIResponder> for TVCaptionButtonView

Source§

fn borrow(&self) -> &UIResponder

Immutably borrows from an owned value. Read more
Source§

impl Borrow<UIView> for TVCaptionButtonView

Source§

fn borrow(&self) -> &UIView

Immutably borrows from an owned value. Read more
Source§

impl CALayerDelegate for TVCaptionButtonView

Source§

fn displayLayer(&self, layer: &CALayer)
where Self: Sized + Message,

Source§

fn layerWillDraw(&self, layer: &CALayer)
where Self: Sized + Message,

Source§

fn layoutSublayersOfLayer(&self, layer: &CALayer)
where Self: Sized + Message,

Source§

fn actionForLayer_forKey( &self, layer: &CALayer, event: &NSString, ) -> Option<Retained<ProtocolObject<dyn CAAction>>>
where Self: Sized + Message,

Source§

impl ClassType for TVCaptionButtonView

Source§

const NAME: &'static str = "TVCaptionButtonView"

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

type Super = TVLockupView

The superclass of this class. Read more
Source§

type ThreadKind = <<TVCaptionButtonView 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 TVCaptionButtonView

Source§

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

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

impl Deref for TVCaptionButtonView

Source§

type Target = TVLockupView

The resulting type after dereferencing.
Source§

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

Dereferences the value.
Source§

impl Hash for TVCaptionButtonView

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 TVCaptionButtonView

Source§

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

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

impl NSCoding for TVCaptionButtonView

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 TVCaptionButtonView

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 TVCaptionButtonView

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 TVCaptionButtonView

Source§

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

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

impl UIAppearance for TVCaptionButtonView

Source§

impl UICoordinateSpace for TVCaptionButtonView

Source§

fn convertPoint_toCoordinateSpace( &self, point: CGPoint, coordinate_space: &ProtocolObject<dyn UICoordinateSpace>, ) -> CGPoint
where Self: Sized + Message,

Source§

fn convertPoint_fromCoordinateSpace( &self, point: CGPoint, coordinate_space: &ProtocolObject<dyn UICoordinateSpace>, ) -> CGPoint
where Self: Sized + Message,

Source§

fn convertRect_toCoordinateSpace( &self, rect: CGRect, coordinate_space: &ProtocolObject<dyn UICoordinateSpace>, ) -> CGRect
where Self: Sized + Message,

Source§

fn convertRect_fromCoordinateSpace( &self, rect: CGRect, coordinate_space: &ProtocolObject<dyn UICoordinateSpace>, ) -> CGRect
where Self: Sized + Message,

Source§

fn bounds(&self) -> CGRect
where Self: Sized + Message,

Source§

impl UIDynamicItem for TVCaptionButtonView

Source§

fn center(&self) -> CGPoint
where Self: Sized + Message,

Source§

fn setCenter(&self, center: CGPoint)
where Self: Sized + Message,

Setter for center.
Source§

fn bounds(&self) -> CGRect
where Self: Sized + Message,

Source§

fn transform(&self) -> CGAffineTransform
where Self: Sized + Message,

Source§

fn setTransform(&self, transform: CGAffineTransform)
where Self: Sized + Message,

Setter for transform.
Source§

fn collisionBoundsType(&self) -> UIDynamicItemCollisionBoundsType
where Self: Sized + Message,

The collision type represents how the dynamics system will evaluate collisions with respect to the dynamic item. defaults to UIDynamicItemCollisionBoundsTypeRectangle
Source§

impl UIFocusEnvironment for TVCaptionButtonView

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 preferredFocusedView(&self) -> Option<Retained<UIView>>
where Self: Sized + Message,

👎Deprecated
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 UIFocusItem for TVCaptionButtonView

Source§

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

Indicates whether or not this item is currently allowed to become focused. Returning NO restricts the item from being focusable, even if it is visible in the user interface. For example, UIControls return NO if they are disabled.
Source§

fn frame(&self) -> CGRect
where Self: Sized + Message,

The geometric frame of this item, represented in the coordinateSpace of the UIFocusItemContainer in which it is contained.
Source§

fn focusGroupPriority(&self) -> isize
where Self: Sized + Message,

The priority this item has in its focus group. The higher the priority, the more likely it is to get picked when focus moves into this group. Note: this method can only be used to increase an item’s priority, not decrease it. For example if an item is currently selected, the actual priority of this item will be determined by MAX(focusGroupPriority, UIFocusGroupPrioritySelected).
Source§

fn focusItemDeferralMode(&self) -> UIFocusItemDeferralMode
where Self: Sized + Message,

If this property is present and returns UIFocusItemDeferralModeNever, the focus deferral will not be enabled again after the user engagement timeout has expired if this item is currently focused and programmatic focus updates pointing to this item will be executed immediatly. If it returns UIFocusItemDeferralModeAlways focus will always be deferred when this item is supposed to be focused. Does nothing when focus deferral is not supported on the platform.
Source§

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

If this returns YES, the focus item is considered transparent in terms of occlusion. Items that are behind it are focusable. This value is ignored when the item is focusable, in which case the item is never considered transparent.
Source§

impl UIFocusItemContainer for TVCaptionButtonView

Source§

fn coordinateSpace(&self) -> Retained<ProtocolObject<dyn UICoordinateSpace>>
where Self: Sized + Message,

The coordinate space of the focus items contained in this container. The focus items returned by focusItemsInRect: should report their frames in this coordinate space. If you are implementing this protocol, you may find it convenient to return the UIScreen as your coordinate space, and ensure that your contained items report their frames in screen space. Similarly, you might find that your focus items’ containing UIView or UIWindow is the most convenient coordinate space to use. You may also choose to implement your own object that conforms to UICoordinateSpace, if that is the most natural solution for your architecture.
Source§

fn focusItemsInRect( &self, rect: CGRect, ) -> Retained<NSArray<ProtocolObject<dyn UIFocusItem>>>
where Self: Sized + Message,

Returns an array of all focus items within this container that intersect with the provided rect. rect is expressed in coordinateSpace. Note: starting in iOS & tvOS 16.0, UIView will return its subviews from this method. If you override this method in a UIView subclass, it will be your responsibility to call super and merge your array of custom focus items with UIView’s default focus items.
Source§

impl UIResponderStandardEditActions for TVCaptionButtonView

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 TVCaptionButtonView

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 TVCaptionButtonView

Source§

impl Eq for TVCaptionButtonView

Source§

impl UIAppearanceContainer for TVCaptionButtonView

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,