LISP文件加载设置.docx_第1页
LISP文件加载设置.docx_第2页
LISP文件加载设置.docx_第3页
LISP文件加载设置.docx_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

下面开始编写初始化LISP程序。这里,我们创建一个LISP程序,命名为:Loadtbox.lsp,这个程序将负责把菜单、主程序等加载到系统中。以下是这个Loadtbox.lsp的写法。我尽量在注释中解释:; 首先定义初始化函数(defun InittboxApplication (/ ; 内部函数 GetMyApplicationPath GettboxPath strParse StrUnParse tbox_AddSupportPath Load_tboxMenu tbox_placemenu ; 局部变量 tbox_cmdecho_save ); 取得本程序的路径.; 文件路径从注册表中读取,这些信息由安装程序负责写入注册表; - (defun GetMyApplicationPath (AppID) (vl-registry-read (strcat HKEY_LOCAL_MACHINESOFTWAREMicrosoftWindowsCurrentVersionUninstall AppID _is1 ) Inno Setup: App Path ) ) (defun GettboxPath () (GetMyApplicationPath Lisp工具箱) ); 解析字符串为表(函数来自明经通道转载); - (defun strParse (Str Delimiter / SearchStr StringLen return n char) (setq SearchStr Str) (setq StringLen (strlen SearchStr) (setq return () (while ( StringLen 0) (setq n 1) (setq char (substr SearchStr 1 1) (while (and (/= char Delimiter) (/= char ) (setq n (1+ n) (setq char (substr SearchStr n 1) ) ;_ end of while (setq return (cons (substr SearchStr 1 (1- n) return) (setq SearchStr (substr SearchStr (1+ n) StringLen) (setq StringLen (strlen SearchStr) ) ;_ end of while (reverse return) ) ;_ end of defun; 反解析表为字符串(函数来自明经通道转载); - (defun StrUnParse (Lst Delimiter / return) (setq return ) (foreach str Lst (setq return (strcat return Delimiter str) ) ;_ end of foreach (substr return 2) ) ;_ end of defun; 添加支持文件搜索路径; -; note: 第二个参数如果为真, 插最前,否则插最后; (defun tbox_AddSupportPath (PathToAdd isFirst / supportlist) (if (not (vl-string-search (strcase (strcat pathToAdd ;) (strcase (strcat (getenv ACAD) ;) ) ) ; 保证不重复添加 (progn (setq supportlist (strparse (getenv ACAD) ;) (setq supportlist (vl-remove-if-not vl-file-directory-p supportlist ) ) ; 移除不存在的文件夹 (if isFirst (setq supportlist (cons PathToAdd supportlist) (setq supportlist (append supportlist (list PathToAdd) ) (setenv ACAD (strUnParse supportlist ;) ) ) ) ; 根据不同的AutoCAD版本加载不同的菜单文件。 (defun Load_tboxMenu (/ acadver) (setq acadver (atof (getvar acadver) (cond (and (= acadver 15.0) (= acadver 16.0) (= acadver 16.2) (command _menuload tbox2006.mnu) ) ) ; 这个函数用来插入菜单条 ; The following code placemenu from LUCAS(龙龙仔) (defun tbox_placemenu (/ n) (if (menugroup tbox) (progn (setq n 1) (while ( n 3) (setq n (- n 2) (setq n 3) ) ;if ; 如需插入多条菜单,以反序在这里写: ; 因只有一条下拉菜单,因此这里4,3,2条注释掉 ; (menucmd (strcat p (itoa n) =+tbox.pop4) ; (menucmd (strcat p (itoa n) =+tbox.pop3) ; (menucmd (strcat p (itoa n) =+tbox.pop2) (menucmd (strcat p (itoa n) =+tbox.pop1) (setq n 25) ) ;progn ) ;if ) ;while ) ;progn ) ;if (princ) ); -; main:; - (setq tbox_cmdecho_save (getvar cmdecho) (setvar cmdecho 0) ; 添加搜索路径 (tbox_AddSupportPath (GettboxPath) nil) ; 如果菜单组还没有被加载,则加载之 (if (not (menugroup tbox) (Load_tboxMenu) ) ; 插到合适的位置; (tbox_placemenu) (setvar cmdecho tbox_cmdecho_save) (setq tbox_cmdecho_save nil) (princ) ;_end of defun inittboxApp

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论