remove usage of FullSizeContentView
This commit is contained in:
		
					parent
					
						
							
								a9709a635c
							
						
					
				
			
			
				commit
				
					
						28fc58067b
					
				
			
		
					 3 changed files with 58 additions and 31 deletions
				
			
		|  | @ -5,6 +5,7 @@ | ||||||
| #include "atom/browser/native_window_mac.h" | #include "atom/browser/native_window_mac.h" | ||||||
| 
 | 
 | ||||||
| #include <AvailabilityMacros.h> | #include <AvailabilityMacros.h> | ||||||
|  | #include <objc/objc-runtime.h> | ||||||
| 
 | 
 | ||||||
| #include <string> | #include <string> | ||||||
| 
 | 
 | ||||||
|  | @ -127,31 +128,6 @@ | ||||||
| 
 | 
 | ||||||
| @end | @end | ||||||
| 
 | 
 | ||||||
| // This view always takes the size of its superview. It is intended to be used |  | ||||||
| // as a NSWindow's contentView.  It is needed because NSWindow's implementation |  | ||||||
| // explicitly resizes the contentView at inopportune times. |  | ||||||
| @interface FullSizeContentView : NSView |  | ||||||
| @end |  | ||||||
| 
 |  | ||||||
| @implementation FullSizeContentView |  | ||||||
| 
 |  | ||||||
| // This method is directly called by NSWindow during a window resize on OSX |  | ||||||
| // 10.10.0, beta 2. We must override it to prevent the content view from |  | ||||||
| // shrinking. |  | ||||||
| - (void)setFrameSize:(NSSize)size { |  | ||||||
|   if ([self superview]) |  | ||||||
|     size = [[self superview] bounds].size; |  | ||||||
|   [super setFrameSize:size]; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // The contentView gets moved around during certain full-screen operations. |  | ||||||
| // This is less than ideal, and should eventually be removed. |  | ||||||
| - (void)viewDidMoveToSuperview { |  | ||||||
|   [self setFrame:[[self superview] bounds]]; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| @end |  | ||||||
| 
 |  | ||||||
| #if !defined(AVAILABLE_MAC_OS_X_VERSION_10_12_AND_LATER) | #if !defined(AVAILABLE_MAC_OS_X_VERSION_10_12_AND_LATER) | ||||||
| 
 | 
 | ||||||
| enum { NSWindowTabbingModeDisallowed = 2 }; | enum { NSWindowTabbingModeDisallowed = 2 }; | ||||||
|  | @ -234,6 +210,48 @@ struct Converter<atom::NativeWindowMac::TitleBarStyle> { | ||||||
| 
 | 
 | ||||||
| namespace atom { | namespace atom { | ||||||
| 
 | 
 | ||||||
|  | namespace { | ||||||
|  | 
 | ||||||
|  | bool IsFramelessWindow(NSView* view) { | ||||||
|  |   NativeWindow* window = [static_cast<AtomNSWindow*>([view window]) shell]; | ||||||
|  |   return window && !window->has_frame(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | IMP original_set_frame_size = nullptr; | ||||||
|  | IMP original_view_did_move_to_superview = nullptr; | ||||||
|  | 
 | ||||||
|  | // This method is directly called by NSWindow during a window resize on OSX | ||||||
|  | // 10.10.0, beta 2. We must override it to prevent the content view from | ||||||
|  | // shrinking. | ||||||
|  | void SetFrameSize(NSView* self, SEL _cmd, NSSize size) { | ||||||
|  |   if (!IsFramelessWindow(self)) { | ||||||
|  |     auto original = | ||||||
|  |         reinterpret_cast<decltype(&SetFrameSize)>(original_set_frame_size); | ||||||
|  |     return original(self, _cmd, size); | ||||||
|  |   } | ||||||
|  |   // For frameless window, resize the view to cover full window. | ||||||
|  |   if ([self superview]) | ||||||
|  |     size = [[self superview] bounds].size; | ||||||
|  |   // [super setFrameSize:size]; | ||||||
|  |   auto super_impl = reinterpret_cast<decltype(&SetFrameSize)>( | ||||||
|  |       [[self superclass] instanceMethodForSelector:_cmd]); | ||||||
|  |   super_impl(self, _cmd, size); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // The contentView gets moved around during certain full-screen operations. | ||||||
|  | // This is less than ideal, and should eventually be removed. | ||||||
|  | void ViewDidMoveToSuperview(NSView* self, SEL _cmd) { | ||||||
|  |   if (!IsFramelessWindow(self)) { | ||||||
|  |     // [BridgedContentView viewDidMoveToSuperview]; | ||||||
|  |     auto original = reinterpret_cast<decltype(&ViewDidMoveToSuperview)>( | ||||||
|  |         original_view_did_move_to_superview); | ||||||
|  |     return original(self, _cmd); | ||||||
|  |   } | ||||||
|  |   [self setFrame:[[self superview] bounds]]; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | }  // namespace | ||||||
|  | 
 | ||||||
| NativeWindowMac::NativeWindowMac(const mate::Dictionary& options, | NativeWindowMac::NativeWindowMac(const mate::Dictionary& options, | ||||||
|                                  NativeWindow* parent) |                                  NativeWindow* parent) | ||||||
|     : NativeWindow(options, parent), |     : NativeWindow(options, parent), | ||||||
|  | @ -450,11 +468,15 @@ NativeWindowMac::NativeWindowMac(const mate::Dictionary& options, | ||||||
|     // produces warnings. To eliminate the warnings, we resize the contentView |     // produces warnings. To eliminate the warnings, we resize the contentView | ||||||
|     // to fill the window, and add subviews to that. |     // to fill the window, and add subviews to that. | ||||||
|     // http://crbug.com/380412 |     // http://crbug.com/380412 | ||||||
|     container_view_.reset([[FullSizeContentView alloc] init]); |     if (!original_set_frame_size) { | ||||||
|     [container_view_ |       Class cl = [[window_ contentView] class]; | ||||||
|         setAutoresizingMask:NSViewWidthSizable | NSViewHeightSizable]; |       original_set_frame_size = class_replaceMethod( | ||||||
|     [container_view_ setFrame:[[[window_ contentView] superview] bounds]]; |           cl, @selector(setFrameSize:), (IMP)SetFrameSize, "v@:{_NSSize=ff}"); | ||||||
|     [window_ setContentView:container_view_]; |       original_view_did_move_to_superview = | ||||||
|  |           class_replaceMethod(cl, @selector(viewDidMoveToSuperview), | ||||||
|  |                               (IMP)ViewDidMoveToSuperview, "v@:"); | ||||||
|  |       [[window_ contentView] viewDidMoveToWindow]; | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     // The fullscreen button should always be hidden for frameless window. |     // The fullscreen button should always be hidden for frameless window. | ||||||
|     [[window_ standardWindowButton:NSWindowFullScreenButton] setHidden:YES]; |     [[window_ standardWindowButton:NSWindowFullScreenButton] setHidden:YES]; | ||||||
|  |  | ||||||
|  | @ -36,8 +36,9 @@ class ScopedDisableResize { | ||||||
| @property BOOL disableAutoHideCursor; | @property BOOL disableAutoHideCursor; | ||||||
| @property BOOL disableKeyOrMainWindow; | @property BOOL disableKeyOrMainWindow; | ||||||
| @property NSPoint windowButtonsOffset; | @property NSPoint windowButtonsOffset; | ||||||
| @property (nonatomic, retain) NSView* vibrantView; | @property(nonatomic, retain) NSView* vibrantView; | ||||||
| - (void)setShell:(atom::NativeWindowMac*)shell; | - (void)setShell:(atom::NativeWindowMac*)shell; | ||||||
|  | - (atom::NativeWindowMac*)shell; | ||||||
| - (void)enableWindowButtonsOffset; | - (void)enableWindowButtonsOffset; | ||||||
| - (void)toggleFullScreenMode:(id)sender; | - (void)toggleFullScreenMode:(id)sender; | ||||||
| @end | @end | ||||||
|  |  | ||||||
|  | @ -27,6 +27,10 @@ bool ScopedDisableResize::disable_resize_ = false; | ||||||
|   shell_ = shell; |   shell_ = shell; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | - (atom::NativeWindowMac*)shell { | ||||||
|  |   return shell_; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| - (NSTouchBar*)makeTouchBar API_AVAILABLE(macosx(10.12.2)) { | - (NSTouchBar*)makeTouchBar API_AVAILABLE(macosx(10.12.2)) { | ||||||
|   if (shell_->touch_bar()) |   if (shell_->touch_bar()) | ||||||
|     return [shell_->touch_bar() makeTouchBar]; |     return [shell_->touch_bar() makeTouchBar]; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Cheng Zhao
				Cheng Zhao