HERBERS Excel-Forum - die Beispiele

Thema: Tabellenblattbereich sortiert als Zellkontextmenü

Home

Gruppe

Menue

Problem

Wie kann ich einen Tabellenblattbereich sortiert in ein in ein Zell-Kontextmenü übernehmen und dieses bei Klick mit der rechten Maustaste ausschließlich in Zelle B2 anzeiten lassen? Der jeweil ausgewählte Menüpunkt soll in Zelle B2 eingetragen werden.

Lösung
Geben Sie den Ereigniscode in das Klassenmodul des Arbeitsblattes ein.
ClassModule: DieseArbeitsmappe

Private Sub Workbook_BeforeClose(Cancel As Boolean)
   Call CmdDelete
End Sub

ClassModule: Tabelle1

Private Sub Worksheet_BeforeRightClick( _
   ByVal Target As Excel.Range, Cancel As Boolean)
   Dim oBar As CommandBar
   Dim oBtn As CommandBarButton
   Dim arrItems() As String
   Dim arrMenu As Variant
   Dim iRow As Integer, iRowM As Integer
   If ActiveCell.Address <> "$B$1" Then Exit Sub
   Cancel = True
   Call CmdDelete
   Set oBar = CommandBars.Add _
      (Name:="MyContext", Position:=msoBarPopup)
   iRow = 5
   Do Until IsEmpty(Cells(iRow, 5))
      iRowM = iRowM + 1
      ReDim Preserve arrItems(iRowM)
      arrItems(iRowM) = Cells(iRow, 5)
      iRow = iRow + 1
   Loop
   arrMenu = SortMenu(arrItems)
   For iRow = 1 To UBound(arrItems)
      Set oBtn = oBar.Controls.Add
      With oBtn
         .Caption = arrItems(iRow)
         .OnAction = "Eingabe"
         .Style = msoButtonCaption
      End With
   Next iRow
   oBar.ShowPopup
End Sub

Private Function SortMenu(arrItems)
   Dim iCount As Integer, iA As Integer, iB As Integer
   Dim sTmp As String
   iCount = UBound(arrItems)
   For iA = 1 To iCount
      For iB = iA + 1 To iCount
         If arrItems(iA) > arrItems(iB) Then
            sTmp = arrItems(iA)
            arrItems(iA) = arrItems(iB)
            arrItems(iB) = sTmp
         End If
      Next iB
   Next iA
   SortMenu = arrItems
End Function

StandardModule: basMain

Sub CmdDelete()
   On Error GoTo ERRORHANDLER
   Application.CommandBars("MyContext").Delete
ERRORHANDLER:
End Sub

Sub Eingabe()
   ActiveCell.Value = Application.CommandBars("MyContext").Controls(Application.Caller(1)).Caption
End Sub

Beiträge aus dem Excel-Forum zu den Themen Menue und Context

Excel Form Kontextmenue geht nicht Zellen Kontextmenue ausfuehren
Dynamisches Kontextmenue Makro für Pulldown Menue
Menueeintrag einbinden makro in kontextabhängiges Befehlsmenue
Menue mit eigenen Macros versehen Entfernen eines Eintrages im Kontextmenue
Untermenue von Menueleiste Adresszeile/Formelzeile im Menue ist weg
FaceId bei Untermenue möglich? Menue Leiste ein ausblenden
Menue nur erstellen, wenn noch nicht vorhadnen Menuebar ausblenden
2003 Menuepunkte in 2007 finden Kontexmenue
Filter als Dropdown-Menue in neuem Tabellenblatt Menue
Eigenes Formatierungsmenue Kontextmenue
Autofilter, polldown Menue in Fragmenten? Drop down Menue
Excel Menues mit Bildern Pfeil im Drop-Down-Menue dauerhaft
Drop Down Menue in Zelle Abhängige Drop-Down-Menues
Mehrere Untermenues + Application.caller() Problem Menue - Makro editieren
Menueleiste zerschossen Menueerweiterung um Bildchens
Pulldown Menueeintraege disablen enablen? Menueleiste "Überarbeiten" nie anzeigen !
Alle Menue- und Symbolleisten sind weg. Einfügen von Werten in ein Dropdownmenue
Dropdownmenue Dateien eines Verzeichnisses in Pulldown Menues
drop-down menue als Sortierung Zusaetzliches Menue in Menueleiste
dropdownmenue nicht "selbstentleerend" Menue-Text aus Zelle übernehmen
Menue Sheet beim Oeffnen einer Excel Datei Menueeintrag immer sichtbar machen
Menueleiste An Heiko-Eigenes Context Menü für Maus
Eigenes Context Menü für Maus Kontex-Menue
eigene Menueleiste erstellen Frage zur HelpContextID-Eigenschaft bei Label
FDrage zur HelpContextID-Eigenschaft bei Label Problem beim Menueeintrag verbergen