*这是原来从网上搜集、整理后编制用于自己的小程序使用的OCX是否注册及未注册控件的自动注册函数。
CheckCtrlFileRegist("ctToolBar.ctToolBarCtrl.4")
&& 检测与注册DBI工具条控件(ctToolBar)
****************************** 控件注册函数
Function CheckCtrlFileRegist
Parameters lcCheck
&& 调用形如:CheckCtrlFileRegist("ctGrid.ctGridCtrl.3")
&& 其中,经常用到的控件如下:
&& MS日期控件 MSComCt2.OCX 版本2-("MSComCtl2.DTPicker.2")(MS Date and Time Picker Control 6.0 (SP4))
&& 视频头控件 AVCap.OCX 版本1-("AVCap.AVCapture.1")
&& DBI表格控件 ctGrid.OCX 版本3-("ctGrid.ctGridCtrl.3"),版本1-("ctGrid.ctGridCtrl.1")
&& DBI下拉框控件 ctCombo.OCX 版本2-("ctCoLorCombo.ctColorComboCtrl.2")
&& DBI工具条控件 ctToolBar.OCX 版本4-("ctToolBar.ctToolBarCtrl.4")
&& DBI树形控件 ctTree.OCX 版本7-("ctTree.ctTreeView.7")
Local oErr As Exception, oErrExit As Exception
Local lcCtrlFile As Character, lcCtrl As Character, lcRun As Character
Local oCtrl As Object, oShell As Object
Local lcMess As Character
lcMess=''
lcCtrl=SubStr(lcCheck,1,At('.',lcCheck,1)-1)
Try
oCtrl=CreateObject(lcCheck)
Catch To oErr
oErr.UserValue="发现OCX控件["+lcCtrl+"]未注册!"
=MessageBox(oErr.UserValue,0+64,'提示!')
Do While .T.
lcCtrlFile=GetFile('OCX','输入文件名:','确定',0,'选择需要操作的文件')
If Not File(lcCtrlFile,1) OR Empty(lcCtrlFile) Then
lcMess='程序所必要的控件文件'+Iif(Empty(lcCtrlFile),'','['+lcCtrlFile+']')+'不存在!继续注册么?'
If 6=MessageBox(lcMess,4+32+256,'系统提示!') Then
Loop
Else
Quit
Endif
Endif
oShell=CreateObject('Wscript.shell')
lcRun="Regsvr32 /S "+lcCtrlFile
If oShell.Run('&lcRun',0,.T.) != 0 Then && 隐藏窗口运行并返回错误代码(不为0,运行出错,注册失败)
lcMess='选定的控件文件'+lcCtrlFile+'不包含控件'+lcCtrl+', 注册失败!继续注册么?'
If 6=Messagebox(lcMess, 4+32+256, '信息提示') Then
Loop
Else
Quit
Endif
Endif
Try
oCtrl=CreateObject(lcCheck)
Catch To oErrExit
oErrExit.UserValue = "OCX控件["+lcCtrl+"]未注册成功 或 与要求版本不符合!"
=MessageBox(oErrExit.UserValue,0+64,'提示!')
Quit
Finally
EndTry
lcMess='控件['+lcCtrl+']注册成功!'
=MessageBox(lcMess, 0+64, '系统提示!',5000)
Exit
EndDo
Finally
Release oErr, oErrExit, lcCtrlFile, lcCtrl, lcRun, oCtrl, oShell, lcMess
EndTry
EndFunc