Ios UIActivityViewController在发送电子邮件或文本而不是fb或Twitter时冻结
我有一个非常标准的UIActivityViewController实现。当我使用Twitter或Facebook时,视图控制器被关闭,应用程序继续工作。但是,当我通过电子邮件或文本发送相同内容时,视图控制器将被解除,但应用程序将冻结(而不是崩溃)。所有内容仍在屏幕上,但已冻结-无输入等 也许邮件或消息应用程序尚未将控制权释放回我的应用程序?有没有办法用仪器来分析发生了什么 谢谢 我从NSArray那里得到了一条关于这部分的信息Ios UIActivityViewController在发送电子邮件或文本而不是fb或Twitter时冻结,ios,uiactivityviewcontroller,Ios,Uiactivityviewcontroller,我有一个非常标准的UIActivityViewController实现。当我使用Twitter或Facebook时,视图控制器被关闭,应用程序继续工作。但是,当我通过电子邮件或文本发送相同内容时,视图控制器将被解除,但应用程序将冻结(而不是崩溃)。所有内容仍在屏幕上,但已冻结-无输入等 也许邮件或消息应用程序尚未将控制权释放回我的应用程序?有没有办法用仪器来分析发生了什么 谢谢 我从NSArray那里得到了一条关于这部分的信息 - (void)postToFacebook:(UITapGestu
- (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];
}
是的,有一种方法,就像你提到的,使用仪器。但是如果我要预告你的结果,我会说你可能想在非UI线程上进行网络调用,在后台的某个地方,这样你的UI线程就可以在你的应用程序与Twitter或Facebook对话时完成任务。当我同时使用多个
UIWindow
对象时,这个问题也发生在我身上
解除UIActivityViewController
后,将无法正确恢复显示的windows内容。具体来说,窗口的第一个子视图(uilayoutcainerview
)缺少对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
}
}
您是否有机会从辅助UI窗口演示UIActivityViewController?在这种情况下,我遇到了类似的问题,并找到了解决方案。太棒了!!!我在keyWindow/lastWindow上有一个警报的全局覆盖,不知道如何消除它,因为它总是留下一个UIRemoteKeyboardWindow,或者后面的TransitionView将留在后台无法访问,因此我无法为警报设置整个设备窗口!!非常感谢你!!