-
Notifications
You must be signed in to change notification settings - Fork 516
CarPlay iOS xcode14.0 beta2
Manuel de la Pena edited this page Jul 6, 2022
·
3 revisions
#CarPlay.framework https://github.com/xamarin/xamarin-macios/pull/15403
diff -ruN /Applications/Xcode_14.0.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/CarPlay.framework/Headers/CPPointOfInterest.h /Applications/Xcode_14.0.0-beta2.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/CarPlay.framework/Headers/CPPointOfInterest.h
--- /Applications/Xcode_14.0.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/CarPlay.framework/Headers/CPPointOfInterest.h 2022-05-31 14:52:39.000000000 -0400
+++ /Applications/Xcode_14.0.0-beta2.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/CarPlay.framework/Headers/CPPointOfInterest.h 2022-06-17 15:29:36.000000000 -0400
@@ -16,16 +16,17 @@
@interface CPPointOfInterest : NSObject <NSSecureCoding>
/**
- Initializes a point of interest to be used with @c CPPointOfInterestTemplate
+ Initializes a point of interest to be used with @c CPPointOfInterestTemplate .
@param location Location indicator use by map annotations.
- @param title Primary title for this point of interest
- @param subtitle Optional: Secondary title for this point of interest
- @param summary Optional: Summary text for this point of interest
- @param detailTitle Optional: Title to be used when POI detail card is visible
- @param detailSubtitle Optional: Subtitle to be used when POI detail card is visible
- @param detailSummary Optional: Summary text to be used when POI detail card is visible
- @param pinImage Optional: a custom map annotation image
+ @param title Primary title for this point of interest.
+ @param subtitle Optional: Secondary title for this point of interest.
+ @param summary Optional: Summary text for this point of interest.
+ @param detailTitle Optional: Title to be used when POI detail card is visible.
+ @param detailSubtitle Optional: Subtitle to be used when POI detail card is visible.
+ @param detailSummary Optional: Summary text to be used when POI detail card is visible.
+ @param pinImage Optional: a custom unselected map annotation image.
+ @param selectedPinImage Optional: a custom selected map annotation image.
@note When providing an image, your app should provide a @c UIImage that is display-ready. If necessary for the image, provide
light and dark styles by using an asset from your asset catalog, prepared with light and dark styles
@@ -33,6 +34,39 @@
both styles.
CPPointOfInterest instances appear on the Point of Interest map view as both selectable items in the table view overlay and as map annotations.
+
+ @discussion To properly size your pin images, your app should size them to the display scale of the car screen. See -[CPInterfaceController carTraitCollection].
+ */
+
+- (instancetype)initWithLocation:(MKMapItem *)location
+ title:(NSString *)title
+ subtitle:(nullable NSString *)subtitle
+ summary:(nullable NSString *)summary
+ detailTitle:(nullable NSString *)detailTitle
+ detailSubtitle:(nullable NSString *)detailSubtitle
+ detailSummary:(nullable NSString *)detailSummary
+ pinImage:(nullable UIImage *)pinImage
+ selectedPinImage:(nullable UIImage *)selectedPinImage NS_DESIGNATED_INITIALIZER API_AVAILABLE(ios(16.0));
+/**
+ Initializes a point of interest to be used with @c CPPointOfInterestTemplate.
+
+ @param location Location indicator use by map annotations.
+ @param title Primary title for this point of interest.
+ @param subtitle Optional: Secondary title for this point of interest.
+ @param summary Optional: Summary text for this point of interest.
+ @param detailTitle Optional: Title to be used when POI detail card is visible.
+ @param detailSubtitle Optional: Subtitle to be used when POI detail card is visible.
+ @param detailSummary Optional: Summary text to be used when POI detail card is visible.
+ @param pinImage Optional: a custom map annotation image.
+
+ @note When providing an image, your app should provide a @c UIImage that is display-ready. If necessary for the image, provide
+ light and dark styles by using an asset from your asset catalog, prepared with light and dark styles
+ or by using @c UIImageAsset to combine two @c UIImage instances into a single image with
+ both styles.
+
+ CPPointOfInterest instances appear on the Point of Interest map view as both selectable items in the table view overlay and as map annotations.
+
+ @discussion To properly size your pin images, your app should size them to the display scale of the car screen. See -[CPInterfaceController carTraitCollection].
*/
- (instancetype)initWithLocation:(MKMapItem *)location
title:(NSString *)title
@@ -41,56 +75,75 @@
detailTitle:(nullable NSString *)detailTitle
detailSubtitle:(nullable NSString *)detailSubtitle
detailSummary:(nullable NSString *)detailSummary
- pinImage:(nullable UIImage *)pinImage NS_DESIGNATED_INITIALIZER;
+ pinImage:(nullable UIImage *)pinImage;
+
+/**
+ If you provide a custom image for this point of interest, the unselected image must be this size. Any image larger than this size will be resized.
+*/
+@property (nonatomic, class, readonly) CGSize pinImageSize API_AVAILABLE(ios(16.0));
/**
- Location associated with this point of interest
+ If you provide a custom image for this point of interest, the selected image must be this size. Any image larger than this size will be resized.
+*/
+@property (nonatomic, class, readonly) CGSize selectedPinImageSize API_AVAILABLE(ios(16.0));
+
+/**
+ Location associated with this point of interest.
*/
@property (nonatomic, strong) MKMapItem *location;
/**
- Primary title for this point of interest
+ Primary title for this point of interest.
*/
@property (nonatomic, copy) NSString *title;
/**
- Subtitle for this point of interest
+ Subtitle for this point of interest.
*/
@property (nonatomic, copy, nullable) NSString *subtitle;
/**
- Summary text for this point of interest
+ Summary text for this point of interest.
*/
@property (nonatomic, copy, nullable) NSString *summary;
/**
- Title to be used when POI detail card is visible
+ Title to be used when POI detail card is visible.
- @note If not provided, the point of interest will fall back to displaying @c title
+ @note If not provided, the point of interest will fall back to displaying @c title.
*/
@property (nonatomic, copy, nullable) NSString *detailTitle;
/**
- Subtitle to be used when POI detail card is visible
+ Subtitle to be used when POI detail card is visible.
- @note If not provided, the point of interest will fall back to displaying @c subtitle
+ @note If not provided, the point of interest will fall back to displaying @c subtitle.
*/
@property (nonatomic, copy, nullable) NSString *detailSubtitle;
/**
Summary text to be used when POI detail card is visible.
- @note If not provided, the point of interest will fall back to displaying @c summary
+ @note If not provided, the point of interest will fall back to displaying @c summary.
*/
@property (nonatomic, copy, nullable) NSString *detailSummary;
/**
- Image used for map view annotations
+ Image used for map view unselected annotations.
+
+ @discussion To properly size your pin image, your app should size them to the display scale of the car screen. See -[CPInterfaceController carTraitCollection].
*/
@property (nonatomic, strong, nullable) UIImage *pinImage;
/**
-Point of Interest detail card buttons
+ Image used for map view selected annotation.
+
+ @discussion To properly size your pin image, your app should size them to the display scale of the car screen. See -[CPInterfaceController carTraitCollection].
+ */
+@property (nonatomic, strong, nullable) UIImage *selectedPinImage API_AVAILABLE(ios(16.0));
+
+/**
+Point of Interest detail card buttons.
*/
@property (nullable, nonatomic, strong) CPTextButton *primaryButton;
@property (nullable, nonatomic, strong) CPTextButton *secondaryButton;
diff -ruN /Applications/Xcode_14.0.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/CarPlay.framework/Headers/CPPointOfInterestTemplate.h /Applications/Xcode_14.0.0-beta2.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/CarPlay.framework/Headers/CPPointOfInterestTemplate.h
--- /Applications/Xcode_14.0.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/CarPlay.framework/Headers/CPPointOfInterestTemplate.h 2022-05-31 14:52:37.000000000 -0400
+++ /Applications/Xcode_14.0.0-beta2.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/CarPlay.framework/Headers/CPPointOfInterestTemplate.h 2022-06-17 15:29:35.000000000 -0400
@@ -8,6 +8,7 @@
#import <CarPlay/CPTemplate.h>
#import <CarPlay/CPPointOfInterest.h>
#import <MapKit/MKGeometry.h>
+#import <CarPlay/CPBarButtonProviding.h>
@class CPPointOfInterestTemplate;
@@ -32,7 +33,7 @@
@end
API_AVAILABLE(ios(14.0)) API_UNAVAILABLE(macos, watchos, tvos)
-@interface CPPointOfInterestTemplate : CPTemplate
+@interface CPPointOfInterestTemplate : CPTemplate <CPBarButtonProviding>
/**
CPPointOfInterestTemplate displays a map view with selectable points of interest.
- README
- xcode13.0 Binding Status
- xcode13.1 Binding Status
- xcode13.2 Binding Status
- xcode13.3 Binding Status
- xcode13.4 Binding Status
- xcode14.0 Binding Status
- xcode14.1 Binding Status
- xcode14.2 Binding Status
- xcode14.3 Binding Status
- xcode15.0 Binding Status
- xcode15.1 Binding Status
- xcode15.3 Binding Status
- xcode15.4 Binding Status
- xcode16.0 Binding Status
- xcode16.1 Binding Status
- xcode16.2 Binding Status