X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f298b203b5a969175bb76a6cef6757fa7c6c4b24..defbed48e78f4e84b35f62c2c1b7fd58d740501c:/include/wx/cocoa/window.h diff --git a/include/wx/cocoa/window.h b/include/wx/cocoa/window.h index e1a69eba19..06ce0bb977 100644 --- a/include/wx/cocoa/window.h +++ b/include/wx/cocoa/window.h @@ -18,6 +18,8 @@ #import #endif //def __OBJC__ +DECLARE_WXCOCOA_OBJC_CLASS(NSAffineTransform); + class wxWindowCocoaHider; class wxWindowCocoaScrollView; @@ -70,6 +72,14 @@ public: // Add/remove children void CocoaAddChild(wxWindowCocoa *child); void CocoaRemoveFromParent(void); +#ifdef __OBJC__ + // Returns an autoreleased NSAffineTransform which can be applied + // to a graphics context currently using the view's coordinate system + // (such as the one locked when drawRect is called or after a call + // to [NSView lockFocus]) such that further drawing is done using + // the wxWidgets coordinate system. + WX_NSAffineTransform CocoaGetWxToBoundsTransform(); +#endif //def __OBJC__ protected: // enable==false: disables the control // enable==true: enables the control IF it should be enabled @@ -111,6 +121,12 @@ protected: // NOTE: position is 10,10 to make it "obvious" that it's out of place return NSMakeRect(10.0,10.0,WidthDefault(size.x),HeightDefault(size.y)); } + // These functions translate NSPoint or NSRect between the coordinate + // system of Cocoa's boudns rect and wx's coordinate system. + NSPoint CocoaTransformBoundsToWx(NSPoint pointBounds); + NSRect CocoaTransformBoundsToWx(NSRect rectBounds); + NSPoint CocoaTransformWxToBounds(NSPoint pointWx); + NSRect CocoaTransformWxToBounds(NSRect rectWx); #endif //def __OBJC__ // ------------------------------------------------------------------------ // Implementation