Hot News:

Unser Angebot:

  Foren auf CAD.de (alle Foren)
  Inventor VBA
  Alternative zu ThisApplication

Antwort erstellen  Neues Thema erstellen
CAD.de Login | Logout | Profil | Profil bearbeiten | Registrieren | Voreinstellungen | Hilfe | Suchen

Anzeige:

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen nächster neuer Beitrag | nächster älterer Beitrag
  
Gut zu wissen: Hilfreiche Tipps und Tricks aus der Praxis prägnant, und auf den Punkt gebracht für Autodesk Produkte
Autor Thema:  Alternative zu ThisApplication (2620 mal gelesen)
tarkan
Mitglied


Sehen Sie sich das Profil von tarkan an!   Senden Sie eine Private Message an tarkan  Schreiben Sie einen Gästebucheintrag für tarkan

Beiträge: 5
Registriert: 27.11.2003

erstellt am: 09. Feb. 2004 15:45    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Servus
Gibt es eine Möglichkeit Inventor als Applikation zu bestimmen ohne ThisApplication zu benutzen, vergleichbar mit Excel.Application für Excel, so daß man auf die APIProgrammier- und Anwendungsschnittstelle (Application Programming Interface) auch von außen zugreifen kann?
MfG ulli

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

PaulSchuepbach
Moderator
Programmierer




Sehen Sie sich das Profil von PaulSchuepbach an!   Senden Sie eine Private Message an PaulSchuepbach  Schreiben Sie einen Gästebucheintrag für PaulSchuepbach

Beiträge: 1005
Registriert: 01.10.2003

erstellt am: 09. Feb. 2004 16:03    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für tarkan 10 Unities + Antwort hilfreich

Hallo Ulli,

ThisApplication gibt's nur direkt in Inventor-VBA. Das  was Du suchst, funktioniert genau gleich: wenn Du z.B. in Excel die Inventor-Typelibrary einbindest, dann setze die Referenz auf Inventor z.B als 

Private oApp As Inventor.Application

' GetObject setzt voraus, dass Inventor bereits laeuft, sonst Err
Set oApp = GetObject(, "Inventor.Application")

' falls Fehler wird Inventor gestartet
If Err then
  Err.Clear
  Set oApp = CreateObject("Inventor.Application")

  ' oder anstelle 'CreateObject' einfach Fehlermeldung ausgeben
  ' MsgBox "Inventor muss gestartet sein!",16,"Falscher Fehler"
  ' Exit Sub
EndIf

oApp.Visible = True


usw.

Gruesse,

Paul

www.morecam.ch/cad.htm

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

tarkan
Mitglied


Sehen Sie sich das Profil von tarkan an!   Senden Sie eine Private Message an tarkan  Schreiben Sie einen Gästebucheintrag für tarkan

Beiträge: 5
Registriert: 27.11.2003

erstellt am: 09. Feb. 2004 17:28    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Danke.
Das ist genau das, was ich benötige.
allerdings würde ich dazu gern noch etwas wissen.
Kann ich so auch aus einem VB-Programm auf die Lib zugreifen??
Das wäre nämlich sehr wichtig für mich.
MfG
ulli

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

PaulSchuepbach
Moderator
Programmierer




Sehen Sie sich das Profil von PaulSchuepbach an!   Senden Sie eine Private Message an PaulSchuepbach  Schreiben Sie einen Gästebucheintrag für PaulSchuepbach

Beiträge: 1005
Registriert: 01.10.2003

erstellt am: 09. Feb. 2004 19:28    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für tarkan 10 Unities + Antwort hilfreich

Hallo Ulli,

oeffne in Excel den VAB-Editor. Im VBA-Editor geh auf 'Extras' - 'Verweise'. Eine Liste mit verfuegbaren Verweisen oeffnet sich. Aktiviere in der Liste das Kontrollkaestchen fuer 'Autodesk Inventor Object Library' - thats it.

Uebrigens: ich hatte im Code-Beispiel noch was vergessen:

VOR Set oApp = GetObject(, "Inventor.Application")
gehoert noch 'On Error Resume Next' - sonst kackt Deine Applikation bei 'GetObject' ab, falls Inventor nicht laeuft.


Gruesse,

Paul


www.morecam.ch/cad.htm

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

tarkan
Mitglied


Sehen Sie sich das Profil von tarkan an!   Senden Sie eine Private Message an tarkan  Schreiben Sie einen Gästebucheintrag für tarkan

Beiträge: 5
Registriert: 27.11.2003

erstellt am: 12. Feb. 2004 11:34    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hmm ich hab das jetzt mal so probiert in ein VB-Programm zu schreiben.
Leider kriege ich da immer Fehlermeldungen der Art:
"Fehler beim Kompilieren
Benutzerdefinierter Typ nicht definiert."
Die bezieht sich auf oApp As Inventor.Application.
Muß ich das noch irgendwo definieren.
Ich habe alle möglichen Verweise gesetzt, die setzbar sind.
Der Code sieht folgendermaßen aus:


Public Sub main()

' Inventor-Objekt finden

Dim oApp As Inventor.Application

On Error Resume Next
' GetObject setzt voraus, dass Inventor bereits laeuft, sonst Err
Set oApp = GetObject(, "Inventor.Application")

' falls Fehler wird Inventor gestartet
If Err Then
  Err.Clear
  Set oApp = CreateObject("Inventor.Application")

 
End If

oApp.Visible = True

' eigentliche Funktion

Dim oOccurrence As ComponentOccurrence

Set oOccurrence = oApp.ActiveDocument.SelectSet.Item(1)
    If Err Then
        MsgBox "An occurrence must be selected."
        Exit Sub
    End If
    On Error GoTo 0
   
    Call SetVisibility(oOccurrence.Name)

End Sub


Private Sub SetVisibility(SearchName As String)
   
    Dim oOccurrence As ComponentOccurrence
    oOccurrence.Edit

End Sub

Was hab ich vergessen, falsch gemacht, nicht gewusst??
Ist schließlich das erste VB-Programm, das ich schreibe.
MfG
ulli

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP



Planer*in für Glasfasernetze bzw. Operative/r LWL-Planer*in mit Betriebsaufgaben

Du suchst eine spannende Aufgabe mit positivem gesellschaftlichem Impact? Lass uns gemeinsam daran arbeiten, die Grundlage für eine moderne und zukunftsfähige Berliner Verwaltung zu schaffen und die Digitalisierung voranzutreiben ? werde Teil unseres Teams!

Für die Abteilung Kommunikationsdienste suchen wir ab sofort tatkräftige Unterstützung:
Planer*in für Glasfasernetze bzw....

Anzeige ansehenProjektmanagement
tarkan
Mitglied


Sehen Sie sich das Profil von tarkan an!   Senden Sie eine Private Message an tarkan  Schreiben Sie einen Gästebucheintrag für tarkan

Beiträge: 5
Registriert: 27.11.2003

erstellt am: 12. Feb. 2004 11:53    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hat sich schon erledigt.
Ich habe die Verweise fälschlicherweise in Inventors VBA-Editor gesetzt und nicht im Visual Studio und noch ein paar Fehler im Code.
Jetzt läuft es.
Ich möchte mich hiermit nochmals herzlichst bedanken für die ausgezeichnete Hilfe.
MfG
ulli

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Anzeige.:

Anzeige: (Infos zum Werbeplatz >>)

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen

nächster neuerer Beitrag | nächster älterer Beitrag
Antwort erstellen


Diesen Beitrag mit Lesezeichen versehen ... | Nach anderen Beiträgen suchen | CAD.de-Newsletter

Administrative Optionen: Beitrag schliessen | Archivieren/Bewegen | Beitrag melden!

Fragen und Anregungen: Kritik-Forum | Neues aus der Community: Community-Forum

(c)2023 CAD.de | Impressum | Datenschutz