Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

Menueintrag mit VBA in Outlook

Frage Entwicklung VB for Applications

Mitglied: veraxel

veraxel (Level 1) - Jetzt verbinden

26.04.2012 um 14:30 Uhr, 6330 Aufrufe, 3 Kommentare

Menueintrag anlegen und löschen

Hallo Zusammen,

eines vorab, ich habe sehr wenig Ahnung in VBA.

Ich möchte in Outlook einen Menüeintrag beim starten hinzufügen. Beim Klick soll ein neues E-Mail-Fenster aufgehen mit vordefinierten Inhalt.
Das habe ich auch dank google hinbekommen ...

Private Sub Application_Startup()

Dim MenuBar As Office.CommandBar
Dim Menu As Office.CommandBarControl
Dim Control As Office.CommandBarButton
Set MenuBar = Application.ActiveExplorer.CommandBars("Menu Bar")

Set Menu = MenuBar.Controls.Add(Type:=msoControlPopup)
Menu.Caption = "Mein Menüeintrag"
Set Control = Menu.Controls.Add
With Control
.Caption = "Eintrag1"
.OnAction = "Eintrag1"
.Style = msoButtonCaption
End With

End Sub

.
.
.

Sub Eintrag1()

Set myOlApp = CreateObject("Outlook.Application")
Set MyItem = myOlApp.CreateItem(olMailItem)
MyItem.Subject = "Betreff Eintrag1"
MyItem.Body = Chr$(13) & "Nachrichtentext Eintrag1"
MyItem.To = "eintrag1@email.de"
MyItem.Display

End Sub


Nun ist es jedoch so dass der Menüeintrag jedesmal erstellt wird und ich mittlerweile viele davon habe.
Folgende Änderungen sind erwünscht, aber ich krieg es nicht hin. Habe schon ein paar Beispielcodes im Internet gefunden, aber funktionieren irgendwie alle nicht.

1.) Es soll vor dem Anlegen geprüft werden ob der Eintrag nicht schon vorhanden ist.
2.) Beim Beenden soll der Menüeintrag wieder gelöscht werden

Und weitere Frage:
Wie kann ich das fertige Makro/VBA-Script signieren?

Vielen Dank für jede Hilfe.
Mitglied: 76109
26.04.2012 um 17:19 Uhr
Hallo veraxel!

Füge diese Sub in einem Modul ein und starte diese einmal über den Debugger. Anschließend den Code wieder entfernen:
01.
Sub MyMenuBarDelete() 
02.
    Dim MenuBar As Office.CommandBar 
03.
 
04.
    Set MenuBar = Application.ActiveExplorer.CommandBars("Menu Bar") 
05.
    MenuBar.Controls("Mein Menüeintrag").Delete 
06.
End sub
Ersetze in Deinem Code diese Codezeile
01.
Set Menu = MenuBar.Controls.Add(Type:=msoControlPopup)
durch diese Codezeile:
01.
Set Menu = MenuBar.Controls.Add(Type:=msoControlPopup, Temporary:=True)
Dadurch wird Deine MenuBar erst zur Laufzeit erstellt und bei Programmende automatisch wieder entfernt.

Für Dein Zertificat versuch mal, ob Du die "SelfCert.exe" starten kannst. Wenn nicht, musst Du Dein Office-Setup starten und das Feature "Gemeinsame genutzte Office-Features > Digitale Signatur für VBA-Projekte" installieren.


Gruß Dieter
Bitte warten ..
Mitglied: veraxel
27.04.2012 um 09:31 Uhr
Hallo Dieter,

ich kann es erst nächste Woche Mittwoch ausprobieren und gebe Info ob es klappt. Danke vorab und schönes Wochenende.

Gruß,
Axel
Bitte warten ..
Mitglied: veraxel
07.05.2012 um 12:08 Uhr
Vielen Dank! Habe es jetzt getestet und klappt super.
Bitte warten ..
Ähnliche Inhalte
Outlook & Mail
gelöst Outlook vba Email Anhang in Ordner speichern (3)

Frage von Daywalkercxp zum Thema Outlook & Mail ...

VB for Applications
Vba Outlook Betreff Datum - Absender - Empfänger (7)

Frage von Romy0907 zum Thema VB for Applications ...

VB for Applications
gelöst VBA - Automatisches Entpacken von Zipordnern (6)

Frage von it4baer zum Thema VB for Applications ...

Neue Wissensbeiträge
Firewall

PfSense Repository für Version 2.3.x

(2)

Information von Dobby zum Thema Firewall ...

LAN, WAN, Wireless

WPA-2 hat erste Risse: KRACK

(4)

Information von the-buccaneer zum Thema LAN, WAN, Wireless ...

Hardware

GPD Pocket: Winziger Laptop für Wenig Tipper

(1)

Information von pelzfrucht zum Thema Hardware ...

Windows 10

Microsoft veröffentlicht das "Fall Creators Update

(10)

Information von Penny.Cilin zum Thema Windows 10 ...

Heiß diskutierte Inhalte
Windows Server
gelöst Gruppenrichtlinie greift nicht zu! (23)

Frage von Syosse zum Thema Windows Server ...

Hosting & Housing
Mailserver Software Empfehlungen (20)

Frage von sunics zum Thema Hosting & Housing ...

Windows 7
gelöst Windows 7 Anmeldedomäne festlegen (13)

Frage von flotaut zum Thema Windows 7 ...