Man kann viel darüber lesen, dass es ab der Version 4.0 von Microsoft Dynamics AX möglich ist auch mit .NET Objekten innerhalb von Dynamics AX zu arbeiten. Leider fehlt es oft an konkreten Beispielen, die einen ersten Überblick geben, wie man was machen muss.
Jeder der sich mit dem Thema schon einmal auseinander setzen musste, wird mit hoher Wahrscheinlichkeit auf eines dieser „Probleme“ gestoßen sein:
- Wie kann ein Datum zwischen Dynamics AX und .NET ausgetauscht werden?
- Wie kann die aktuelle Zeit an ein .NET Objekt übermittelt werden?
- Wie rufe ich eigentlich Werte eines .NET Enums ab?
Diese Liste könnte man noch beliebig erweitern.
Damit man einen kleinen Anhaltspunkt hat, wie die „Arbeit“ mit .NET Objekten gehen kann, soll dies anhand des Beispiels „Anlegen eines Termins in Outlook“ vorgestellt werden.
Zuerst muss eine Referenz zur der .NET Assembly erstellt werden, welche im Weitern verwendet werden soll. Hierzu muss im AOT der Zweig „References“ gewählt werden und über das Kontextmenü „Verweis hinzufügen“ ausgewählt werden.

In der neuen Maske wird die Assembly ausgewählt zu der eine Referenz erstellt werden soll. Hierzu navigiert man zu der entsprechenden Assembly und wählt diese über „Auswählen“ aus. Mit dem Drücken von „OK“ werden zu den ausgewählten Assemblys die Referenzen erstellt.
Bei diesem Beispiel wurde eine Referenz zur Assembly „Microsoft.Office.Interop.Outlook“ erstellt.

Ab jetzt können alle .NET Objekte, die in dieser Assembly enthalten sind, in Dynamics AX verwendet werden.
Wie dies im Einzelnen geschieht kann dem folgenden Beispiel entnommen werden, wo demonstriert wird, wie man aus Dynamics AX heraus ein Outlook Termin erstellt werden kann.
static void CreateOutlookAppointment(Args _args)
{
//.NET (CLR) Datentypen
InteropPermission permission;
Microsoft.Office.Interop.Outlook._Application outlookApplication;
Microsoft.Office.Interop.Outlook._AppointmentItem outlookAppointment;
Microsoft.Office.Interop.Outlook.OlItemType outlookItemType;
System.DateTime appointmentStartTime;
System.DateTime appointmentEndTime;
//Dynamics AX Datentypen
Date1980 startDate, endDate;
TimeExpected startTime, endTime;
;
permission = new InteropPermission(InteropKind::ClrInterop);
if (permission == null)
{
return;
}
//”Unsichere” Aufrufe starten
permission.assert();
//Das Outlook Application Objekt instanzieren
//(Beispiel für Erstellung eines .NET Klassenobjekts)
outlookApplication = new Microsoft.Office.Interop.Outlook.ApplicationClass();
//Gewünschten Outlook-Elementtyp auswählen
//(Beispiel für Zuweisung eines .NET Enum Wertes)
outlookItemType = ClrInterop::parseClrEnum('Microsoft.Office.Interop.Outlook.OlItemType', 'olAppointmentItem');
//Gewünschten Outlook-Elemnttyp erstellen (Termin)
outlookAppointment = outlookApplication.CreateItem(outlookItemType);
//Den Betreff zuweisen
//(Beispiel für Zuweisung eines "einfachen" Wertes)
outlookAppointment.set_Subject("Ein Test aus Dynamics AX");
startDate = str2Date("25.10.2007", 123);
startTime = str2Time("10:30:00");
//"Beginnt um" zuweisen
//(Beispiel für Konvertierung Dynamics AX Datum/Zeit -> .NET DateTime)
appointmentStartTime = System.Convert::ToDateTime(strfmt("%1 %2", startDate, time2str(startTime, 0, 0)));
outlookAppointment.set_Start(appointmentStartTime);
endDate = str2Date("26.10.2007", 123);
endTime = str2Time("11:00:00");
//"Endet um" zuweisen
appointmentEndTime = System.Convert::ToDateTime(strfmt("%1 %2", endDate, time2str(endTime, 0, 0)));
outlookAppointment.set_End(appointmentEndTime);
//Den Termin speichern (ab jetzt ist der Termin in Outlook zu sehen)
outlookAppointment.Save();
//”Unsichere” Aufrufe beenden
CodeAccessPermission::revertAssert();
}