脚本宝典收集整理的这篇文章主要介绍了[ Skill ] 图形化组件在注册 User Trigger 时需要注意的事情,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
https://www.cnblogs.com/yeungchie/
使用 deRegUserTriggers
可以用来配置:当打开一个新窗口时,自动集成自定义的菜单、工具栏等等。
格式如下:
deRegUserTriggers(
t_viewType
[ s_appTrigger
[ s_menuTrigger
[ s_postInstallTrigger ] ] ]
) => t / nil
首先,viewType 在不同版本的 Virtuoso 可能存在差异,比如 maskLayoutGXL 高版本中可能已经取消。因此在注册前可以先判断一下当前类型是否可以获取到信息。
给不存在的 viewType 注册会报 Error 。
viewType = "maskLayoutGXL"
when( appInfo = deGetAppInfo( viewType )
; 判断 appInfo 为真再进行下一步操作。
)
第二步,再判断是否已经注册过,重复注册会报 Warning 。
上一步返回的 appInfo
是一个 DPL ,通过查看 userMenuTrigList
或 userPostInstallTrigList
可以判断相应的程序是否已经注册过。
上面两个 TrigList 返回的是一个已经注册的子程序的 symbol 名组成的 list 。
假设已经定义了一个用于自动集成工具栏的子程序 autoPlaceToolbar
:
unless( member( 'autoPlaceToolbar appInfo->userPostInstallTrigList )
; 当程序名不存在(未注册)的时候再执行注册
deRegUserTriggers( winType nil nil 'autoPlaceToolbar )
)
s_postInstallTrigger
位置。hiPlaceToolbar
之后需要多加一句 hiShowToolbar
。这是因为同一窗口在切换 viewType 时,可能会让 toolbar 隐藏。( 就挺无语的 ... )arg->window
,不要使用 hiGetCurrentWindow()
,某些情况下可能会导致 toolbar 集成到错误的窗口去。hiGetWindowToolbars
,判断 toolbar 是否已经存在。hiPlaceToolbar
和 deManageToolbar
不要同时使用,会冲突。下面是一个自动集成 toolbar的例子:
先写好了一个 toolbar 变量:
ycToolbar
procedure( ycAutoPlaceToolbar( @optional arg( list( nil 'window hiGetCurrentWindow())) "l" )
prog(( win toolbars )
boundp( 'ycToolbar ) || return()
win = arg->window || return()
toolbars = hiGetWindowToolbars( win )
unless( member( ycToolbar toolbars )
hiPlaceToolbar( win ycToolbar 'left )
)
hiShowToolbar( ycToolbar )
return( t )
)
); ycAutoPlaceToolbar
foreach( viewType list( "maskLayout" "maskLayoutXL" "maskLayoutGXL" )
let(( appInfo )
when( appInfo = deGetAppInfo( viewType )
unless( member( 'ycAutoPlaceToolbar appInfo->userPostInstallTrigList )
deRegUserTriggers( viewType nil nil 'ycAutoPlaceToolbar )
)
)
)
); RegTrigger
以上是脚本宝典为你收集整理的[ Skill ] 图形化组件在注册 User Trigger 时需要注意的事情全部内容,希望文章能够帮你解决[ Skill ] 图形化组件在注册 User Trigger 时需要注意的事情所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。