wxNonOwnedWindowCocoaImpl* impl;
}
+- (NSRect)constrainFrameRect:(NSRect)frameRect toScreen:(NSScreen *)screen;
- (void)setImplementation: (wxNonOwnedWindowCocoaImpl *) theImplementation;
- (wxNonOwnedWindowCocoaImpl*) implementation;
- (void)noResponderFor: (SEL) selector;
@implementation wxNSWindow
+// The default implementation always moves the window back onto the screen,
+// even when the programmer explicitly wants to hide it.
+- (NSRect)constrainFrameRect:(NSRect)frameRect toScreen:(NSScreen *)screen
+{
+ return frameRect;
+}
+
- (void)setImplementation: (wxNonOwnedWindowCocoaImpl *) theImplementation
{
impl = theImplementation;
}
}
+// We need this for borderless windows, i.e. shaped windows or windows without
+// a title bar. For more info, see:
+// http://lists.apple.com/archives/cocoa-dev/2008/May/msg02091.html
+- (BOOL)canBecomeKeyWindow
+{
+ return YES;
+}
+
@end
@interface wxNSPanel : NSPanel
NSRect r = wxToNSRect( NULL, wxRect( pos, size) );
[m_macWindow setImplementation:this];
+ r = [NSWindow contentRectForFrameRect:r styleMask:windowstyle];
[m_macWindow initWithContentRect:r
styleMask:windowstyle
[m_macWindow orderWindow:NSWindowBelow relativeTo:0];
}
+void wxNonOwnedWindowCocoaImpl::ShowWithoutActivating()
+{
+ [m_macWindow orderFront:nil];
+ [[m_macWindow contentView] setNeedsDisplay: YES];
+}
+
bool wxNonOwnedWindowCocoaImpl::Show(bool show)
{
if ( show )
{
- [m_macWindow makeKeyAndOrderFront:nil];
- [[m_macWindow contentView] setNeedsDisplay:YES];
+ wxNonOwnedWindow* wxpeer = GetWXPeer();
+ if (wxpeer && !(wxpeer->GetWindowStyle() & wxFRAME_TOOL_WINDOW))
+ [m_macWindow makeKeyAndOrderFront:nil];
+ else
+ [m_macWindow orderFront:nil];
+ [[m_macWindow contentView] setNeedsDisplay: YES];
}
else
[m_macWindow orderOut:nil];
return true;
}
-bool wxNonOwnedWindowCocoaImpl::ShowWithEffect(bool show, wxShowEffect WXUNUSED(effect), unsigned WXUNUSED(timeout))
+bool wxNonOwnedWindowCocoaImpl::ShowWithEffect(bool show,
+ wxShowEffect effect,
+ unsigned timeout)
{
- return Show(show);
+ return wxWidgetCocoaImpl::
+ ShowViewOrWindowWithEffect(m_wxPeer, show, effect, timeout);
}
void wxNonOwnedWindowCocoaImpl::Update()
}
}
-bool wxNonOwnedWindowCocoaImpl::SetBackgroundStyle(wxBackgroundStyle WXUNUSED(style))
+void wxNonOwnedWindowCocoaImpl::SetWindowStyleFlag( long style )
+{
+ if (m_macWindow)
+ {
+ CGWindowLevel level = kCGNormalWindowLevel;
+
+ if (style & wxSTAY_ON_TOP)
+ level = kCGUtilityWindowLevel;
+ else if (( style & wxFRAME_FLOAT_ON_PARENT ) || ( style & wxFRAME_TOOL_WINDOW ))
+ level = kCGFloatingWindowLevel;
+
+ [m_macWindow setLevel: level];
+ }
+}
+
+bool wxNonOwnedWindowCocoaImpl::SetBackgroundStyle(wxBackgroundStyle style)
{
+ if ( style == wxBG_STYLE_TRANSPARENT )
+ {
+ [m_macWindow setOpaque:NO];
+ [m_macWindow setBackgroundColor:[NSColor clearColor]];
+ }
+
return true;
}
bool wxNonOwnedWindowCocoaImpl::SetShape(const wxRegion& WXUNUSED(region))
{
- return false;
+ [m_macWindow setOpaque:NO];
+ [m_macWindow setBackgroundColor:[NSColor clearColor]];
+
+ return true;
}
void wxNonOwnedWindowCocoaImpl::SetTitle( const wxString& title, wxFontEncoding encoding )
*y = p.y;
}
+bool wxNonOwnedWindowCocoaImpl::IsActive()
+{
+ return [m_macWindow isKeyWindow];
+}
+
+void wxNonOwnedWindowCocoaImpl::SetModified(bool modified)
+{
+ [m_macWindow setDocumentEdited:modified];
+}
+
+bool wxNonOwnedWindowCocoaImpl::IsModified() const
+{
+ return [m_macWindow isDocumentEdited];
+}
+
wxNonOwnedWindowImpl* wxNonOwnedWindowImpl::CreateNonOwnedWindow( wxNonOwnedWindow* wxpeer, wxWindow* parent, const wxPoint& pos, const wxSize& size,
long style, long extraStyle, const wxString& name )
{