精华区 [关闭][返回]

当前位置:网易精华区>>讨论区精华>>编程开发>>● VB和Basic>>● VB和Basic(1)>>文章连载>>VB邮件>>免费vb邮件(5.16全文)

主题:免费vb邮件(5.16全文)
发信人: msnet()
整理人: cobe(1999-12-17 12:44:35), 站内信件
                      编者的话
=========================
大家好!
    VB邮件在各位网友的热情支持与关心下正在茁壮成长,
为了使这一邮件列表办得更好,我们期侍各位能热情投稿,
稿件可以涉及与VB、ASP有关的内容。
    如果你有好的作品或你发现了好的作品,不要忘了让
大家共享。
                                版主   冯德平
                                [email protected]
=================================================

              vb邮件(5.16)
=========================
a 启动时禁止装入Add-Ins 
 
启动VB时, Add-Ins 将加载。如果Add-Ins中有错误的话,
每次都可能产生错误。 为了启动时禁止装入 Add-Ins, 
在启动VB前,编辑 Windows 目录中的 VBAddin.INI 文件。
找到以下的语句: AppWizard.Wizard=1 将 1 改为 0。 

b VB经验技巧(一)
 
记载Windows使用的时间
 怎样关闭一个正在运行的程序
 我怎样确定我的程序是否在运行?
 
怎样延迟一个VB程序?
 怎样改变双击鼠标的时间间隔?
 怎样找到鼠标指针的XY坐标?
 
怎样捕捉窗体的鼠标?
 怎样使我的程序总处于屏幕最前方?(Always on top)
 怎样得到文本框(TextBox)中的文本行数?
 
怎样使程序的标题条闪烁?
 
 
 
 
在程序设计中,我们经常遇见这样或那样的问题,即使是“身经百战”的编程老

手,对于一些过于具体、细微的问题有时也会不知所措,以下是我从外文网站上

摘取的一些VB经验技巧,并对它们进行的翻译整理,希望对你会有所帮助,有疏

漏之处请大家指正,谢谢!


----------------------------------------------------------------------

----------

记载Windows使用的时间

有时候你需要记下每次Windows开启和关闭的时间,下面这个小程序就可以完成这

个功能,你可以把它放在Windows开始菜单的“启动”文件夹里面,这样当你进入

Windows时,这个小程序就会自动启动(不可见),并在你指定的文件中写下当时

的时间,在你推出Windows系统时,小程序会关闭并记下离开的时间,并关闭记录

文件。

Private Sub Form_Load()

Left = -10000

Top = -10000

Open "c:\apps\log.txt" For Append As #1

Print #1, "On: " & CStr(Now)

Close #1

End Sub

Private Sub Form_Unload(Cancel As Integer)

Open "c:\apps\log.txt" For Append As #1

Print #1, "Off:" & CStr(Now)

Close #1

End

End Sub


----------------------------------------------------------------------

----------

怎样关闭一个正在运行的程序

 

你可以使用API函数FindWindow和PostMessage去寻找指定的窗口,并关闭它。下

面的例子教给你怎样找到并关掉一个Caption为“Caluclator”的程序。

 

Dim winHwnd As Long

Dim RetVal As Long

winHwnd = FindWindow(vbNullString, "Calculator")

Debug.Print winHwnd

If winHwnd <> 0 Then

RetVal = PostMessage(winHwnd, WM_CLOSE, 0&, 0&)

If RetVal = 0 Then

MsgBox "置入消息错误!"

End If

Else

MsgBox "Calculator没有打开!"

End If

 

为了让以上的代码工作,你必须在模块文件中什么以下API函数:

 

Declare Function FindWindow Lib "user32" Alias _

"FindWindowA" (ByVal lpClassName As String, _

ByVal lpWindowName As String) As Long 

Declare Function PostMessage Lib "user32" Alias _

"PostMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, _

ByVal wParam As Long, lParam As Any) As Long 

Public Const WM_CLOSE = &H10


----------------------------------------------------------------------

----------

我怎样确定我的程序是否在运行?

 

把以下代码放在第一个窗体的Form_Load事件中:

 

If App.PrevInstance = True Then

Call MsgBox("这个程序正在运行!",_

vbExclamation)

End

End If


----------------------------------------------------------------------

----------

怎样延迟一个VB程序?

 

延迟在VB中非常有意义!举个例子,有时你需要等待一个额外的过程完成,才能

运行程序下面的代码。延迟使程序摆脱了CPU的运算速度对程序运行速度的影响,

但是在VB中却没有延迟这个很多语言都有的现成函数,所以还要依靠API函数,请

看以下的代码:

 

Declare Sub Sleep Lib "kernel32" _

(ByVal dwMilliseconds As Long)

 

'延迟1秒

Call Sleep(1000)


----------------------------------------------------------------------

----------

怎样改变双击鼠标的时间间隔?

 

在较短时间里连续的点击两次鼠标就会造成鼠标双击事件。你可以调用API函数S

etDoubleClickTime改变鼠标双击所需要的时间,它只有一个参数,并可精确到毫

秒级。

 

Declare Function SetDoubleClickTime _

Lib "user32" Alias "SetDoubleClickTime" _

(ByVal wCount As Long) As Long 

 

提示:这种改变将影响到整个操作系统。


----------------------------------------------------------------------

----------

怎样找到鼠标指针的XY坐标?

 

在很多的作图软件中都有一个小的区域显示当前屏幕上的光标位置,这利用API函

数非常容易做到,下面的例子将演示使用代码如何返回当前光标的XY的坐标值。



 

步骤:

在VB5中建立一个新项目文件,Form1使用默认设置.

选择菜单的“Project/add Module”,建立一个新的模块文件“Moudule1”。

输入以下代码声明API函数。

Option Explicit

Type POINTAPI ' Declare types

x As Long

y As Long

End Type

Declare Function GetCursorPos Lib "user32" _

(lpPoint As POINTAPI) As Long ' Declare API 

把焦点移到Form1,添加两个标签对象(Label)和一个计时器对象(Timer1),

把计时器的Interval属性设为1,然后双击Form1的任何区域,在代码窗口中输入



 

 

Option Explicit

Dim z As POINTAPI ' 声明变量

 

Private Sub Timer1_Timer()

GetCursorPos z ' 得到坐标

Label1 = "x: " & z.x ' 得到X坐标

Label2 = "y: " & z.y ' 得到Y坐标

End Sub 

 

5、按F5运行程序,移动鼠标注意观察两个标签对象的变化。


----------------------------------------------------------------------

----------

怎样捕捉窗体的鼠标?

 

这个技巧将向您展示如何使用捕捉光标的API函数阻止鼠标指针移出窗体。

 

注意!:如果窗体的BorderStyle属性被设为sizeable(2或5),则当你改变窗体

的大小时鼠标就会“逃脱”程序的监控!因此你最好把BorderStyle设为0、1、3

或4。

 

步骤:

 

把以下代码添加如模块:

 

Option Explicit 

Type RECT

Left As Long

Top As Long

Right As Long

Bottom As Long

End Type 

Declare Function ClipCursor Lib "user32" _

(lpRect As Any) As Long

 

Public Sub DisableTrap(CurForm As Form)

Dim erg As Long

'声明过程变量

'设置新坐标

Dim NewRect As RECT

CurForm.Caption = "释放鼠标"

With NewRect

.Left = 0&

.Top = 0&

.Right = Screen.Width / Screen.TwipsPerPixelX

.Bottom = Screen.Height / Screen.TwipsPerPixelY

End With

erg& = ClipCursor(NewRect)

End Sub 

Public Sub EnableTrap(CurForm As Form)

Dim x As Long, y As Long, erg As Long

'声明过程变量

'设置新坐标

Dim NewRect As RECT

'得到TwipsperPixel

'窗体的ScaleMode必须设为Twips!!!

x& = Screen.TwipsPerPixelX

y& = Screen.TwipsPerPixelY

CurForm.Caption = "捕捉鼠标"

'设置光标的范围

With NewRect

.Left = CurForm.Left / x&

.Top = CurForm.Top / y&

.Right = .Left + CurForm.Width / x&

.Bottom = .Top + CurForm.Height / y&

End With

erg& = ClipCursor(NewRect)

End Sub 

 

2、在窗体上添加两个命令按钮(Command Button)。

 

3、把以下代码添加如Form1。

Private Sub Command1_Click()

EnableTrap Form1

End Sub 

Private Sub Command2_Click()

DisableTrap Form1

End Sub 

Private Sub Form_Unload(Cancel As Integer)

'程序结束时释放鼠标。

DisableTrap Form1

End Sub


----------------------------------------------------------------------

----------

怎样使我的程序总处于屏幕最前方?(Always on top)

 

如果你想让你的程序处于前方,可以使用以下代码:

 

Form1.ZOrder 

 

配合计时器使用,每隔一段很小的时间间隔调用这种方法可以使窗体Form1处于屏

幕前方,但是用户还是可能使别的窗体在短暂的时间里处于Form1的上方。所以这

种方法并不能使窗体真正的实现Always on top,而要真正的Always on top可以

使用API函数SetWindowPos,代码如下:

 

'声明函数: 

Declare Function SetWindowPos Lib "user32" _

(ByVal h%, ByVal hb%, ByVal x%, ByVal y%, _

ByVal cx%,ByVal cy%,ByVal f%) As Integer 

Global Const SWP_NOMOVE = 2 

Global Const SWP_NOSIZE = 1 

Global Const FLAGS = SWP_NOMOVE Or SWP_NOSIZE 

Global Const HWND_TOPMOST = -1 

Global Const HWND_NOTOPMOST = -2 

'把窗体放在最前面: 

 

res% = SetWindowPos (Form1.hWnd, HWND_TOPMOST, _

0, 0, 0, 0, FLAGS) 

'如果res%=0, 就产生错误 

 

'使窗体恢复普通模式:

res% = SetWindowPos (Form1.hWnd, HWND_NOTOPMOST, _

0, 0, 0, 0, FLAGS)


----------------------------------------------------------------------

----------

怎样得到文本框(TextBox)中的文本行数?

 

计算文本框中输入文本的行数可以使用SendMessage函数返回,当一行文字发生环

绕时,它将被当作新的一行,而被非简单的计算文本中的换行符个数。

 

把以下API函数的声明添入模块文件的general declarations区域,如果您使用的

是VB4-32或VB5,也可以把此声明添入Form1的general declarations中,并把所

有的“Public”更换为“Private”。

 

Option Explicit

 

Public Declare Function SendMessageLong Lib _

"user32" Alias "SendMessageA" _

(ByVal hwnd As Long, _ 

ByVal wMsg As Long, _ 

ByVal wParam As Long, _

ByVal lParam As Long) As Long

 

Public Const EM_GETLINECOUNT = &HBA 

Form Code

Sub Text1_Change()

Dim lineCount as Long

On Local Error Resume Next

 

'得到/显示文本行数

lineCount = SendMessageLong(Text1.hwnd, EM_GETLINECOUNT, 0&, 0&)

Label1 = Format$(lineCount, "##,###")

End Sub 

 

注释:

为了使本程序成功,请在设计阶段把文本框的Multiline属性设为True。


----------------------------------------------------------------------

----------

怎样使程序的标题条闪烁?

 

建立新的项目文件,添加模块文件,并填写如下代码:

 

Public Declare Function FlashWindow _

Lib "user32" (ByVal hwnd As Long, _

ByVal bInvert As Long) As Long

 

在窗体中添加两个按钮和一个计时器,并用设置以下属性:

 

command1.caption="开始"

command2.caption="停止"

timer1.interval=500 '每0.5秒闪烁一次

timer1.enabled=false

 

Private Sub Timer1_Timer()

a& = FlashWindow(Me.hwnd, 1)

End Sub

 

Private Sub Command1_Click()

Timer1.Enabled = True

End Sub

 

Private Sub Command2_Click()

Timer1.Enabled = False

End Sub

 

按F5运行程序。
 
HandsomeMen 推荐  

=============================================
欢迎投稿  [email protected]
主    页  goodvbhome.yeah.net
=============================================
订阅请到如下地址:
http://server.com/WebApps/mail-list-subscribe.cgi?id=16852
=============================================


----------------------------------------------------------------------
----------

记载Windows使用的时间

有时候你需要记下每次Windows开启和关闭的时间,下面这个小程序就可以完成这
个功能,你可以把它放在Windows开始菜单的“启动”文件夹里面,这样当你进入
Windows时,这个小程序就会自动启动(不可见),并在你指定的文件中写下当时
的时间,在你推出Windows系统时,小程序会关闭并记下离开的时间,并关闭记录
文件。

Private Sub Form_Load()

Left = -10000

Top = -10000

Open "c:\apps\log.txt" For Append As #1

Print #1, "On: " & CStr(Now)

Close #1

End Sub

Private Sub Form_Unload(Cancel As Integer)

Open "c:\apps\log.txt" For Append As #1

Print #1, "Off:" & CStr(Now)

Close #1

End

End Sub


----------------------------------------------------------------------
----------

怎样关闭一个正在运行的程序

 

你可以使用API函数FindWindow和PostMessage去寻找指定的窗口,并关闭它。下
面的例子教给你怎样找到并关掉一个Caption为“Caluclator”的程序。

 

Dim winHwnd As Long

Dim RetVal As Long

winHwnd = FindWindow(vbNullString, "Calculator")

Debug.Print winHwnd

If winHwnd <> 0 Then

RetVal = PostMessage(winHwnd, WM_CLOSE, 0&, 0&)

If RetVal = 0 Then

MsgBox "置入消息错误!"

End If

Else

MsgBox "Calculator没有打开!"

End If

 

为了让以上的代码工作,你必须在模块文件中什么以下API函数:

 

Declare Function FindWindow Lib "user32" Alias _

"FindWindowA" (ByVal lpClassName As String, _

ByVal lpWindowName As String) As Long 

Declare Function PostMessage Lib "user32" Alias _

"PostMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, _

ByVal wParam As Long, lParam As Any) As Long 

Public Const WM_CLOSE = &H10


----------------------------------------------------------------------
----------

我怎样确定我的程序是否在运行?

 

把以下代码放在第一个窗体的Form_Load事件中:

 

If App.PrevInstance = True Then

Call MsgBox("这个程序正在运行!",_

vbExclamation)

End

End If


----------------------------------------------------------------------
----------

怎样延迟一个VB程序?

 

延迟在VB中非常有意义!举个例子,有时你需要等待一个额外的过程完成,才能
运行程序下面的代码。延迟使程序摆脱了CPU的运算速度对程序运行速度的影响,
但是在VB中却没有延迟这个很多语言都有的现成函数,所以还要依靠API函数,请
看以下的代码:

 

Declare Sub Sleep Lib "kernel32" _

(ByVal dwMilliseconds As Long)

 

'延迟1秒

Call Sleep(1000)


----------------------------------------------------------------------
----------

怎样改变双击鼠标的时间间隔?

 

在较短时间里连续的点击两次鼠标就会造成鼠标双击事件。你可以调用API函数S
etDoubleClickTime改变鼠标双击所需要的时间,它只有一个参数,并可精确到毫
秒级。

 

Declare Function SetDoubleClickTime _

Lib "user32" Alias "SetDoubleClickTime" _

(ByVal wCount As Long) As Long 

 

提示:这种改变将影响到整个操作系统。


----------------------------------------------------------------------
----------

怎样找到鼠标指针的XY坐标?

 

在很多的作图软件中都有一个小的区域显示当前屏幕上的光标位置,这利用API函
数非常容易做到,下面的例子将演示使用代码如何返回当前光标的XY的坐标值。


 

步骤:

在VB5中建立一个新项目文件,Form1使用默认设置.

选择菜单的“Project/add Module”,建立一个新的模块文件“Moudule1”。

输入以下代码声明API函数。

Option Explicit

Type POINTAPI ' Declare types

x As Long

y As Long

End Type

Declare Function GetCursorPos Lib "user32" _

(lpPoint As POINTAPI) As Long ' Declare API 

把焦点移到Form1,添加两个标签对象(Label)和一个计时器对象(Timer1),
把计时器的Interval属性设为1,然后双击Form1的任何区域,在代码窗口中输入


 

 

Option Explicit

Dim z As POINTAPI ' 声明变量

 

Private Sub Timer1_Timer()

GetCursorPos z ' 得到坐标

Label1 = "x: " & z.x ' 得到X坐标

Label2 = "y: " & z.y ' 得到Y坐标

End Sub 

 

5、按F5运行程序,移动鼠标注意观察两个标签对象的变化。


----------------------------------------------------------------------
----------

怎样捕捉窗体的鼠标?

 

这个技巧将向您展示如何使用捕捉光标的API函数阻止鼠标指针移出窗体。

 

注意!:如果窗体的BorderStyle属性被设为sizeable(2或5),则当你改变窗体
的大小时鼠标就会“逃脱”程序的监控!因此你最好把BorderStyle设为0、1、3
或4。

 

步骤:

 

把以下代码添加如模块:

 

Option Explicit 

Type RECT

Left As Long

Top As Long

Right As Long

Bottom As Long

End Type 

Declare Function ClipCursor Lib "user32" _

(lpRect As Any) As Long

 

Public Sub DisableTrap(CurForm As Form)

Dim erg As Long

'声明过程变量

'设置新坐标

Dim NewRect As RECT

CurForm.Caption = "释放鼠标"

With NewRect

.Left = 0&

.Top = 0&

.Right = Screen.Width / Screen.TwipsPerPixelX

.Bottom = Screen.Height / Screen.TwipsPerPixelY

End With

erg& = ClipCursor(NewRect)

End Sub 

Public Sub EnableTrap(CurForm As Form)

Dim x As Long, y As Long, erg As Long

'声明过程变量

'设置新坐标

Dim NewRect As RECT

'得到TwipsperPixel

'窗体的ScaleMode必须设为Twips!!!

x& = Screen.TwipsPerPixelX

y& = Screen.TwipsPerPixelY

CurForm.Caption = "捕捉鼠标"

'设置光标的范围

With NewRect

.Left = CurForm.Left / x&

.Top = CurForm.Top / y&

.Right = .Left + CurForm.Width / x&

.Bottom = .Top + CurForm.Height / y&

End With

erg& = ClipCursor(NewRect)

End Sub 

 

2、在窗体上添加两个命令按钮(Command Button)。

 

3、把以下代码添加如Form1。

Private Sub Command1_Click()

EnableTrap Form1

End Sub 

Private Sub Command2_Click()

DisableTrap Form1

End Sub 

Private Sub Form_Unload(Cancel As Integer)

'程序结束时释放鼠标。

DisableTrap Form1

End Sub


----------------------------------------------------------------------
----------

怎样使我的程序总处于屏幕最前方?(Always on top)

 

如果你想让你的程序处于前方,可以使用以下代码:

 

Form1.ZOrder 

 

配合计时器使用,每隔一段很小的时间间隔调用这种方法可以使窗体Form1处于屏
幕前方,但是用户还是可能使别的窗体在短暂的时间里处于Form1的上方。所以这
种方法并不能使窗体真正的实现Always on top,而要真正的Always on top可以
使用API函数SetWindowPos,代码如下:

 

'声明函数: 

Declare Function SetWindowPos Lib "user32" _

(ByVal h%, ByVal hb%, ByVal x%, ByVal y%, _

ByVal cx%,ByVal cy%,ByVal f%) As Integer 

Global Const SWP_NOMOVE = 2 

Global Const SWP_NOSIZE = 1 

Global Const FLAGS = SWP_NOMOVE Or SWP_NOSIZE 

Global Const HWND_TOPMOST = -1 

Global Const HWND_NOTOPMOST = -2 

'把窗体放在最前面: 

 

res% = SetWindowPos (Form1.hWnd, HWND_TOPMOST, _

0, 0, 0, 0, FLAGS) 

'如果res%=0, 就产生错误 

 

'使窗体恢复普通模式:

res% = SetWindowPos (Form1.hWnd, HWND_NOTOPMOST, _

0, 0, 0, 0, FLAGS)


----------------------------------------------------------------------
----------

怎样得到文本框(TextBox)中的文本行数?

 

计算文本框中输入文本的行数可以使用SendMessage函数返回,当一行文字发生环
绕时,它将被当作新的一行,而被非简单的计算文本中的换行符个数。

 

把以下API函数的声明添入模块文件的general declarations区域,如果您使用的
是VB4-32或VB5,也可以把此声明添入Form1的general declarations中,并把所
有的“Public”更换为“Private”。

 

Option Explicit

 

Public Declare Function SendMessageLong Lib _

"user32" Alias "SendMessageA" _

(ByVal hwnd As Long, _ 

ByVal wMsg As Long, _ 

ByVal wParam As Long, _

ByVal lParam As Long) As Long

 

Public Const EM_GETLINECOUNT = &HBA 

Form Code

Sub Text1_Change()

Dim lineCount as Long

On Local Error Resume Next

 

'得到/显示文本行数

lineCount = SendMessageLong(Text1.hwnd, EM_GETLINECOUNT, 0&, 0&)

Label1 = Format$(lineCount, "##,###")

End Sub 

 

注释:

为了使本程序成功,请在设计阶段把文本框的Multiline属性设为True。


----------------------------------------------------------------------
----------

怎样使程序的标题条闪烁?

 

建立新的项目文件,添加模块文件,并填写如下代码:

 

Public Declare Function FlashWindow _

Lib "user32" (ByVal hwnd As Long, _

ByVal bInvert As Long) As Long

 

在窗体中添加两个按钮和一个计时器,并用设置以下属性:

 

command1.caption="开始"

command2.caption="停止"

timer1.interval=500 '每0.5秒闪烁一次

timer1.enabled=false

 

Private Sub Timer1_Timer()

a& = FlashWindow(Me.hwnd, 1)

End Sub

 

Private Sub Command1_Click()

Timer1.Enabled = True

End Sub

 

Private Sub Command2_Click()

Timer1.Enabled = False

End Sub

 

按F5运行程序。
 
HandsomeMen 推荐  

=============================================
欢迎投稿  [email protected]
主    页  goodvbhome.yeah.net
=============================================
订阅请到如下地址:
http://server.com/WebApps/mail-list-subscribe.cgi?id=16852
=============================================

--
网站主页地址:http://home.hn.cninfo.net/home/msnet
网易上的主页地址:http://www4.netease.com/~aaaaaaaaa
本网站主页镜像地址:http://goodvbhome.yeah.net

※ 修改:.msnet 于 May 16 10:50:23 修改本文.[FROM: 202.103.46.92]
※ 来源:.月光软件站 http://www.moon-soft.com.[FROM: 202.103.46.92]

[关闭][返回]