![]() |
|
||||||||||||||
| | 网站首页 | 数据库教程 | web编程 | 服务器 | 程序设计 | | ||
|
||
|
|||||||||||||||||||||||||||||||||
| vb打造超酷个性化菜单(一) | |||||||||||||||||||||||||||||||||
作者:佚名 文章来源:不详 点击数: 更新时间:2007-7-1 ![]() |
|||||||||||||||||||||||||||||||||
|
VB打造超酷个性化菜单(一) 众所周知,MS Office 2003推出已经有一段时间了,但我们依然不会忘记Office XP刚刚推出时其令人耳目一新的菜单给我们留下的深刻印象。 现在,我想有必要说一说我们现在要做的事情。事实上,我们只要做一个菜单类就行了。但谁都会明白,只做一个菜单类是不够的,我们需要一个程序,或者更详细的说,是一个窗体,来测试我们的菜单类。在我个人的开发过程中,我是先写的菜单类,后写的测试窗体,但为了让大家先领略一下写好的菜单类在应用时是多么的方便,所以让我们先来看看测试窗体: (1)打开VB,新建“标准EXE”工程。 (2)下面是窗体的控件:
其实就是在窗体上添加了一个Frame,然后在Frame里添加OptionButton控件数组,用来设置菜单风格,还有一个Label,上面只显示一行提示文字,非常简单。 (3)窗体代码:
Option Explicit Private Declare Function GetCursorPos Lib "user32.dll" (lpPoint As POINTAPI) As Long Private Type POINTAPI X As Long Y As Long End Type Dim menu As cMenu Private Sub Form_Load() ' 初始化菜单并添加菜单项 Set menu = New cMenu menu.CreateMenu menu.AddItem "open", LoadPicture("images\open.ico"), "打开", MIT_STRING menu.AddItem "save", LoadPicture("images\save.ico"), "保存", MIT_STRING menu.AddItem "print", LoadPicture("images\print.ico"), "打印", MIT_STRING menu.AddItem "find", LoadPicture("images\find.ico"), "查找", MIT_STRING menu.AddItem "sep1", LoadPicture(), "", MIT_SEPARATOR menu.AddItem "undo", LoadPicture("images\undo.ico"), "撤消", MIT_STRING menu.AddItem "redo", LoadPicture("images\redo.ico"), "重复", MIT_STRING menu.AddItem "sep2", LoadPicture(), "", MIT_SEPARATOR menu.AddItem "cut", LoadPicture("images\cut.ico"), "剪切", MIT_STRING menu.AddItem "copy", LoadPicture("images\copy.ico"), "复制", MIT_STRING menu.AddItem "paste", LoadPicture("images\paste.ico"), "粘贴", MIT_STRING menu.AddItem "sep3", LoadPicture(), "", MIT_SEPARATOR menu.AddItem "check", LoadPicture("images\check.ico"), "一个 CheckBox", MIT_CHECKBOX menu.AddItem "exit", LoadPicture("images\exit.ico"), "退出", MIT_STRING End Sub Private Sub Form_MouseDown(Button As Integer, Shift As Integer, X As Single, Y As Single) ' 单击鼠标右建弹出菜单 If Button = vbRightButton Then Dim pos As POINTAPI GetCursorPos pos menu.PopupMenu pos.X, pos.Y, POPUP_LEFTALIGN Or POPUP_TOPALIGN End If End Sub Private Sub Form_Unload(Cancel As Integer) ' 释放资源, 卸载窗体 Set menu = Nothing Dim frm As Form For Each frm In Forms Unload frm Next End Sub Private Sub opnStyle_Click(Index As Integer) ' 设置菜单风格 Select Case Index Case 0 ' Windows 标准 menu.Style = STYLE_WINDOWS Case 1 ' XP 风格 menu.Style = STYLE_XP Case 2 ' 3D 立体风格 menu.Style = STYLE_3D Case 3 ' 渐变风格 menu.Style = STYLE_SHADE Case 4 ' 多彩风格 menu.Style = STYLE_COLORFUL End Select End Sub 代码中创建了一个cMenu类的对象,我们的编程重点将会放在cMenu类上,上面的代码只是简单地调用cMenu。在后面的文章中,我们会看到其实cMenu有多达30个方法和属性供我们调用,它的Style属性只提供了5种内置风格,在实际应用中,我们可以利用cMenu类提供的方法和属性制作出各种各样风格的菜单,为自己的程序锦上添花。 (4)运行结果:
这篇文章只是抛砖引玉,让大家先睹为快,提前体验一下这个菜单类的魅力。在下一篇中,我们将继续讨论个性化菜单的制作,不一样的是,我们的重点将是那个cMenu类。 :)
(待续)
相关链接: VB打造超酷个性化菜单(一) VB打造超酷个性化菜单(二) VB打造超酷个性化菜单(三) VB打造超酷个性化菜单(四) VB打造超酷个性化菜单(五) VB打造超酷个性化菜单(六)
|
|||||||||||||||||||||||||||||||||
| 文章录入:admin 责任编辑:admin | |||||||||||||||||||||||||||||||||
| 【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】 | |||||||||||||||||||||||||||||||||
| 网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!) |
| | 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明 | 网站公告 | 网站地图 | 管理登录 | | |||
|