先用菜单编辑器制作一个你想d出的菜单,将主菜单项的可见选项去掉,但要给它一个名字,标题随便。其它子菜单项都要有名称,便于给它写代码。
假设主菜单项名称为"Caidan",然后输入以下代码:
PrivateSubForm_MouseDown(ButtonAsInteger,ShiftAsInteger,XAsSingle,YAsSingle)'如果在窗体上按下鼠标
IfButton=2Then'如果点击右键
PopupMenuCaidan'd出名为"Caidan"的菜单
EndIf
EndSub
如果要给d出菜单中的选项编代码,就要直接编写代码。
假设子菜单项的名称为"New"
PrivateSubNew_Click()
EndSub
这两行代码之间就是点击了名为"New"的选项之后的动作。
就是要先建立一个菜单。然后用popupmenu来d出这个菜单。当然最上级菜单设置成visible=false,这样这个d出菜单就是一个独立的专门的d出菜单了
VB实现窗口的d出式菜单
在Windows95、Windows98或NT的风格中,有按动鼠标器右键d出下拉菜单的 *** 作,在VB执行环境下,有一些控件本身具有d下拉菜单的功能,如TexTbox控件等,但大多数编辑类控件以及窗体本身却没有此功能,要在窗口中任意位置实现PopUpMenu(d出式菜单),可借助VB的菜单工具来实现。
首先,打开VB的“工具”菜单条,利用“菜单编辑器”为窗体生成一个菜单:
标题(Caption) 菜单条名(Name)
编辑 menuEdit
……复制 mnuCopy
……剪切 munCut
其次,将生成的menuEdit菜单设置为不可视。
Private Sub Form_Load()
Me.menuEdit.Visibe=False
′menuEdit菜单设置为不可视
End Sub
然后,利用MouseDown事件实现任意位置d出PopUpMenu,如下例:
本例中以RichTexBox控件为例,在其上面实现复制、剪切功能。
1.复制功能的实现。
Private Sub MnuCopy_Click()
Clipboar.Clear′将剪贴板清空
′将RichTexBox控件上选择上的内容复制到剪贴板
Clipboard.SetTextRichTexBox1.SelText
End Sub
2.剪切功能的实现。
Private Sub MnuCut_Click()
Clipboard.Clear ′将剪贴板清空
′将RichTextBox控件上选择了的内容复制到剪贴板
Clipboard.SetTextRichBox1.SelText
′将RichTexBox控件上选择了的内容删除
SendKeys〃{DELETE}〃,True
End Sub
3.在RichTexBox控件的MouseDown事件中实现任意位置d出PopUPMenu。
OPrivate Sub RichTexBox1_MouseDown(Button As Integer,Shift As Integer,x As Single,Y As Single)
Dim MnuFile AS Menu ′声明一个菜单类型的变量
Set munFile=Me.MenuEdit ′将MenuEdit赋给菜单变量
if Button=2 Then ′判断是否按动鼠标器右键
′判断RichTexBox控件上选择了的内容是否存在,决定复制、剪切菜单条是否可 *** 作。
If Len(RichTexBox.Text)=0 Or Len(RichTexBox.SelText)=0 Then
mnuCopy.Enabled=Flase ′复制菜单条不可 *** 作。
nmuCut.Enabled=False ′剪切菜单条不可 *** 作。
nmuCopy.Enabled=True ′复制菜单条可 *** 作。
nmuCut.Enabled=True ′剪切菜单条可 *** 作。
End IF
PopupMenu mnuFile ′d出PopUpMenu。
End If
End Sub
这样,在VB执行环境中, *** 作窗体上的RichTexBox控件,按动鼠标器右键就可d出下拉菜单,实现复制、剪切功能。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)