UIActivityViewController在电子邮件或文本时冻结,但不冻结fb或Twitter

时间:2013-06-04 03:36:07

标签: ios uiactivityviewcontroller

我有一个非常标准的UIActivityViewController实现。当我使用Twitter或Facebook时,视图控制器被解雇,应用程序继续工作。但是,当我通过电子邮件发送或发送相同内容时,视图控制器将被解除,但应用程序会冻结(而不是崩溃)。一切仍然在屏幕上但冻结 - 没有输入等。

也许邮件或邮件应用程序尚未将控制权发布回我的应用程序?有没有办法使用Instruments来分析发生了什么?

谢谢!

我从NSArray那里得到了这个部分作为罪犯的泄密

- (void)postToFacebook:(UITapGestureRecognizer *)sender
{
    NSString *postText = @"Testing";
    UIImage *imageToPost = [self captureTheScreenImage];
    NSArray *postItems = @[postText, imageToPost];

    UIActivityViewController *activityPostVC = [[UIActivityViewController alloc]initWithActivityItems:postItems applicationActivities:nil];


    NSArray *excludedItems = @[UIActivityTypePostToWeibo,UIActivityTypePrint,UIActivityTypeCopyToPasteboard,UIActivityTypeAssignToContact,UIActivityTypeSaveToCameraRoll, UIActivityTypeMail, UIActivityTypeMessage];

    [activityPostVC setExcludedActivityTypes:excludedItems];

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

}

2 个答案:

答案 0 :(得分:0)

是的,有一种方法,就像你提到的那样,使用仪器。但是,如果我要预示你的结果,我会说你可能想在非UI线程上进行网络调用,在后台的某个地方,这样你的UI线程可以在你的应用与Twitter或Facebook对话时发挥作用。 / p>

答案 1 :(得分:0)

当同时使用多个UIWindow个对象时,我也遇到了这个问题。

解除UIActivityViewController后,呈现窗口内容无法正确恢复。具体来说,窗口的第一个子视图(UILayoutContainerView)缺少对superview的约束。这会导致窗口UILayoutContainerView的宽度为零,导致窗口显示为透明,并显示窗口下方的窗口但不允许用户交互。

修复可以是在当前窗口的顶部放置一个空的透明窗口,并从与该新窗口关联的空视图控制器中显示UIActivityViewController。当UIActivityViewController被解雇时,我们可以处理它所呈现的空窗口。

import Foundation

private var previousWindow: UIWindow?
private var activityViewControllerWindow: UIWindow?

extension UIViewController {

  fileprivate var isActivityViewControllerWindowPresented: Bool {
    return activityViewControllerWindow?.isKeyWindow ?? false
  }

  func presentActivityViewController(_ activityViewController: UIActivityViewController, animated: Bool = true, completion: (() -> Void)? = nil) {
    if isActivityViewControllerWindowPresented {
      return
    }

    let window = UIWindow(frame: view.window!.frame)
    previousWindow = UIApplication.shared.keyWindow
    activityViewControllerWindow = window
    window.rootViewController = UIViewController()
    window.makeKeyAndVisible()

    let activityCompletionClosure = activityViewController.completionWithItemsHandler
    activityViewController.completionWithItemsHandler = { [weak self] (activityType, completed, returnedItems, activityError) in
      self?.cleanUpActivityViewControllerWindow()
      activityCompletionClosure?(activityType, completed, returnedItems, activityError)
    }

    window.rootViewController?.present(activityViewController, animated: animated, completion: completion)
  }

  fileprivate func cleanUpActivityViewControllerWindow() {
    previousWindow?.makeKeyAndVisible()
    activityViewControllerWindow?.rootViewController = nil
    activityViewControllerWindow = nil
  }

}