ios - UIActivityViewController completionWithItemsHandler 函数未在 MacOS 应用程序中调用

标签 ios swift macos uiactivityviewcontroller mac-catalyst

背景

下面代码中的函数 shareImage() 启动 UIActivityViewController 并共享图像,例如发送到消息或保存到照片。

图片分享后,UIActivityViewController结束,调用completionWithItemsHandler函数activityComplete()

代码在 iOS/iPadOS/MacOS 上运行良好,如预期的那样并共享图像,除了在 MacOS 上,completionWithItemsHandler 函数 activityComplete() 从不被调用,使用标志 print("Share complete.") 确认。

Xcode 改为记录以下输出: 场景销毁请求失败,出现错误:(null)


问题

是什么导致了阻止 completionWithItemsHandler 函数 activityComplete() 在 MacOS 上被调用的问题,如何在代码中更正这个问题?


代码

注意:更新后根据答案添加了两行。

import UIKit

class ViewController: UIViewController {

    var shareButton = UIButton(type: UIButton.ButtonType.custom)
    var activityImage: UIImage!

    override func viewDidLoad() {
        super.viewDidLoad()
        
        // Create share button
        shareButton.setTitle("Share", for:UIControl.State())
        shareButton.setTitleColor(.white, for: UIControl.State())
        shareButton.backgroundColor = .purple
        shareButton.frame = CGRect(x: 50, y: 100, width: 200, height: 200)
        shareButton.addTarget(self, action: #selector(ViewController.shareImage), for:.touchUpInside)
        view.addSubview(shareButton)
    }


    private var activity: UIActivityViewController?  // <-- Added
    
    @objc func shareImage() {
        
        // Take view screenshot
        UIGraphicsBeginImageContextWithOptions(self.view.frame.size, false, 0)
        self.view.drawHierarchy(in: CGRect(x: 0, y: 0, width: self.view.bounds.width, height: self.view.bounds.height), afterScreenUpdates: false)
        activityImage = UIGraphicsGetImageFromCurrentImageContext()
        UIGraphicsEndImageContext()
        
        // Share view screenshot
        let activity = UIActivityViewController(activityItems: [activityImage as Any], applicationActivities: nil)
        
        // Present iPhone share options
        if UIDevice.current.userInterfaceIdiom == .phone {
            self.present(activity, animated: true, completion: nil)
        }
        
        // Present iPad share options
        if UIDevice.current.userInterfaceIdiom == .pad {
            self.present(activity, animated: true, completion: nil)
            if let popOver = activity.popoverPresentationController {
                popOver.sourceView = self.shareButton
            }
        }
        
        // Complete share
        activity.completionWithItemsHandler = {activity, success, items, error in
            self.activityComplete()
        }

        self.activity = activity  // <-- Added

    }
    
    func activityComplete() {
        
        print("Share complete.")
    }
}

最佳答案

尝试在呈现后保留您的事件 View Controller 。 像这样的东西:

    private var activityViewController: UIActivityViewController?

    @objc func presentActivityViewController(activityItems: [Any]) {
        let activityViewController = UIActivityViewController(activityItems: activityItems, applicationActivities: nil)
        self.present(activityViewController, animated: true, completion: nil)
        activityViewController.completionWithItemsHandler = { activity, success, items, error in
            // some logic
        }
        self.activityViewController = activityViewController // <- retaining activityViewController
    }

关于ios - UIActivityViewController completionWithItemsHandler 函数未在 MacOS 应用程序中调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69367599/

相关文章:

ios - AVCaptureVideoPreviewLayer 在 iOS 中添加覆盖和捕获照片

ios - 收到新消息时如何平滑更新聊天 View

java - 无法在我的 MacBook 中使用 Firefox 浏览器打开网页

ios - 创建一个外部网络服务并在 viewdidload 中调用它

ios - 使 UILabel 约束显示全宽

iphone - 将通用应用程序作为缩放的 iPhone 应用程序运行?

macos - 如何允许 Delphi XE2 从运行 Windows 7 的 VirtualBox VM 中查看 Mac 上的共享文件夹

ios - 为什么我的 UILabel 没有在 queryPedometerDataFromDate 内更改?

ios - UIViewController 连续关闭调用

macos - Flyway - MacOs 中的 libjvm.dylib 问题