Microsoft KB Archive/108662

From BetaArchive Wiki

Article ID: 108662

Article Last Modified on 10/11/2006



APPLIES TO

  • Microsoft Excel 5.0 Standard Edition



This article was previously published under Q108662

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 professionals 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


Keywords: kbprogramming KB108662