KMBrowserWindowController+Actions.swift 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337
  1. //
  2. // KMBrowserWindowController+Actions.swift
  3. // PDF Reader Pro
  4. //
  5. // Created by tangchao on 2024/2/20.
  6. //
  7. import Foundation
  8. // MARK: - Actions
  9. @objc extension KMBrowserWindowController {
  10. }
  11. // MARK: - 幻灯片
  12. extension KMBrowserWindowController {
  13. func canEnterFullscreen() -> Bool {
  14. if self.isSwitchingFullScreen {
  15. return false
  16. }
  17. // if useNativeFullScreen() {
  18. // return interactionMode == .SKNormalMode || interactionMode == .SKPresentationMode
  19. // } else {
  20. if let mainVc = (self.document as? KMMainDocument)?.mainViewController {
  21. if mainVc.canEnterFullscreen() == false {
  22. return false
  23. }
  24. }
  25. let mode = self.interactionMode
  26. if mode == .fullScreen || mode == .legacyFullScreen {
  27. return false
  28. }
  29. let cnt = self.window?.tabbedWindows?.count ?? 0
  30. return cnt < 2
  31. }
  32. override func canEnterPresentation() -> Bool {
  33. let can = super.canEnterPresentation()
  34. if can == false {
  35. return false
  36. }
  37. if let mainVc = (self.document as? KMMainDocument)?.mainViewController {
  38. if mainVc.canEnterPresentation() == false {
  39. return false
  40. }
  41. }
  42. return can
  43. }
  44. func canExitFullscreen() -> Bool {
  45. if self.isSwitchingFullScreen == false {
  46. return false
  47. }
  48. let mode = self.interactionMode
  49. if mode == .fullScreen || mode == .legacyFullScreen {
  50. return true
  51. }
  52. return false
  53. }
  54. // 进入幻灯片
  55. func enterPresentation() {
  56. if self.canEnterPresentation() == false {
  57. NSSound.beep()
  58. return
  59. }
  60. let wasInteractionMode = self.interactionMode
  61. if wasInteractionMode == .fullScreen
  62. { // 是全屏模式,直接退出全屏模式
  63. self.window?.wantsPresentation = true
  64. self.window?.toggleFullScreen(nil)
  65. return
  66. }
  67. let backgroundColor = NSColor.black
  68. let level = UserDefaults.standard.bool(forKey: "SKUseNormalLevelForPresentationKey") ? NSWindow.Level.normal : NSWindow.Level.popUpMenu
  69. // let page = self.listView.currentPage()
  70. if wasInteractionMode == .normal {
  71. // savedNormalSetup.setDictionary(self.currentPDFSettings() as! [AnyHashable : Any])
  72. }
  73. // 设置切换中标识
  74. self.window?.isSwitchingFullScreen = true
  75. // if findController.view().window() != nil {
  76. // findController.toggleAboveView(nil, animate: false)
  77. // }
  78. // 设置模式标识
  79. self.window?.interactionMode = .presentation
  80. let mainVc = (self.document as? KMMainDocument)?.mainViewController
  81. if wasInteractionMode == .legacyFullScreen {
  82. mainVc?.enterPresentationMode()
  83. //// updatePresentationOptions(for: self.view.window!)
  84. //
  85. // pdfSplitView.frame = CGRect(x: 0, y: 0, width: CGRectGetWidth(centerContentView.bounds), height: CGRectGetHeight(centerContentView.bounds)-1)
  86. // centerContentView.addSubview(pdfSplitView)
  87. // listView.frame = (self.view.window?.contentView?.bounds)!
  88. // self.view.window?.contentView?.addSubview(listView)
  89. //
  90. // self.view.window?.backgroundColor = backgroundColor
  91. // self.view.window?.level = level
  92. // listView.layoutDocumentView()
  93. // listView.requiresDisplay()
  94. //
  95. // self.forceSubwindowsOnTop(false)
  96. //
  97. // self.hideLeftSideWindow()
  98. // self.hideRightSideWindow()
  99. // self.removeBlankingWindows()
  100. } else {
  101. self.window?.fadeInFullScreenWindow(with: backgroundColor, level: level.rawValue)
  102. mainVc?.enterPresentationMode()
  103. // mainVc?.fadeInFullScreenView(mainVc!.listView, inset: 0)
  104. self.window?.fadeInFullScreenView(fullScreenWindow: self.window as! KMFullScreenWindow, with: mainVc!.listView, inset: 0)
  105. mainVc?.listView.layoutDocumentView()
  106. mainVc?.listView.requiresDisplay()
  107. }
  108. // if _isShowToolbar {
  109. // self.toolbarViewController.hiddenToolbar(true)
  110. // }
  111. //
  112. // if self.pdfView().currentPage()?.isEqual(page) == false {
  113. // self.pdfView().go(to: page)
  114. // }
  115. //
  116. // 恢复切换全屏标识
  117. self.window?.isSwitchingFullScreen = false
  118. //
  119. // pdfView().setInteractionMode(SKPresentationMode)
  120. }
  121. func exitFullscreen() {
  122. let wasInteractionMode = self.interactionMode
  123. if self.canExitFullscreen() == false && self.canExitPresentation() == false {
  124. return
  125. }
  126. if wasInteractionMode == .fullScreen {
  127. self.window?.toggleFullScreen(nil)
  128. return
  129. }
  130. // let backgroundColor = UserDefaults.standard.color(forKey: "SKBackgroundColorKey")
  131. var view: NSView?
  132. var contentView: NSView?
  133. // PDFPage *page = [[self pdfView] currentPage];
  134. //
  135. self.window?.isSwitchingFullScreen = true
  136. //
  137. // if ([[findController view] window])
  138. // [findController toggleAboveView:nil animate:NO];
  139. //
  140. if wasInteractionMode == .legacyFullScreen {
  141. let doc = self.document as? KMMainDocument
  142. view = doc?.mainViewController?.pdfSplitView
  143. contentView = doc?.mainViewController?.centerContentView
  144. } else {
  145. let doc = self.document as? KMMainDocument
  146. view = doc?.mainViewController?.listView
  147. contentView = doc?.mainViewController?.readContentView
  148. }
  149. self.hideLeftSideWindow()
  150. self.hideRightSideWindow()
  151. // do this first, otherwise the navigation window may be covered by fadeWindow and then reveiled again, which looks odd
  152. // [pdfView setInteractionMode:SKNormalMode];
  153. //
  154. // this should be done before exitPresentationMode to get a smooth transition
  155. if let v = view {
  156. self.fadeOutFullScreenView(v)
  157. view?.frame = contentView?.bounds ?? .zero
  158. contentView?.addSubview(v)
  159. v.mas_makeConstraints { make in
  160. make?.left.mas_equalTo()(0)
  161. make?.right.mas_equalTo()(0)
  162. make?.top.mas_equalTo()(0)
  163. make?.bottom.mas_equalTo()(0)
  164. }
  165. (v as? CPDFListView)?.layoutDocumentView()
  166. (v as? CPDFListView)?.requiresDisplay()
  167. }
  168. if let mainVc = (self.document as? KMMainDocument)?.mainViewController {
  169. mainVc.exitFullscreenMode()
  170. }
  171. // [self applyPDFSettings:savedNormalSetup];
  172. // [savedNormalSetup removeAllObjects];
  173. //
  174. // [pdfView layoutDocumentView];
  175. // [pdfView requiresDisplay];
  176. //
  177. // if ([[[self pdfView] currentPage] isEqual:page] == NO)
  178. // [[self pdfView] goToPage:page];
  179. //
  180. self.window?.isSwitchingFullScreen = false
  181. self.forceSubwindowsOnTop(false)
  182. //
  183. self.window?.interactionMode = .normal
  184. // if (_isShowToolbar) {
  185. // [self.toolbarViewController hiddenToolbar:NO];
  186. // }
  187. self.fadeOutFullScreenWindow()
  188. // the page number may have changed
  189. self.synchronizeWindowTitleWithDocumentName()
  190. self.removeBlankingWindows()
  191. }
  192. func hideLeftSideWindow() {
  193. // if leftSideViewController.view.window == leftSideWindow {
  194. // self.leftView.remove()
  195. // if leftSideWindow.firstResponder()?.isDescendant(of: leftSideController.view()) {
  196. // leftSideWindow.makeFirstResponder(nil)
  197. // }
  198. // leftSideController.view().setFrame(SKShrinkRect(NSInsetRect(leftSideContentView.bounds, -1.0, -1.0), 1.0, .maxYEdge))
  199. // leftSideContentView.addSubview(leftSideController.view())
  200. //
  201. // if self.interactionMode() == SKPresentationMode {
  202. // self.setLeftSidePaneState(mwcFlags.savedLeftSidePaneState)
  203. // }
  204. //
  205. // leftSideWindow = nil
  206. // }
  207. }
  208. func hideRightSideWindow() {
  209. // if rightSideController.view().window() == rightSideWindow {
  210. // rightSideWindow.remove()
  211. // if rightSideWindow.firstResponder()?.isDescendant(of: rightSideController.view()) {
  212. // rightSideWindow.makeFirstResponder(nil)
  213. // }
  214. // rightSideController.view().setFrame(SKShrinkRect(NSInsetRect(rightSideContentView.bounds, -1.0, -1.0), 1.0, .maxYEdge))
  215. // rightSideContentView.addSubview(rightSideController.view())
  216. //
  217. // rightSideWindow = nil
  218. // }
  219. }
  220. func removeBlankingWindows() {
  221. // [blankingWindows makeObjectsPerformSelector:@selector(fadeOut)];
  222. // blankingWindows = nil;
  223. }
  224. // func fadeInFullScreenWindow(with backgroundColor: NSColor, level: Int) {
  225. // self._mainWindow = self.view.window
  226. // let fullScreenWindow = KMFullScreenWindow(screen: (self.mainWindow?.screen ?? NSScreen.main)!, bgColor: backgroundColor, level: NSWindow.Level.popUpMenu.rawValue, isMain: true)
  227. //
  228. // self.mainWindow?.delegate = nil
  229. // fullScreenWindow.fadeInBlocking()
  230. // self.browserWindowController?.window = fullScreenWindow
  231. // fullScreenWindow.makeKey()
  232. //
  233. //// NSApp.updatePresentationOptions(for: fullScreenWindow)
  234. //
  235. // let sel = NSSelectorFromString("setAnimationBehavior:")
  236. // if self.mainWindow?.responds(to: sel) ?? false{
  237. // self.mainWindow?.animationBehavior = .none
  238. // }
  239. // self.mainWindow?.orderOut(nil)
  240. // if self.mainWindow?.responds(to: sel) ?? false{
  241. // self.mainWindow?.animationBehavior = .default
  242. // }
  243. // fullScreenWindow.level = NSWindow.Level(rawValue: level)
  244. // fullScreenWindow.orderFront(nil)
  245. //// NSApp.addWindowsItem(fullScreenWindow, title: windowTitleForDocumentDisplayName(self.document?.displayName) ?? "", filename: false)
  246. // }
  247. func fadeOutFullScreenView(_ view: NSView) {
  248. guard let fullScreenWindow = self.window as? KMFullScreenWindow else {
  249. NSSound.beep()
  250. return
  251. }
  252. let fadeWindow = KMFullScreenWindow(screen: fullScreenWindow.screen ?? NSScreen.main!, bgColor: fullScreenWindow.backgroundColor, level: fullScreenWindow.level.rawValue, isMain: false)
  253. fadeWindow.alphaValue = 0
  254. fadeWindow.order(.above, relativeTo: fullScreenWindow.windowNumber)
  255. fadeWindow.fadeInBlocking()
  256. view.removeFromSuperview()
  257. fullScreenWindow.display()
  258. fullScreenWindow.delegate = nil
  259. fullScreenWindow.makeFirstResponder(nil)
  260. fadeWindow.orderOut(nil)
  261. }
  262. func fadeOutFullScreenWindow() {
  263. guard let fullScreenWindow = self.window as? KMFullScreenWindow else {
  264. NSSound.beep()
  265. return
  266. }
  267. let mainVc = (self.document as? KMMainDocument)?.mainViewController
  268. // let mainWindow = mainVc?.mainWindow
  269. let mainWindow = fullScreenWindow.interactionParent
  270. let collectionBehavior = mainWindow?.collectionBehavior
  271. self.window = mainWindow
  272. mainWindow?.alphaValue = 0
  273. if let data = mainWindow?.responds(to: NSSelectorFromString("setAnimationBehavior:")), data {
  274. mainWindow?.animationBehavior = .none
  275. }
  276. // trick to make sure the main window shows up in the same space as the fullscreen window
  277. fullScreenWindow.addChildWindow(mainWindow!, ordered: .below)
  278. fullScreenWindow.removeChildWindow(mainWindow!)
  279. fullScreenWindow.level = .popUpMenu
  280. // these can change due to the child window trick
  281. mainWindow?.level = .normal
  282. mainWindow?.alphaValue = 1.0
  283. mainWindow?.collectionBehavior = collectionBehavior!
  284. mainWindow?.display()
  285. mainWindow?.makeFirstResponder(mainVc?.listView)
  286. mainWindow?.recalculateKeyViewLoop()
  287. mainWindow?.delegate = self
  288. mainWindow?.makeKey()
  289. // [NSApp updatePresentationOptionsForWindow:mainWindow];
  290. if let data = mainWindow?.responds(to: NSSelectorFromString("setAnimationBehavior:")), data {
  291. mainWindow?.animationBehavior = .default
  292. }
  293. NSApp.removeWindowsItem(fullScreenWindow)
  294. fullScreenWindow.fadeOut()
  295. }
  296. }