明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: zhongys

一次性建立多个层,自定义函数通不过,大家帮忙解决一下

  [复制链接]
发表于 2009-9-4 23:05:00 | 显示全部楼层
(defun zgx-mklayer (layname color ltype linewid / lst1 lst2)
  (if (and (not (tblobjname "ltype" ltype))
    (not (command "_.-linetype" "_load" ltype "acad.lin" "")
    )
    (not (tblobjname "ltype" ltype))
      )     ;and
    (setq ltype "CONTINUOUS")
  )
  (setq lst1 (list 0 100 100 2 62 6 70 370)
 lst2 (list "layer"       "AcDbSymbolTableRecord"
     "AcDbLayerTableRecord"
     layname       color
     ltype       0
     linewid
    )
  )
  (setq lst2 (mapcar 'cons lst1 lst2))
  (entmake lst2)
)
发表于 2009-9-5 15:02:00 | 显示全部楼层
VBA建立的图层。
  1. Function Maked3DModelLayer(cadApp As AcadApplication, EntArr As Variant, EntColorArr As Variant) As Variant
  2.   Dim LayerArray, LayerColorArray
  3.   Dim oLayer As AcadLayer
  4.   For Each oLayer In cadApp.ActiveDocument.Layers
  5.     If InStr(oLayer.Name, "中心线") > 0 Then
  6.       Exit Function
  7.     End If
  8.   Next oLayer
  9.   LayerArray = Array("粗实线", "虚线", "细实线", "中心线", "点划线", "尺寸线", "文本", "明细表材料表", "件号", "标题栏")
  10.   Maked3DModelLayer = LayerArray
  11.   LayerColorArray = Array(1, 255, 3, 4, 4, 6, 2, 131, 124, 4)
  12.   Dim TestLayer As AcadLayer
  13.   For ii = 0 To UBound(LayerArray)
  14.     Set TestLayer = cadApp.ActiveDocument.Layers.Add(LayerArray(ii))
  15.     TestLayer.Color = LayerColorArray(ii)
  16.   Next ii
  17.   For ii = 0 To UBound(EntArr)
  18.     Set TestLayer = cadApp.ActiveDocument.Layers.Add(EntArr(ii))
  19.     TestLayer.Color = EntColorArr(ii)
  20.   Next ii
  21.   With cadApp.ActiveDocument
  22.     .Linetypes.Load "ACAD_ISO03W100", "acad.lin"
  23.     .Linetypes.Load "ACAD_ISO04W100", "acad.lin"
  24.     .Linetypes.Load "ACAD_ISO05W100", "acad.lin"
  25.     .Layers("中心线").Linetype = "ACAD_ISO04W100"
  26.     .Layers("虚线").Linetype = "ACAD_ISO03W100"
  27.     .Layers("点划线").Linetype = "ACAD_ISO05W100"
  28.     '.SendCommand "ltscale" & vbCr & 10 & vbCr
  29.   End With
  30. End Function
  31. '''
发表于 2009-9-5 21:04:00 | 显示全部楼层
龙龙仔版主的mapcar用法太强.学习
发表于 2009-9-11 11:56:00 | 显示全部楼层
思路都很好,学习了
发表于 2009-9-11 17:14:00 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2010-9-16 19:44:00 | 显示全部楼层
大家给的程序都非常好。谢谢。
发表于 2011-4-29 01:22:31 | 显示全部楼层
学习啦
发表于 2012-4-10 13:45:43 | 显示全部楼层
xyp1964 发表于 2009-9-2 13:14

很棒,不知能不能 在修改一下, 每个层有对应想线型,比如中心线层,就自动加载 虚线。
发表于 2012-6-3 00:01:48 | 显示全部楼层
xyp1964 发表于 2009-9-2 13:14

在程序里面能加LWDEFAULT变量(线宽)
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2025-5-19 07:39 , Processed in 0.153417 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表