vb.net当中如何才能使用mscomm32.ocx和MSWINSCK.OCX?

kw123 2005-08-05 10:29:08
为什么我增加MSCOMM32.OCX的时候,系统提示:不兼容....,无法增加?

我怎样才能使用MSCOMM32.OCX组件呢?

同样,如何才能在VS。NET中使用串口控件!!!
...全文
443 14 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
vb_vs 2005-09-15
  • 打赏
  • 举报
回复
呵呵,
把安装盘下的Extras\VB6 Controls
的注册表文件添加一下看看,
njhyh 2005-09-14
  • 打赏
  • 举报
回复
在解决方案中:打开引用-->点击右键--〉添加引用--〉加入Interop.MSCommLib.dll动态库,然后就可以了。
xiaolang88 2005-09-14
  • 打赏
  • 举报
回复
#Region "Properties"

' This property gets or sets the BaudRate
Public Property BaudRate() As Integer
Get
Return miBaudRate
End Get
Set(ByVal Value As Integer)
miBaudRate = Value
End Set
End Property

' This property gets or sets the BufferSize
Public Property BufferSize() As Integer
Get
Return miBufferSize
End Get
Set(ByVal Value As Integer)
miBufferSize = Value
End Set
End Property

' This property gets or sets the DataBit.
Public Property DataBit() As Integer
Get
Return miDataBit
End Get
Set(ByVal Value As Integer)
miDataBit = Value
End Set
End Property

' This write-only property sets or resets the DTR line.
Public WriteOnly Property Dtr() As Boolean
Set(ByVal Value As Boolean)
If Not mhRS = -1 Then
If Value Then
EscapeCommFunction(mhRS, Lines.SetDtr)
Else
EscapeCommFunction(mhRS, Lines.ClearDtr)
End If
End If
End Set
End Property

' This read-only property returns an array of bytes that represents
' the input coming into the Comm Port.
Overridable ReadOnly Property InputStream() As Byte()
Get
Return mabtRxBuf
End Get
End Property

' This read-only property returns a string that represents
' the data coming into to the Comm Port.
Overridable ReadOnly Property InputStreamString() As String
Get
Dim oEncoder As New System.Text.ASCIIEncoding()
Return oEncoder.GetString(Me.InputStream)
End Get
End Property

' This property returns the open status of the Comm Port.
ReadOnly Property IsOpen() As Boolean
Get
Return CBool(mhRS <> -1)
End Get
End Property

' This read-only property returns the status of the modem.
Public ReadOnly Property ModemStatus() As ModemStatusBits
Get
If mhRS = -1 Then
Throw New ApplicationException("Please initialize and open " + _
"port before using this method")
Else
' Retrieve modem status
Dim lpModemStatus As Integer
If Not GetCommModemStatus(mhRS, lpModemStatus) Then
Throw New ApplicationException("Unable to get modem status")
Else
Return CType(lpModemStatus, ModemStatusBits)
End If
End If
End Get
End Property

' This property gets or sets the Parity
Public Property Parity() As DataParity
Get
Return meParity
End Get
Set(ByVal Value As DataParity)
meParity = Value
End Set
End Property

' This property gets or sets the Port
Public Property Port() As Integer
Get
Return miPort
End Get
Set(ByVal Value As Integer)
miPort = Value
End Set
End Property

' This write-only property sets or resets the RTS line.
Public WriteOnly Property Rts() As Boolean
Set(ByVal Value As Boolean)
If Not mhRS = -1 Then
If Value Then
EscapeCommFunction(mhRS, Lines.SetRts)
Else
EscapeCommFunction(mhRS, Lines.ClearRts)
End If
End If
End Set
End Property

' This property gets or sets the StopBit
Public Property StopBit() As DataStopBit
Get
Return meStopBit
End Get
Set(ByVal Value As DataStopBit)
meStopBit = Value
End Set
End Property

' This property gets or sets the Timeout
Public Overridable Property Timeout() As Integer
Get
Return miTimeout
End Get
Set(ByVal Value As Integer)
miTimeout = CInt(IIf(Value = 0, 500, Value))
' If Port is open updates it on the fly
pSetTimeout()
End Set
End Property

' This property gets or sets the working mode to overlapped
' or non-overlapped.
Public Property WorkingMode() As Mode
Get
Return meMode
End Get
Set(ByVal Value As Mode)
meMode = Value
End Set
End Property

#End Region
xiaolang88 2005-09-14
  • 打赏
  • 举报
回复
#Region "Structures"
' This is the DCB structure used by the calls to the Windows API.
<StructLayout(LayoutKind.Sequential, Pack:=1)> Private Structure DCB
Public DCBlength As Integer
Public BaudRate As Integer
Public Bits1 As Integer
Public wReserved As Int16
Public XonLim As Int16
Public XoffLim As Int16
Public ByteSize As Byte
Public Parity As Byte
Public StopBits As Byte
Public XonChar As Byte
Public XoffChar As Byte
Public ErrorChar As Byte
Public EofChar As Byte
Public EvtChar As Byte
Public wReserved2 As Int16
End Structure

' This is the CommTimeOuts structure used by the calls to the Windows API.
<StructLayout(LayoutKind.Sequential, Pack:=1)> Private Structure COMMTIMEOUTS
Public ReadIntervalTimeout As Integer
Public ReadTotalTimeoutMultiplier As Integer
Public ReadTotalTimeoutConstant As Integer
Public WriteTotalTimeoutMultiplier As Integer
Public WriteTotalTimeoutConstant As Integer
End Structure

' This is the CommConfig structure used by the calls to the Windows API.
<StructLayout(LayoutKind.Sequential, Pack:=1)> Private Structure COMMCONFIG
Public dwSize As Integer
Public wVersion As Int16
Public wReserved As Int16
Public dcbx As DCB
Public dwProviderSubType As Integer
Public dwProviderOffset As Integer
Public dwProviderSize As Integer
Public wcProviderData As Byte
End Structure

' This is the OverLapped structure used by the calls to the Windows API.
<StructLayout(LayoutKind.Sequential, Pack:=1)> Public Structure OVERLAPPED
Public Internal As Integer
Public InternalHigh As Integer
Public Offset As Integer
Public OffsetHigh As Integer
Public hEvent As Integer
End Structure
#End Region

#Region "Exceptions"

' This class defines a customized channel exception. This exception is
' raised when a NACK is raised.
Public Class CIOChannelException : Inherits ApplicationException
Sub New(ByVal Message As String)
MyBase.New(Message)
End Sub
Sub New(ByVal Message As String, ByVal InnerException As Exception)
MyBase.New(Message, InnerException)
End Sub
End Class

' This class defines a customized timeout exception.
Public Class IOTimeoutException : Inherits CIOChannelException
Sub New(ByVal Message As String)
MyBase.New(Message)
End Sub
Sub New(ByVal Message As String, ByVal InnerException As Exception)
MyBase.New(Message, InnerException)
End Sub
End Class

#End Region

#Region "Events"
' These events allow the program using this class to react to Comm Port
' events.
Public Event DataReceived(ByVal Source As Rs232, ByVal DataBuffer() As Byte)
Public Event TxCompleted(ByVal Source As Rs232)
Public Event CommEvent(ByVal Source As Rs232, ByVal Mask As EventMasks)
#End Region

#Region "Constants"
' These constants are used to make the code clearer.
Private Const PURGE_RXABORT As Integer = &H2
Private Const PURGE_RXCLEAR As Integer = &H8
Private Const PURGE_TXABORT As Integer = &H1
Private Const PURGE_TXCLEAR As Integer = &H4
Private Const GENERIC_READ As Integer = &H80000000
Private Const GENERIC_WRITE As Integer = &H40000000
Private Const OPEN_EXISTING As Integer = 3
Private Const INVALID_HANDLE_VALUE As Integer = -1
Private Const IO_BUFFER_SIZE As Integer = 1024
Private Const FILE_FLAG_OVERLAPPED As Integer = &H40000000
Private Const ERROR_IO_PENDING As Integer = 997
Private Const WAIT_OBJECT_0 As Integer = 0
Private Const ERROR_IO_INCOMPLETE As Integer = 996
Private Const WAIT_TIMEOUT As Integer = &H102&
Private Const INFINITE As Integer = &HFFFFFFFF


#End Region
xiaolang88 2005-09-14
  • 打赏
  • 举报
回复
微软的例子,参考一下
Option Strict On

Imports System.Runtime.InteropServices
Imports System.Text
Imports System.Threading

' This class provides all the necessary support for communicating
' with the Comm Port (otherwise known as the Serial Port, or
' RS232 port).
Public Class Rs232
' Declare the necessary class variables, and their initial values.
Private mhRS As Integer = -1 ' Handle to Com Port
Private miPort As Integer = 1 ' Default is COM1
Private miTimeout As Integer = 70 ' Timeout in ms
Private miBaudRate As Integer = 9600
Private meParity As DataParity = 0
Private meStopBit As DataStopBit = 0
Private miDataBit As Integer = 8
Private miBufferSize As Integer = 512 ' Buffers size default to 512 bytes
Private mabtRxBuf As Byte() ' Receive buffer
Private meMode As Mode ' Class working mode
Private mbWaitOnRead As Boolean
Private mbWaitOnWrite As Boolean
Private mbWriteErr As Boolean
Private muOverlapped As OVERLAPPED
Private muOverlappedW As OVERLAPPED
Private muOverlappedE As OVERLAPPED
Private mabtTmpTxBuf As Byte() ' Temporary buffer used by Async Tx
Private moThreadTx As Thread
Private moThreadRx As Thread
Private miTmpBytes2Read As Integer
Private meMask As EventMasks

#Region "Enums"

' This enumeration provides Data Parity values.
Public Enum DataParity
Parity_None = 0
Pariti_Odd
Parity_Even
Parity_Mark
End Enum

' This enumeration provides Data Stop Bit values.
' It is set to begin with a one, so that the enumeration values
' match the actual values.
Public Enum DataStopBit
StopBit_1 = 1
StopBit_2
End Enum

' This enumeration contains values used to purge the various buffers.
Private Enum PurgeBuffers
RXAbort = &H2
RXClear = &H8
TxAbort = &H1
TxClear = &H4
End Enum

' This enumeration provides values for the lines sent to the Comm Port
Private Enum Lines
SetRts = 3
ClearRts = 4
SetDtr = 5
ClearDtr = 6
ResetDev = 7 ' Reset device if possible
SetBreak = 8 ' Set the device break line.
ClearBreak = 9 ' Clear the device break line.
End Enum
' This enumeration provides values for the Modem Status, since
' we'll be communicating primarily with a modem.
' Note that the Flags() attribute is set to allow for a bitwise
' combination of values.
<Flags()> Public Enum ModemStatusBits
ClearToSendOn = &H10
DataSetReadyOn = &H20
RingIndicatorOn = &H40
CarrierDetect = &H80
End Enum

' This enumeration provides values for the Working mode
Public Enum Mode
NonOverlapped
Overlapped
End Enum

' This enumeration provides values for the Comm Masks used.
' Note that the Flags() attribute is set to allow for a bitwise
' combination of values.
<Flags()> Public Enum EventMasks
RxChar = &H1
RXFlag = &H2
TxBufferEmpty = &H4
ClearToSend = &H8
DataSetReady = &H10
ReceiveLine = &H20
Break = &H40
StatusError = &H80
Ring = &H100
End Enum
#End Region
kw123 2005-09-14
  • 打赏
  • 举报
回复
只有
imports system
Mircrosoft
VBNET
kw123 2005-09-14
  • 打赏
  • 举报
回复
to njhyh(小辉) :
Imports MSCommLib.MSCommClass
怎么倒入到内部去。关键是这里。若能倒入就行了!

njhyh 2005-09-13
  • 打赏
  • 举报
回复
b2 = Hex(buffer(2))
If Len(b2) = 1 Then
b2 = "0" + b2
Else
b2 = b2
End If

b3 = Hex(buffer(3))
If Len(b3) = 1 Then
b3 = "0" + b3
Else
b3 = b3
End If

b4 = Hex(buffer(4))
If Len(b4) = 1 Then
b4 = "0" + b4
Else
b4 = b4
End If

b5 = Hex(buffer(5))
If Len(b5) = 1 Then
b5 = "0" + b5
Else
b5 = b5
End If

b6 = Hex(buffer(6))
If Len(b6) = 1 Then
b6 = "0" + b6
Else
b6 = b6
End If

b7 = Hex(buffer(7))
If Len(b7) = 1 Then
b7 = "0" + b7
Else
b7 = b7
End If
RString = b0 + b1 + b2 + b3 + b4 + b5 + b6 + b7
If Microsoft.VisualBasic.Left(RString, 2) = "EB" Then
RString = Microsoft.VisualBasic.Left(RString, 10) '''将所有位数取上来
Else
Call Communication(RString) ''判断如果起始两位不是EB,则重新取数据
End If

TT1 = Mid(RString, 3, 2) ''将高两位取出,并付给一个字符变量
TT2 = Mid(RString, 5, 2) ''将中两位取出,并付给一个字符变量
TT3 = Mid(RString, 7, 2) ''将第两位取出,并付给一个字符变量

p = CInt(TT1)
m = CInt(TT2)
'n = CInt(TT3)
TextBox3.Text = RString


TextBox1.Text = CStr(p) + CStr(m) + "." + CStr(TT3)
End Sub

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
Dim RString
Timer1.Enabled = True
Call Communication(RString)
End Sub

Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
'CheckBox1.BackColor = Color.FromArgb(0, CheckBox1.BackColor)
Mscomm.CommPort = 1
Mscomm.Settings = "4800,n,8,1"
Mscomm.InputMode = Mscomm.InputMode.comInputModeBinary '(采用二进制方式进行输入)
Mscomm.InputLen = 0

End Sub

Private Sub Timer1_Tick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Timer1.Tick
Timer1.Enabled = False
End Sub
Protected Overrides Sub OnPaint(ByVal e As PaintEventArgs)
Dim g As Graphics = e.Graphics
Dim rpen As New Pen(Color.Black)
g.DrawLine(rpen, 152, 195 + 30, 152 + 114, 195 + 30)
End Sub

End Class


'很久以前写的。写的不是很好,但是用到了MScomm控件,你可以看一下!
njhyh 2005-09-13
  • 打赏
  • 举报
回复
Imports MSCommLib.MSCommClass
Imports Microsoft.VisualBasic
Imports System.Windows.Forms
Imports System.Drawing

Public Class Form1
Inherits System.Windows.Forms.Form

#Region " Windows 窗体设计器生成的代码 "

Public Sub New()
MyBase.New()

'该调用是 Windows 窗体设计器所必需的。
InitializeComponent()

'在 InitializeComponent() 调用之后添加任何初始化

End Sub

'窗体重写 dispose 以清理组件列表。
Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)
If disposing Then
If Not (components Is Nothing) Then
components.Dispose()
End If
End If
MyBase.Dispose(disposing)
End Sub

'Windows 窗体设计器所必需的
Private components As System.ComponentModel.IContainer

'注意: 以下过程是 Windows 窗体设计器所必需的
'可以使用 Windows 窗体设计器修改此过程。
'不要使用代码编辑器修改它。
Friend WithEvents TextBox1 As System.Windows.Forms.TextBox
Friend WithEvents Button1 As System.Windows.Forms.Button
Friend WithEvents Timer1 As System.Windows.Forms.Timer
Friend WithEvents TextBox2 As System.Windows.Forms.TextBox
Friend WithEvents CheckBox1 As System.Windows.Forms.CheckBox
Friend WithEvents Button2 As System.Windows.Forms.Button
Friend WithEvents Button3 As System.Windows.Forms.Button
Friend WithEvents TextBox3 As System.Windows.Forms.TextBox
<System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent()
Me.components = New System.ComponentModel.Container
Me.TextBox1 = New System.Windows.Forms.TextBox
Me.Button1 = New System.Windows.Forms.Button
Me.Timer1 = New System.Windows.Forms.Timer(Me.components)
Me.TextBox2 = New System.Windows.Forms.TextBox
Me.CheckBox1 = New System.Windows.Forms.CheckBox
Me.Button2 = New System.Windows.Forms.Button
Me.Button3 = New System.Windows.Forms.Button
Me.TextBox3 = New System.Windows.Forms.TextBox
Me.SuspendLayout()
'
'TextBox1
'
Me.TextBox1.Location = New System.Drawing.Point(103, 62)
Me.TextBox1.Name = "TextBox1"
Me.TextBox1.Size = New System.Drawing.Size(221, 21)
Me.TextBox1.TabIndex = 0
Me.TextBox1.Text = "TextBox1"
'
'Button1
'
Me.Button1.Location = New System.Drawing.Point(160, 27)
Me.Button1.Name = "Button1"
Me.Button1.Size = New System.Drawing.Size(86, 26)
Me.Button1.TabIndex = 1
Me.Button1.Text = "Button1"
'
'Timer1
'
'
'TextBox2
'
Me.TextBox2.BackColor = System.Drawing.SystemColors.Control
Me.TextBox2.BorderStyle = System.Windows.Forms.BorderStyle.None
Me.TextBox2.Location = New System.Drawing.Point(174, 203)
Me.TextBox2.Name = "TextBox2"
Me.TextBox2.Size = New System.Drawing.Size(114, 14)
Me.TextBox2.TabIndex = 2
Me.TextBox2.Text = "TextBox2"
'
'CheckBox1
'
Me.CheckBox1.Location = New System.Drawing.Point(107, 284)
Me.CheckBox1.Name = "CheckBox1"
Me.CheckBox1.Size = New System.Drawing.Size(142, 22)
Me.CheckBox1.TabIndex = 3
Me.CheckBox1.Text = "CheckBox1"
'
'Button2
'
Me.Button2.Location = New System.Drawing.Point(56, 124)
Me.Button2.Name = "Button2"
Me.Button2.Size = New System.Drawing.Size(120, 24)
Me.Button2.TabIndex = 4
Me.Button2.Text = "备份"
'
'Button3
'
Me.Button3.Location = New System.Drawing.Point(226, 121)
Me.Button3.Name = "Button3"
Me.Button3.Size = New System.Drawing.Size(147, 28)
Me.Button3.TabIndex = 5
Me.Button3.Text = "恢复"
'
'TextBox3
'
Me.TextBox3.Location = New System.Drawing.Point(104, 87)
Me.TextBox3.Name = "TextBox3"
Me.TextBox3.Size = New System.Drawing.Size(219, 21)
Me.TextBox3.TabIndex = 6
Me.TextBox3.Text = "TextBox3"
'
'Form1
'
Me.AutoScaleBaseSize = New System.Drawing.Size(6, 14)
Me.ClientSize = New System.Drawing.Size(464, 390)
Me.Controls.Add(Me.TextBox3)
Me.Controls.Add(Me.Button3)
Me.Controls.Add(Me.Button2)
Me.Controls.Add(Me.CheckBox1)
Me.Controls.Add(Me.TextBox2)
Me.Controls.Add(Me.Button1)
Me.Controls.Add(Me.TextBox1)
Me.Name = "Form1"
Me.Text = "Form1"
Me.ResumeLayout(False)

End Sub

#End Region
Dim buffer As Object
Dim Mscomm As New MSCommLib.MSComm ''先建立一个对象 在这里建立全局对象以后,在后面就不能够再建立对象了,否则会出错!

Sub Communication(ByVal RString As String)
'Dim Mscomm As New MSCommLib.MSComm ''先建立一个对象

Dim buffer As Object
Dim aa As String
Dim Dummy As Integer
Dim SendData(2) As Byte
Dim Arraya As Object
Dim TT1 As String
Dim TT2 As String
Dim TT3 As String
Dim p, m, n As Integer
Dim i, J, K As Integer

Mscomm.PortOpen = True
Mscomm.InputLen = 14 '将接收的字节数

Do '等待3秒
Application.DoEvents() '调用DoEvents函数,使接收完成前Timer1起作用

Loop Until Mscomm.InBufferCount >= 14 '是否收到全部字节

If Mscomm.PortOpen = True Then
'读取接收到的数据
buffer = Mscomm.Input '' 因为通讯协议写的是每次都传送上来两个字节
End If
Mscomm.PortOpen = False
''将收取上来的值转换成16进制(BCD码),并把格式换算成"00"的格式

Dim b0 As String
Dim b1 As String
Dim b2 As String
Dim b3 As String
Dim b4 As String
Dim b5 As String
Dim b6 As String
Dim b7 As String
''判断取上来的十六进制数位数为几位,1位则前面添0,否则全部显示
b0 = Hex(buffer(0))
If Len(b0) = 1 Then
b0 = "0" + b0
Else
b0 = b0
End If

b1 = Hex(buffer(1))
If Len(b1) = 1 Then
b1 = "0" + b1
Else
b1 = b1
End If
kw123 2005-09-13
  • 打赏
  • 举报
回复
不行,重新回答!!!
tanzsf 2005-08-20
  • 打赏
  • 举报
回复
最好别用,我用过发现不太稳定,有一些错误在程序中会捕捉不到
kw123 2005-08-18
  • 打赏
  • 举报
回复
好象不行啊!
wangchong 2005-08-05
  • 打赏
  • 举报
回复
1,安装VB6
2,添加引用。
但版本高的操作系统好像不是很稳定!!
supershagua 2005-08-05
  • 打赏
  • 举报
回复
安装VB6里面的activeX控件就可以了
微软常用运行库合集是采用microsoft visual studio 20xx编写的软件必须使用的公用dll运行库,是目前为止最全最新的运行库集合,相当于程序的字典文件。某些网上和论坛的部分精简软件没有附带这些公用dll,所以安装这些运行库是系统安装后第一件要做的事情。所有的安装文件全部来自微软官方网站,且为最新数字签名版本 微软常用运行库合集包含如下组件: DLL 动态链接库: atl70.dll 7.0.9975.0 x86; atl71.dll 7.10.6119.0 x86; comct232.ocx 6.0.98.39 x86; comct332.ocx 6.7.0.9839 x86; comctl32.ocx 6.0.98.39 x86; comdlg32.ocx 6.1.98.41 x86; dblist32.ocx 6.1.98.39 x86; mci32.ocx 6.1.98.39 x86; mfc70.dll 7.0.9975.0 x86; mfc70chs.dll 7.0.9975.0 x86; mfc70cht.dll 7.0.9975.0 x86; mfc70deu.dll 7.0.9975.0 x86; mfc70enu.dll 7.0.9975.0 x86; mfc70esp.dll 7.0.9975.0 x86; mfc70fra.dll 7.0.9975.0 x86; mfc70ita.dll 7.0.9975.0 x86; mfc70jpn.dll 7.0.9975.0 x86; mfc70kor.dll 7.0.9975.0 x86; mfc70u.dll 7.0.9975.0 x86; MFC71.dll 7.10.6119.0 x86; MFC71CHS.DLL 7.10.6119.0 x86; MFC71CHT.DLL 7.10.6119.0 x86; MFC71DEU.DLL 7.10.6119.0 x86; MFC71ENU.DLL 7.10.6119.0 x86; MFC71ESP.DLL 7.10.6119.0 x86; MFC71FRA.DLL 7.10.6119.0 x86; MFC71ITA.DLL 7.10.6119.0 x86; MFC71JPN.DLL 7.10.6119.0 x86; MFC71KOR.DLL 7.10.6119.0 x86; MFC71u.dll 7.10.6119.0 x86; mscomct2.ocx 6.1.98.39 x86; mscomctl.ocx 6.1.98.39 x86; mscomm32.ocx 6.1.98.39 x86; msdatgrd.ocx 6.1.98.39 x86; msdatlst.ocx 6.1.98.39 x86; mshflxgd.ocx 6.1.98.39 x86; msflxgrd.ocx 6.1.98.39 x86; msinet.ocx 6.1.98.39 x86; msmask32.ocx 6.1.98.39 x86; msstdfmt.dll 6.1.98.39 x86; MSSTKPRP.DLL 6.1.98.39 x86; msvbvm50.dll 5.2.82.44 x86; msvci70.dll 7.0.9466.0 x86; MSVCP70.DLL 7.0.9466.0 x86; msvcp71.dll 7.10.6052.0 x86; msvcr70.dll 7.0.9981.0 x86; msvcr71.dll 7.10.7031.4 x86; msvcrt10.dll x86; mswinsck.ocx 6.1.98.39 x86; picclp32.ocx 6.1.98.39 x86; richtx32.ocx 6.1.98.39 x86; sysinfo.ocx 6.1.98.39 x86; tabctl32.ocx 6.1.98.39 x86; Vb40032.dll 4.0.29.24 x86; Vb40016.dll 4.0.24.22 x86; vbrun100.dll x86; vbrun200.dll 2.0.9.8 x86; Vbrun300.dll 3.0.5.38 x86; VC++ 运行时库: Microsoft Visual C++ 2005 Redistributable Package v8.0.61001 x86/x64; Microsoft Visual C++ 2008 Redistributable Package v9.0.30729.6161 x86/x64; Microsoft Visual C++ 2010 R
VB控件“许可证信息没有找到”问题解决方案 到微软主页上下载如下文件:http://download.microsoft.com/download/vb60ent/sample30/1/w9xnt4/en-us/vb6cli.exe 或下载本文件 解压目录下点击运行VBC6.EXE 即可 对于VFP来说同样适用,前提是安装过VB才行 附: VB6Cli.exe 是一种实用工具,它用于修复随 Microsoft Visual Basic 6.0 一起发行的 ActiveX 控件中的设计阶段许可证问题。此工具不会修复第三方控件以及 Microsoft Visual Basic 6.0 通常情况下不予安装的控件,也不允许使用 Visual Basic 6.0 专业版中的远程数据对象 (RDO) 对象。 下面是 VB6Cli.exe 可以修复的 ActiveX 控件的列表: ActiveX 控件 文件名 版本号 版本类型 ----------------------------------------------------------- ADO Data Control 6.0 MSADODC.OCX 6.00.8171 L,P,E Chart Control 6.0 MSCHRT20.OCX 6.00.8177 P,E Comm Control 6.0 MSCOMM32.OCX 6.00.8169 P,E Common Dialog Control 6.0 COMDLG32.OCX 6.00.8169 L,P,E Data Bound List Controls 6.0 DBLIST32.OCX 6.00.8169 L,P,E DataGrid Control 6.0 MSDATGRD.OCX 6.00.8169 L,P,E DataList Controls 6.0 MSDATLST.OCX 6.00.8169 L,P,E DataRepeater Control 6.0 MSDATREP.OCX 6.00.8169 P,E FlexGrid Control 6.0 MSFLXGRD.OCX 6.00.8169 L,P,E Hierarchical FlexGrid Control 6.0 MSHFLXGD.OCX 6.00.3005 L,P,E Internet Transfer Control 6.0 MSINET.OCX 6.00.8169 P,E MAPI Controls 6.0 MSMAPI32.OCX 6.00.8169 P,E Masked Edit Control 6.0 MSMASK32.OCX 6.00.8169 P,E Multimedia Control 6.0 MCI32.OCX 6.00.8169 P,E PictureClip Control 6.0 PICCLP32.OCX 6.00.8169 P,E RemoteData Control 6.0 MSRDC20.OCX 6.00.8169 E Rich Textbox Control 6.0 RICHTX32.OCX 6.00.8169 L,P,E SysInfo Control 6.0 SYSINFO.OCX 6.00.8169 P,E Tabbed Dialog Control 6.0 TABCTL32.OCX 6.00.8169 L,P,E Windows Common Controls-3 6.0 COMCT332.OCX 6.00.8169 P,E Windows Common Controls 5.0 (SP2) COMCTL32.OCX 6.00.8022 L,P,E Windows Common Controls 6.0 MSCOMCTL.OCX 6.00.8177 L,P,E Windows Common Controls-2 5.0 (SP2) COMCT232.OCX 6.00.8022 L,P,E Windows Common Controls-2 6.0 MSCOMCT2.OCX 6.00.8177 L,P,E Winsock Control 6.0 MSWINSCK.OCX 6.00.8169 P,E L = 标准版

16,722

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧