AppDelegate.swift 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. import Flutter
  2. import UIKit
  3. @main
  4. @objc class AppDelegate: FlutterAppDelegate {
  5. // 存储冷启动时的URL请求
  6. private var hasLaunched: Bool = false
  7. override func application(
  8. _ application: UIApplication,
  9. didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
  10. ) -> Bool {
  11. GeneratedPluginRegistrant.register(with: self)
  12. let controller = window?.rootViewController as! FlutterViewController
  13. FlutterMethodChannelManager.shared.setupMethodChannels(controller: controller)
  14. // 创建事件通道
  15. let keyboardEventChannel = FlutterEventChannel(name: "keyboard_ios_events",
  16. binaryMessenger: controller.binaryMessenger)
  17. // 设置事件处理器
  18. let keyboardStreamHandler = KeyboardStreamHandler()
  19. keyboardEventChannel.setStreamHandler(keyboardStreamHandler)
  20. // 开始监听键盘切换
  21. startMonitoringKeyboardChanges()
  22. // 延迟处理
  23. DispatchQueue.main.asyncAfter(deadline: .now() + 2.5) {
  24. self.hasLaunched = true
  25. }
  26. JPUSHService.setup(withOption: launchOptions, appKey: "e4c8b538fa1046eccce756de", channel: "appStore", apsForProduction: false)
  27. // JPUSHService.setup(withOption: )
  28. return super.application(application, didFinishLaunchingWithOptions: launchOptions)
  29. }
  30. override func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey : Any] = [:]) -> Bool {
  31. let path = url.path
  32. if let channel = FlutterMethodChannelManager.shared.keyboardChannel {
  33. if path == "/login" {
  34. if hasLaunched {
  35. channel.invokeMethod("navigateToLogin", arguments: nil)
  36. } else {
  37. // 延迟处理
  38. DispatchQueue.main.asyncAfter(deadline: .now() + 2.5) {
  39. channel.invokeMethod("navigateToLogin", arguments: nil)
  40. }
  41. }
  42. } else if path == "/member" {
  43. if hasLaunched {
  44. channel.invokeMethod("navigateToMember", arguments: nil)
  45. } else {
  46. // 延迟处理
  47. DispatchQueue.main.asyncAfter(deadline: .now() + 2.5) {
  48. channel.invokeMethod("navigateToMember", arguments: nil)
  49. }
  50. }
  51. } else if path == "/character/market" {
  52. if hasLaunched {
  53. channel.invokeMethod("navigateToCharacterMarket", arguments: nil)
  54. } else {
  55. // 延迟处理
  56. DispatchQueue.main.asyncAfter(deadline: .now() + 2.5) {
  57. channel.invokeMethod("navigateToCharacterMarket", arguments: nil)
  58. }
  59. }
  60. } else if path == "/intimacy" {
  61. if hasLaunched {
  62. channel.invokeMethod("navigateToIntimacy", arguments: nil)
  63. } else {
  64. // 延迟处理
  65. DispatchQueue.main.asyncAfter(deadline: .now() + 3.5) {
  66. channel.invokeMethod("navigateToIntimacy", arguments: nil)
  67. }
  68. }
  69. } else if path == "/character/custom" {
  70. if hasLaunched {
  71. channel.invokeMethod("navigateToCustomCharacter", arguments: nil)
  72. } else {
  73. // 延迟处理
  74. DispatchQueue.main.asyncAfter(deadline: .now() + 2.5) {
  75. channel.invokeMethod("navigateToCustomCharacter", arguments: nil)
  76. }
  77. }
  78. } else if path == "/open/setting" {
  79. channel.invokeMethod("openSystemSetting", arguments: nil)
  80. }
  81. }
  82. return true
  83. }
  84. func startMonitoringKeyboardChanges() {
  85. NotificationCenter.default.addObserver(self, selector: #selector(keyboardDidChange), name: UITextInputMode.currentInputModeDidChangeNotification, object: nil)
  86. }
  87. @objc func keyboardDidChange() {
  88. // 收到通知后延迟检测
  89. DispatchQueue.main.asyncAfter(deadline: .now() + 0.3) { [weak self] in
  90. if let isCustom = self?.isCustomKeybroad() {
  91. // 发送通知
  92. NotificationCenter.default.post(name: NSNotification.Name("KeyboardDidChange"), object: nil, userInfo: ["isCustomKeyboard": isCustom])
  93. }
  94. }
  95. }
  96. func isCustomKeybroad() -> Bool {
  97. let currentKeyboardName = (((UITextInputMode.activeInputModes as NSArray).filtered(using: NSPredicate(format: "isDisplayed = YES"))).last as? NSObject)?.value(forKey: "extendedDisplayName") as? String
  98. let infoDictionary = Bundle.main.infoDictionary!
  99. let appDisplayName = infoDictionary["CFBundleDisplayName"] as? String
  100. return currentKeyboardName == appDisplayName
  101. }
  102. }
  103. // 事件流处理器
  104. class KeyboardStreamHandler: NSObject, FlutterStreamHandler {
  105. private var eventSink: FlutterEventSink?
  106. override init() {
  107. super.init()
  108. // 注册通知
  109. NotificationCenter.default.addObserver(self, selector: #selector(keyboardDidChange(_:)), name: NSNotification.Name("KeyboardDidChange"), object: nil)
  110. }
  111. @objc func keyboardDidChange(_ notification: Notification) {
  112. if let userInfo = notification.userInfo,
  113. let isCustomKeyboard = userInfo["isCustomKeyboard"] as? Bool,
  114. let eventSink = eventSink {
  115. // 发送事件到Flutter
  116. eventSink(isCustomKeyboard)
  117. }
  118. }
  119. func onListen(withArguments arguments: Any?, eventSink events: @escaping FlutterEventSink) -> FlutterError? {
  120. eventSink = events
  121. return nil
  122. }
  123. func onCancel(withArguments arguments: Any?) -> FlutterError? {
  124. eventSink = nil
  125. return nil
  126. }
  127. deinit {
  128. NotificationCenter.default.removeObserver(self)
  129. }
  130. }