使用SOLIDWORKS API锁定工作表格式的宏
{ width=250 }
这个VBA宏允许使用SOLIDWORKS API禁用(或密码保护)SOLIDWORKS绘图中的工作表格式编辑。
当需要禁止用户修改标准工作表格式时,此宏非常有用。
通过更改以下常量,宏提供了两个可配置的选项:
Public Const LOCK_WITH_PASSWORD As Boolean = False
Public Const PASSWORD As String = ""
锁定编辑
将LOCK_WITH_PASSWORD的值设置为False。
每次调用编辑工作表格式命令并取消命令时,都会显示以下消息:
密码保护编辑
将LOCK_WITH_PASSWORD的值设置为True。将PASSWORD的值设置为目标密码。
建议对VBA宏进行密码保护,以便无法从宏本身查看密码。
每次调用编辑工作表格式命令时,都会显示以下提示:
如果密码匹配,则可以编辑工作表格式;否则,命令将被取消并显示错误消息。
创建宏
- 创建新的宏并粘贴宏模块中的代码
- 添加新的类模块并将其命名为SheetFormatEditorHandler。将下面的代码粘贴到类模块中。
- 添加新的用户窗体并将其命名为PasswordBox。将下面的代码粘贴到用户窗体代码中。
- 根据下图所示添加控件,并指定每个控件的名称。
- 将文本框控件的PasswordChar属性值设置为*,以在键入时隐藏用户界面中的密码。
文件树应该类似于下图。
按照在SOLIDWORKS启动时运行宏的说明设置宏在SOLIDWORKS启动时自动运行。
阻止其他命令
可以修改此宏以阻止其他命令。也可以更改它以同时处理多个命令。为此,需要修改以下行:
If Command = swCommands_Edit_Template Then
为
If Command = CmdId1 Or Command = CmdId2 ... Or Command = CmdId3 Then
例如,以下行将阻止编辑草图、打开SOLIDWORKS选项对话框和打印文档。有关如何提取SOLIDWORKS中特定命令的ID的说明,请参阅捕获命令宏。
If Command = 859 Or Command = 342 Or Command = 589 Then
宏模块
Public Const LOCK_WITH_PASSWORD As Boolean = True
Public Const PASSWORD As String = "admin"
Dim swSheetFormatEditorHandler As SheetFormatEditorHandler
Sub main()
Set swSheetFormatEditorHandler = New SheetFormatEditorHandler
End Sub
SheetFormatEditorHandler 类
Dim WithEvents swApp As SldWorks.SldWorks
Private Sub Class_Initialize()
Set swApp = Application.SldWorks
End Sub
Private Function swApp_CommandOpenPreNotify(ByVal Command As Long, ByVal UserCommand As Long) As Long
Const swCommands_Edit_Template As Long = 1501
If Command = swCommands_Edit_Template Then
Dim cancel As Boolean
cancel = True
If LOCK_WITH_PASSWORD Then
Dim pwd As String
PasswordBox.Message = "工作表格式编辑已锁定。请输入密码以解锁"
PasswordBox.ShowDialog
pwd = PasswordBox.Password
If pwd <> "" Then
If pwd = Password Then
cancel = False
Else
swApp.SendMsgToUser2 "密码不正确", swMessageBoxIcon_e.swMbStop, swMessageBoxBtn_e.swMbOk
End If
End If
Else
swApp.SendMsgToUser2 "工作表格式编辑已锁定", swMessageBoxIcon_e.swMbInformation, swMessageBoxBtn_e.swMbOk
End If
swApp_CommandOpenPreNotify = IIf(cancel, 1, 0)
End If
End Function
PasswordBox 用户窗体
Public Password As String
Public Property Let Message(msg As String)
lblMessage.Caption = msg
End Property
Public Sub ShowDialog()
Password = ""
txtPassword.Text = ""
Show vbModal
End Sub
Private Sub btnOk_Click()
Password = txtPassword.Text
Me.Hide
End Sub