如何利用 VB6 Addin 动态生成菜单

使用 addin 程序可以加快我们的开发速度

以下几个例子,是我个人在平常工作中常用到

 

1.统一改变窗体的控件字体及字体大小

 

  Set objCom = VBInstance.SelectedVBComponent
 
  If (objCom.Type <> vbext_ct_VBForm) And _
     (objCom.Type <> vbext_ct_UserControl) And _
     (objCom.Type <> vbext_ct_DocObject) And _
     (objCom.Type <> vbext_ct_PropPage) Then
    Exit Sub
  End If
 
  For Each objCtrl In objCom.Designer.VBControls
    objCtrl.ControlObject.FontName = Me.cboFont.Text
    objCtrl.ControlObject.FontSize = Val(Me.cboFontSize.Text)
   
    objCtrl.ControlObject.Font.Name = Me.cboFont.Text
    objCtrl.ControlObject.Font.Size = Val(Me.cboFontSize.Text)

    objCtrl.Properties("FontName").Value = Me.cboFont.Text
    objCtrl.Properties("FontSize").Value = Val(Me.cboFontSize.Text)
   
  Next

 

2. 根据数据库设置,动态生成菜单

 

Private Sub CreateMenu(ByVal prsData As ADODB.Recordset, ByVal pobjCom As VBComponent, pobjParent As VBControl, ByVal pstrParentid As String)
  Dim rs        As ADODB.Recordset
  Dim objCtrls  As VBControls
  Dim objCtrl   As VBControl
  Dim strMenuid As String
  Dim strCap    As String
  Dim i         As Integer
  Dim intIdx    As Integer
 
  On Error GoTo ERROR_LABEL
 
  intIdx = 0
  Set rs = prsData.Clone
  rs.Filter = "parentid='" & pstrParentid & "'"
  If rs.RecordCount > 0 Then
'    MsgBox rs.RecordCount
    rs.Sort = "functionindex"
    For i = 1 To rs.RecordCount
     
      strMenuid = Trim(rs.Collect("menuid") & "")
      strCap = Trim(rs.Collect("menuname") & "")
     
      If pobjParent Is Nothing Then
        Set objCtrls = pobjCom.Designer.VBControls
        Set objCtrl = objCtrls.Add("VB.Menu")
      Else
        Set objCtrl = pobjParent.ContainedVBControls.Add("VB.Menu", pobjParent)
      End If
      objCtrl.Properties!Index = Val(rs.Collect("functionindex") & "")
      objCtrl.Properties!Name = rs.Collect("functionname") & ""
     
      If StrComp(strCap, "-", vbTextCompare) <> 0 Then
        If Len(Trim(rs.Collect("shortcut") & "")) > 0 Then
          strCap = strCap & "(" & rs.Collect("shortcut") & "" & ")"
        Else
          intIdx = intIdx + 1
          If intIdx > 9 Then
            strCap = "&" & Chr(64 + intIdx - 9) & ". " & strCap
          Else
            strCap = "&" & CStr(intIdx) & ". " & strCap
          End If
        End If
        objCtrl.Properties!Caption = strCap
      Else
        objCtrl.Properties!Caption = strCap
      End If
      If HasChildMenu(prsData, strMenuid) Then
        Call CreateMenu(prsData, pobjCom, objCtrl, strMenuid)
      End If
      rs.MoveNext
    Next i
  End If
ERROR_LABEL:
  If Err.Number <> 0 Then
'    MsgBox "CreateMenu->" & Err.Description
    Err.Clear
    Resume Next
  End If
End Sub

转载于:https://www.cnblogs.com/betterfar/archive/2010/10/28/1863255.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值