]> git.saurik.com Git - wxWidgets.git/blobdiff - src/common/sizer.cpp
When inserting a new menu don't try to find th eposition of the current one
[wxWidgets.git] / src / common / sizer.cpp
index 1d187529ff52baf2b3261acbea9a0e97584a0ed2..9dfa1e376d1952e271dd8355115d8d3f526460bb 100644 (file)
@@ -1548,7 +1548,36 @@ static void GetStaticBoxBorders( wxStaticBox *box,
     // guess the thickness of a wxStaticBox border
 #ifdef __WXCOCOA__
     box->GetBordersForSizer(borderTop,borderOther);
-#else // __WXCOCOA__
+#elif defined(__WXMAC__)
+
+    static int extraTop = -1; // Uninitted
+    static int other = 5;
+
+    if ( extraTop == -1 )
+    {
+        int verMaj, verMin;
+        (void) ::wxGetOsVersion(&verMaj, &verMin);
+
+        // The minimal border used for the top. Later on the staticbox'
+        // font height is added to this.
+        extraTop = 0;
+
+        // Is the Mac OS version OS X Panther or higher?
+        if ( ((verMaj << 16) + verMin) >= 0x00100030 )
+        {
+            // As indicated by the HIG, Panther needs an extra border of 11
+            // pixels (otherwise overlapping occurs at the top). The "other"
+            // border has to be 11.
+            extraTop = 11;
+            other = 11; 
+        }
+
+    }
+
+    *borderTop = extraTop + box->GetCharHeight();
+    *borderOther = other;
+
+#else
 #ifdef __WXGTK__
     if ( box->GetLabel().IsEmpty() )
         *borderTop = 5;