Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de
  AutoCAD VBA
  Aufruf von VBA-Prozeduren via Lisp

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
  
PNY wird von NVIDIA zum Händler des Jahres gewählt – zum dritten Mal in Folge, eine Pressemitteilung
Autor Thema:  Aufruf von VBA-Prozeduren via Lisp (2176 mal gelesen)
RoSiNiNo
Mitglied
Konstrukteur


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

Beiträge: 1126
Registriert: 09.10.2002

Acad 2011-deutsch, Express Tools
3ds Max 2010
Win 7-Professional
HP Workstation Z400, 6GB
GeForce GTX 470

erstellt am: 07. Jul. 2004 16:41    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

Hallo Kollegen,
ich hab da mal eine Frage zu LISP.
Bisher habe ich die Befehle so definiert:
Code:
(defun c:blocknum () (vl-vbarun "acad.dvb!koordinaten.BlockNumeriert"))
(defun c:AttCountX () (vla-runmacro(vlax-get-acad-object) "acad.dvb!Modify.AttribCountExtend"))

(defun c:BlockTxP () (vl-vbarun "acad.dvb!block.BlockTextPrefix"))
(defun c:BlockTxS () (vl-vbarun "acad.dvb!block.BlockTextSuffix"))



Jetzt habe ich in einem anderen Beitrag eine gute Variante gelesen, z.B. folgendes.
Code:
;;; *********************
;;; setq global variables
;;; *********************

;;; get the application object
(setq *acadObj* (vlax-get-acad-object))

;;    array of command name strings
(setq CommandList
      (list
"BreakLineByBlock" "CapsLockEnable"
"CapslockToggle" "ColorToByLayer"
"ColorToEntity" "DeleteAllPlotConfig"
"DeletePlotConfig" "DeletePlotConfigs"
"EraseClouds" "ExplodeMinsert"
"HelpAbout" "ImportPageSetups"
"ImportPageSetupsConfig"
"ImportPageSetupsND" "ImportPlotConfigs"
"PrintSchedule" "ScriptMgr"
"SetLayout" "SetPlotConfig"
"SetViewportScale" "ShowLayouts"
"ScriptMgr" "ScriptMgr"
"ToggleVPLock" "VpExtentsBox"
)
)

;;    make a defun for each command name
(foreach CommandName CommandList
  (eval
    (list 'defun
  (read (strcat "C:" CommandName))
  '()
  (list 'vla-RunMacro *AcadObj* CommandName)
  '(princ)
    )
  )
)


Wie ihr seht ist es eine einfache Liste mit CommandName's.
Jetzt habe ich aber das Problem das bei mir bei ;;make a defun for each command name nicht zwei mal der gleiche CommandName benötigt werden würde sondern:

Code:
(foreach CommandName CommandList
  (eval
    (list 'defun
  (read (strcat "C:" CommandName))
  '()
  (list 'vla-RunMacro *AcadObj* CommandNameDefinition)
  '(princ)
    )
  )
)

Kann man das in einer Liste bewerkstelligen? Ich hoffe mich klar genug ausgedrückt zu haben.

------------------
Roland

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

CADmium
Moderator
Maschinenbaukonstrukteur




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

Beiträge: 13530
Registriert: 30.11.2003

ACAD 2008 Mechanical

erstellt am: 07. Jul. 2004 16:54    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 RoSiNiNo 10 Unities + Antwort hilfreich

ungestestet , so etwa :

(Setq VBA-LISTE
  (list
    ("BlockTxP" "acad.dvb!block.BlockTextPrefix")
    ("BlockTxS" "acad.dvb!block.BlockTextSuffix")
  )
)

(foreach LISTENEINTRAG VBA-LISTE
  (eval
    (list 'defun
          (read (strcat "C:" (car LISTENEINTRAG)))
          '()
          (list 'vla-RunMacro *AcadObj* (cadr LISTENEINTRAG))
          '(princ)
    )
  )
)

------------------
- Thomas -

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

RoSiNiNo
Mitglied
Konstrukteur


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

Beiträge: 1126
Registriert: 09.10.2002

Acad 2011-deutsch, Express Tools
3ds Max 2010
Win 7-Professional
HP Workstation Z400, 6GB
GeForce GTX 470

erstellt am: 08. Jul. 2004 07:06    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 Thomas,
ich werde es einmal testen. Da hätte ich dann doch noch eine Frage, kann man eigentlich zu jedem Listeneintrag auch noch Kommentare schreiben? z.B.

(Setq VBA-LISTE
   (list
    ("BlockTxP" "acad.dvb!block.BlockTextPrefix")  ;Schreibt Prefix vor Attributtext
    ("BlockTxS" "acad.dvb!block.BlockTextSuffix")  ;Schreibt Suffix nach Attributtext
   )
)

------------------
Roland

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

CADmium
Moderator
Maschinenbaukonstrukteur




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

Beiträge: 13530
Registriert: 30.11.2003

ACAD 2008 Mechanical

erstellt am: 08. Jul. 2004 07:38    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 RoSiNiNo 10 Unities + Antwort hilfreich

Aber sicher! .. P.S: Warum testest du es nicht einfach ? 

------------------
- Thomas -

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

RoSiNiNo
Mitglied
Konstrukteur


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

Beiträge: 1126
Registriert: 09.10.2002

Acad 2011-deutsch, Express Tools
3ds Max 2010
Win 7-Professional
HP Workstation Z400, 6GB
GeForce GTX 470

erstellt am: 08. Jul. 2004 07:40    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

Schäm :-(

------------------
Roland

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

RoSiNiNo
Mitglied
Konstrukteur


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

Beiträge: 1126
Registriert: 09.10.2002

Acad 2011-deutsch, Express Tools
3ds Max 2010
Win 7-Professional
HP Workstation Z400, 6GB
GeForce GTX 470

erstellt am: 08. Jul. 2004 13:12    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

Ich hab jetzt ein kleines Problem mit diesem Code:

;;; *********************
;;; setq global variables
;;; *********************

;;; get the application object
(setq *acadObj* (vlax-get-acad-object))

;; array of command name strings
(setq CommandList
      (list
("HK3D" "acad.dvb!aTest.HK_OBQZ") ;3d Höhenkote
("RIDL" "acad.dvb!aTest.RechnenIstDochLeicht") ;Rechnen
      )
)

;; make a defun for each command name
(foreach CommandName CommandList
  (eval
    (list 'defun
  (read (strcat "C:" (car CommandName)))
  '()
  (list 'vla-RunMacro *AcadObj* (cadr CommandName))
  '(princ)
    )
  )
)


Ich bekomme beim Laden folgenden Fehler:

Befehl: (load"TestBefehle")
; Fehler: Fehlerhafte Funktion: "HK3D"

Wenn ich die Befehle wie früher so definiere, dann klappt es:

(defun c:HK3D () (vla-runmacro (vlax-get-acad-object) "acad.dvb!aTest.HK_OBQZ"))
(defun c:RIDL () (vla-runmacro (vlax-get-acad-object) "acad.dvb!aTest.RechnenIstDochLeicht"))


Wo ist oben der Fehler begraben, ich habe auch versucht die Einträge in der Liste zu ändern:
("HK3D" "\"acad.dvb!aTest.HK_OBQZ\"") ;3d Höhenkote
hat aber auch nicht funktioniert.

------------------
Roland

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

CADmium
Moderator
Maschinenbaukonstrukteur




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

Beiträge: 13530
Registriert: 30.11.2003

ACAD 2008 Mechanical

erstellt am: 08. Jul. 2004 13:17    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 RoSiNiNo 10 Unities + Antwort hilfreich

mußt das ganze so schreiben:

(setq CommandList
      (list
'("HK3D" "acad.dvb!aTest.HK_OBQZ") ;3d Höhenkote
'("RIDL" "acad.dvb!aTest.RechnenIstDochLeicht") ;Rechnen
      )
)

' verhindert die Ausführung, lisp "denkt" sonst, da wäre eine Funktion

P.S. Schau mal http://www.autolisp-tutorial.mapcar.net
------------------
       
  - Thomas -

[Diese Nachricht wurde von CADmium am 08. Jul. 2004 editiert.]

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)2025 CAD.de | Impressum | Datenschutz