ここでは共有拡張機能(share extension
)を使って、自分アプリへのシステム共有機能や拡張機能内でのホストアプリへのジャンプ機能、データ送信機能などを主に説明します。
1. 共有拡張機能を追加する
作成に成功するとフォルダーが生成されます
info.plist
拡張機能を有効にするためのルールがあり、ルールに一致すると、独自のアプリがシステム共有に表示されます。
NSExtensionActivationRule
: デフォルトは文字列「TRUEPREDICATE」で、拡張子が常に共有メニューに表示されることを意味します。運用環境では使用できません。タイプを辞書タイプに変更してから、次のフィールドを追加する必要があります。
NSExtensionActivationSupportsAttachmentsWithMaxCount
添付ファイルには、ファイル、画像、ムービーの 3 つのカテゴリが含まれます。単一選択または混合選択の合計数は、指定された量を超えません。
NSExtensionActivationSupportsAttachmentsWithMinCount
添付ファイルの最小制限は、上記のフィールドの最大数が設定されている場合に有効になります。デフォルトで少なくとも 1 つの添付ファイルが選択され、共有メニューに拡張機能アイコンが表示されます。
NSExtensionActivationSupportsImageWithMaxCount
画像の最大数は制限されており、単一選択も混合選択も指定された数を超えません。
NSExtensionActivationSupportsMovieWithMaxCount
ビデオの最大数は制限されており、単一選択も混合選択も指定された数を超えません。
NSExtensionActivationSupportsText
テキスト型、ブール型をサポートするかどうか。デフォルトではサポートされません。[メモ]共有など
NSExtensionActivationSupportsWebPageWithMaxCount
Web ページの最大制限。数値タイプです。Web ページの共有はデフォルトではサポートされていないため、値を自分で設定する必要があります。
NSExtensionActivationSupportsWebURLWithMaxCount
Web リンクの最大制限。数値タイプです。ハイパーリンクの共有はデフォルトではサポートされていないため、値を自分で設定する必要があります。
デフォルトの共有拡張クラス ShareViewController には、完全にカスタマイズできる独自のビューが付属していますが、ここでは説明しません。
2. 共有データを取得し、ホストアプリにジャンプします
dispatch_group_t group = dispatch_group_create();
NSExtensionItem *extensionItem = self.extensionContext.inputItems[0];
for (NSItemProvider *attachment in extensionItem.attachments) {
if ([attachment hasItemConformingToTypeIdentifier:(NSString *)kUTTypeImage]) {
dispatch_group_enter(group);
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
[attachment loadItemForTypeIdentifier:(NSString *)kUTTypeImage
options:nil
completionHandler:^(id<NSSecureCoding> _Nullable item, NSError * _Null_unspecified error) {
NSData *data = [[NSData alloc]initWithContentsOfURL:item];
dispatch_group_leave(group);
}];
});
}
if ([attachment hasItemConformingToTypeIdentifier:(NSString *)kUTTypeMovie]) {
dispatch_group_enter(group);
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
[attachment loadItemForTypeIdentifier:(NSString *)kUTTypeMovie
options:nil
completionHandler:^(id<NSSecureCoding> _Nullable item, NSError * _Null_unspecified error) {
NSData *data = [[NSData alloc]initWithContentsOfURL:item];
dispatch_group_leave(group);
}];
});
}
}
dispatch_group_notify(group, dispatch_get_main_queue(), ^{
UIResponder* responder =self;
responder = [responder nextResponder];
while((responder = [responder nextResponder]) !=nil) {
if([responder respondsToSelector:@selector(openURL:)] ==YES) {
//打开APP
//这里的asancloud是app的URL Schemes ,home是自己随便定义的,用于判断
[responder performSelector:@selector(openURL:) withObject:[NSURL URLWithString:[NSString stringWithFormat:@"custome://"]]];
//执行分享内容处理
[self.extensionContext completeRequestReturningItems:@[] completionHandler:NULL];
}
}
});
ホストアプリにジャンプした後、以下のメソッドでロジックを処理します
-(BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options;
3. データ送信(3種類あります。ここではNSUserDefaultsを紹介します)
まず、同じアプリ グループを構成する必要があります。このアプリ グループは group で始まる必要があります。
NSUserDefaults *de = [[NSUserDefaults alloc]initWithSuiteName:@"group.(跟上面app groups一致)"];
[de setObject:value forKey:@"key"];
ホストアプリがデータを取得する
NSUserDefaults *de = [[NSUserDefaults alloc]initWithSuiteName:@"group.(跟上面app groups一致)"];
id value = [de objectForKey:@"key"];
4. デバッグ
拡張機能は、実行する対応するホスト アプリを選択する必要がありますが、拡張機能は独立したプロセスです。デバッグ中に拡張機能が実行される場合、ホスト アプリのブレークポイントは実行されません。同様に、ホスト アプリが実行されると、ブレークポイントは拡張子の中にあるものは実行されません。