一直想有一个在Allegro中换层的skill,比如输入l 1 2 3,就显示1、2、3这三层。最近学了点基础的Skill语言,简单写了一个,基本能用。
软件:Cadence Allegro 16.6
; change_layer.il
; 放在.brd同路径下,allegro中执行skill load("change_layer.il")后可以使用
; 切换线路层,例如,
;l 1 2 ; 1/2 两层,
;l 3 4 5 ; 3/4/5 三层
;l ;清空显示
axlCmdRegister( "l" 'showlayers);注册指令"l"
defun(showlayers (@rest args)
axlVisibleDesign(nil) ;清空显示
foreach(item args
layerNum = evalstring(item)
showlayer(layerNum)
);设置每一层的显示
axlVisibleUpdate(t)
)
defun(showlayer (layerNum)
allLayer = axlGetParam("paramLayerGroup:ETCH")->groupMembers
;axlVisibleDesign(nil)
layerName = nthelem(layerNum allLayer) ;layerName = nthelem(2 allLayer)
etchlayer = strcat("ETCH/" layerName)
axlVisibleLayer(etchlayer t)
when(axlDBGetLayerType(etchlayer) == "PLANE"
axlVisibleLayer( "ANTI ETCH/ALL" t )) ;如果是plane,额外显示anti etch/all层
axlVisibleLayer(strcat("PIN/" layerName) t)
axlVisibleLayer(strcat("VIA CLASS/" layerName) t)
axlVisibleLayer(strcat("BOUNDARY/" layerName) t)
axlVisibleLayer(strcat("DRC ERROR CLASS/" layerName) t)
axlVisibleLayer(strcat("route keepout/" layerName) t)
axlVisibleLayer(strcat("via keepout/" layerName) t)
axlVisibleLayer(strcat("CONSTRAINT REGION/" layerName) t)
axlVisibleLayer( "CONSTRAINT REGION/ALL" t )
axlVisibleLayer( "BOARD GEOMETRY/OUTLINE" t )
axlVisibleLayer( "route keepout/all" t )
axlVisibleLayer( "route keepin/all" t )
planlayer = strcat("PLAN/" layerName)
when(axlLayerGet(planlayer)
axlVisibleLayer( planlayer t ))
axlSetActiveLayer(strcat("ETCH/" layerName))
;axlVisibleUpdate(t)
)
放在和.brd 设计 文件同一个路径下,在下方控制台输入skill load("change_layer.il"),即可使用。
Command > skill load("change_layer.il")
t
Command > l 2 3
Command > l 3 4 5
效果:

change_layer.il复制到x:\Cadence\SPB_16.6\share\local\pcb\skill目录下。allegro.ilinit如下:(当然,也可以复制一份目录下的example.ilinit,改名为allegro.ilinit,加载当前目录下的所有.il文件。);allegro.ilinit
;x:\Cadence\SPB_16.6\share\local\pcb\skill
load("change_layer.il")
change_layer.ilshowlayers和参数的括号(@rest args)之间必须加空格,否则会报错,查了好久。 E- Error defun: argument #1 should be a symbol (type template = “sgg”) - _Check_Refdes_main() =>必須將_Check_Refdes_main()** 改為_Check_Refdes_main () , main _與 ()_之間要空格SKILL编程常见报错及解决办法(持续更新中……) - 编译调试 - Cadence Skill 论坛 - Powered by Discuz! (allegro-skill.com)
t和nil,简单看,t可以表示true,nil表示false或empty:The true condition is represented by the special atom t or anything other than nil. axlCmdRegister( "l" 'showlayers)axlVisibleUpdate 等函数:主要是和显示层有关的函数,见Allegro® User Guide: SKILL Referencenthelem、foreach、@rest等:skill语言的基本语法和函数,见SKILL Language User Guide上面这个skill的一些执行步骤记录:
skill,进入SKILL-AXL这个shell;exit,退出。Command > skill
Skill > allLayer = axlGetParam("paramLayerGroup:ETCH")->groupMembers
("TOP" "02_GND1" "03_SIG1" "04_GND2" "05_SIG2"
"06_GND3" "07_SIG3" "08_GND4" "09_PWR1" "10_PWR2"
"11_GND5" "12_SIG4" "13_GND6" "14_SIG5" "15_GND7"
"BOTTOM"
)
Skill > layerNum=3
3
Skill > layerName = nthelem(layerNum allLayer)
"03_SIG1"
Skill > etchlayer = strcat("ETCH/" layerName)
"ETCH/03_SIG1"
Skill > axlVisibleLayer(etchlayer t)
t
Skill > exit
t
Command >
SKILL Language User Guide: X:\Cadence\SPB_16.6\doc\sklanguserAllegro® User Guide: SKILL Reference: X:\Cadence\SPB_16.6\doc\algroskill
免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删