如何利用 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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值