Accéder au contenu principal

[General] UIDocumentInteractionController not available

Lorsque l'on porte une application sur Mac Catalyst, il y a un problème avec les UIDocumentInteractionController... Les logs disent :

[General] UIDocumentInteractionController not available

Dans ce cas, là plusieurs cas de figure...

Cas 1 :

 On essaye juste de visualiser un fichier standard, par exemple un PDF... Dans ce cas on peut remplacer le document interactif par un simple open. Dans l'application IOS il faut laisser le document interactif car sinon on sort de l'application. Mais sur un Mac ce n'est pas grave.

-(IBAction)info:(UIButton*)sender {
    NSURL * url = [[NSBundle mainBundle] URLForResource:@"TaPytha" withExtension:@"pdf"];

#if TARGET_OS_MACCATALYST
    [[UIApplication sharedApplication] openURL:url options:@{} completionHandler:nil];
#else
    documentInteractionController = [UIDocumentInteractionController interactionControllerWithURL:url];
    assert(documentInteractionController);
    documentInteractionController.delegate = self;
    [documentInteractionController presentPreviewAnimated:YES];
#endif
}

Une autre solution serait de créer un contrôler avec une WKWebView et de lire l'URL à partir de la vue. Mais cela oblige à faire un contrôler jute pour cela. Sur Mac je n'en vois pas l'intérêt.

Cas 2 :

On veut exporter un fichier qui n'est utile que dans l'application. En clair une sauvegarde ou un export pour un autre appareil. Sous IOS c'est logique. On appelle UIDocumentInteractionViewController qui propose de copier le document dans les apps qui peuvent le recevoir.
En réalité, ce que l'on veut, sous Mac, c'est un "Sauver sous...". Un navigateur du système de fichier pour savoir où déposer le fichier. Et si possible un "Partager...".

    NSURL *url = [NSURL fileURLWithPath:path];

//    documentInteractionController = [UIDocumentInteractionController interactionControllerWithURL:url];
//    assert(documentInteractionController);
//    documentInteractionController.delegate = self;
//    [documentInteractionController presentOptionsMenuFromRect:selectedRect inView:self.view animated:YES];

    UIActivityViewController *activity = [[UIActivityViewController alloc]
                                          initWithActivityItems:@[ url ]
                                          applicationActivities:nil];
    activity.popoverPresentationController.sourceView = self.view;
    activity.popoverPresentationController.sourceRect = selectedRect;

    [self presentViewController:activity animated:YES completion:nil];

Dans ce cas, c'est presque plus simple. Pas besoin de code conditionnel, on peut utiliser UIActivityViewController à la place de UIDocumentInteractionViewController. C'est exactement le même résultat, sauf que UIActivityViewController fonctionne sur IOS et sur MacCatalyst.



Commentaires

Posts les plus consultés de ce blog

IOS14 et Bonjour qui ne fonctionne pas.

 J'utilise Bonjour dans certaines de mes application pour échanger des données entre appareils se trouvant sur le même réseau local.  Depuis IOS14, vous devez déclarer dans info.plist : <key> NSLocalNetworkUsageDescription </key> <string> L'accès au réseau local est obligatoire pour.... </string> <key> NSBonjourServices </key> <array> <string> _http._tcp </string> </array>  La clef NSLocalNetworkUsageDescription est obligatoire pour toute utilisation du réseau local (en dehors des produits Apple comme AirDrop, AirPrint, etc.). C'est la même chose que l'accès à la caméra ou au micro, vous devez dire pourquoi vous désirez cet accès dans votre application. La clef NSBonjourServices est spécifique pour le protocole Bonjour, elle contient la liste des services que vous partagez avec Bonjour. Dans l'exemple, il s'agit d'un serveur web (http).

UITableView avec multi-sélection sur Mac Catalyst

Si vous mettez à YES les attributs Multi Selection  et Multi Sélection During Editing d'un UITableView, cela ne fonctionnera pas comme attendu sur Mac. C'est juste énervant et voici ubout de code qui règle le problème. #if TARGET_OS_MACCATALYST -( NSIndexPath *) tableView :( UITableView *)tableView willSelectRowAtIndexPath :( NSIndexPath *)indexPath {     if ([tableView. indexPathsForSelectedRows containsObject :indexPath]) {         [tableView deselectRowAtIndexPath :indexPath animated : NO ];         return nil ;     }     return indexPath; } -( NSIndexPath *) tableView :( UITableView *)tableView willDeselectRowAtIndexPath :( NSIndexPath *)indexPath {     if ([tableView. indexPathsForSelectedRows containsObject :indexPath]) {         return nil ;     }     return indexPath; } -( BOOL ) tableView :( UITableView *)tableView shouldHighlightRowAtIndexPath :( NSIndexPath *)indexPath {     for ( NSIndexPath *ip in tableView. indexPathsForSelectedRows ) {         [tabl

Tiret insécable

 Ecrivant un livre sur CoreAnimation en Objective-C et en Swift, j'écris souvent "Objective-C".  Mais je ne souhaite pas que la césure du texte se face avec le C, il me faut donc un tiret insécable. Malheureusement il n'y a pas de tiret insécable sur le clavier du Mac, il faut donc utiliser le caractère Unicode U+2011. Mais le clavier du Mac ne comprends pas non plus par défaut de possibilité d'ajouter un caractère par son code Unicode.  Il faut donc aller dans les réglages d'Apple, dans les réglages du clavier, dans les méthodes de saisie et ajouter le clavier "Universel (Unicode Hex)". Ensuite, lorsque l'on a besoin d'un caractère Unicode, on change de clavier et on utilise la touche Option + le code en hexadécimal. Pour accélérer le changement d'un clavier à l'autre, toujours dans les réglages du clavier, vous pouvez activer les raccourcis clavier. Bon, c'était encore trop long, alors j'ai mis un remplacement automatique da