Menus.Count Returns Different Number When Workbook Maximized

Last reviewed: September 2, 1997
Article ID: Q108662
The information in this article applies to:
  • Microsoft Excel for Windows, version 5.0

SYMPTOMS

In the Microsoft Visual Basic Programming System, Applications Edition, the following code

   ActiveMenuBar.Menus.Count

returns a different number of menus on the active menu bar depending on whether or not the active workbook is maximized.

CAUSE

When the active workbook is maximized, the control menu appears next to the File menu. Because this menu is counted by ActiveMenuBar.Menus.Count, the number returned by the code will be one greater for a maximized workbook than for a workbook that is restored or minimized.

WORKAROUND

Microsoft provides examples of Visual Basic for Applications procedures for illustration only, without warranty either expressed or implied, including, but not limited to the implied warranties of merchantability and/or fitness for a particular purpose. The Visual Basic procedures in this article are provided 'as is' and Microsoft does not guarantee that they can be used in all situations. While Microsoft support engineers can help explain the functionality of a particular macro, they will not modify these examples to provide added functionality, nor will they help you construct macros to meet your specific needs. If you have limited programming experience, you may want to consult one of the Microsoft Solution Providers. Solution Providers offer a wide range of fee-based services, including creating custom macros. For more information about Microsoft Solution Providers, call Microsoft Customer Information Service at (800) 426-9400.

To return the actual number of menus on the active menu bar, excluding the control menu if the worksheet is maximized, use the following code.

Sample Visual Basic Code

Sub Menu_Count()
   ' Declare variable x as an Integer and MyMenu as an Object
   Dim x As Integer
   Dim mymenu As Object
   ' Set initial value of x to zero
   x = 0
      ' Use For Next loop to count number of menus
      For Each mymenu In ActiveMenuBar.Menus
          x = x + 1
     Next
     ' Display number of menus in a message box
     MsgBox x
End Sub

REFERENCES

For more information about the Menu Bar Object, choose the Search button in Visual Basic Online Help and type:

    menu bar object


Additional query words: 5.00
Keywords : kbprg PgmOthr
Version : 5.00
Platform : WINDOWS


THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY.

Last reviewed: September 2, 1997
© 1998 Microsoft Corporation. All rights reserved. Terms of Use.