2013-04-14 4 views
9

Я пытаюсь использовать новый UIActivityViewController для замены всех моих таблиц UIActionSheets для совместного использования, однако я столкнулся с проблемой.UIActivityViewController - присоединяйте только URL для определенных действий.

У меня есть 5 мероприятий, сообщений, электронной почты, копий, Twitter и Facebook. Я уже понял, как у тех, показать другой текст, через это в пользовательских UIActivityProvider подкласса:

- (id) activityViewController:(UIActivityViewController *)activityViewController 
     itemForActivityType:(NSString *)activityType 
{ 
    if ([activityType isEqualToString:UIActivityTypePostToTwitter]) 
     return twitter; 
    if ([activityType isEqualToString:UIActivityTypePostToFacebook]) 
     return facebook; 
    if ([activityType isEqualToString:UIActivityTypeMessage]) 
     return urlScheme; 
    if ([activityType isEqualToString:UIActivityTypeMail]) 
     return urlScheme; 
    if ([activityType isEqualToString:UIActivityTypeCopyToPasteboard]) 
     return urlScheme; 
    return nil; 
} 

И это, на мой взгляд контроллер:

ActivityProvider *aProvider = [[ActivityProvider alloc] init]; 
    aProvider.facebook = facebook; 
    aProvider.twitter = twitter; 
    aProvider.urlScheme = URL; 

    NSArray *Items = @[aProvider, sharedURL]; 

    UIActivityViewController *activityVC = [[UIActivityViewController alloc]initWithActivityItems:Items applicationActivities:Nil]; 
    activityVC.excludedActivityTypes = @[UIActivityTypePrint, UIActivityTypeAssignToContact,UIActivityTypeSaveToCameraRoll, UIActivityTypePostToWeibo]; 


    [self presentViewController:activityVC animated:TRUE completion:nil]; 

Однако, я только хочу, чтобы показать URL (sharedURL) в общих листингах Facebook и Twitter, а не в сообщении, электронной почте или копии. Любой способ это сделать?

ответ

15

Вы можете выбрать, что отправить в каждый вид деятельности. Я создал пользовательского поставщика активности и назвать его так:

 NSMutableArray *activityItems = [NSMutableArray array]; 

    CustomActivityItemProvider *activityItemProvider = 
    [[CustomActivityItemProvider alloc] initWithText:text 
                urlText:urlString]; 

    [activityItems addObject:activityItemProvider]; 


    //you can have your own custom activities too: 
    NSArray *applicationActivities = @[[CustomActivity new], 
               [OtherCustomActivity new]]; 
    UIActivityViewController *vc = [[UIActivityViewController alloc]initWithActivityItems:activityItems 
                    applicationActivities:applicationActivities]; 

Обычай поставщик является подклассом UIActivityItemProvider

@interface CustomActivityItemProvider : UIActivityItemProvider 

- (id)initWithText:(NSString *)text urlText:(NSString *)url; 

@end 

Внутренности моего пользовательского поставщика класса выглядеть примерно так:

- (id)initWithText:(NSString *)text urlText:(NSString *)url{ 

    if ((self = [super initWithPlaceholderItem:text])) {  
     self.text = text ?: @""; 
     self.url = url ?: @""; 
    } 
    return self; 
} 

- (id)item { 
    NSString *activityType = self.activityType; 
    if ([self.placeholderItem isKindOfClass:[NSString class]]) {    
     if ([self.activityType isEqualToString:UIActivityTypePostToFacebook] || 
      [self.activityType isEqualToString:UIActivityTypeMail]) { 

      return [NSString stringWithFormat:@"%@\n%@", self.text, self.url]; 

     } else if ([activityType isEqualToString:UIActivityTypePostToTwitter]) { 

      return [self findBestStringOfLength:kTwitterMessageLength hashTags:YES]; 

     } else if ([activityType isEqualToString:UIActivityTypeMessage]) { 

      return [self findBestStringOfLength:kSMSMessageLength hashTags:YES]; 

     } else { 
      return self.text; 
     } 
    } 

    return self.placeholderItem; 
} 
0

Вы должны быть в состоянии сделать это, внедряя свой собственный UIActivityItemProvider, и возвращая нуль для любого вида деятельности, где вы не хотите использовать эти данные.

Смежные вопросы