我有一个非常标准的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];
}
答案 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
}
}