frmAbout.frm
上传用户:fuyouda
上传日期:2015-08-19
资源大小:6876k
文件大小:10k
源码类别:

家庭/个人应用

开发平台:

Visual C++

  1. VERSION 5.00
  2. Begin VB.Form frmAbout 
  3.    BorderStyle     =   3  'Fixed Dialog
  4.    Caption         =   "About..."
  5.    ClientHeight    =   2670
  6.    ClientLeft      =   45
  7.    ClientTop       =   330
  8.    ClientWidth     =   5205
  9.    ClipControls    =   0   'False
  10.    Icon            =   "frmAbout.frx":0000
  11.    LinkTopic       =   "Form1"
  12.    MaxButton       =   0   'False
  13.    MinButton       =   0   'False
  14.    ScaleHeight     =   2670
  15.    ScaleWidth      =   5205
  16.    ShowInTaskbar   =   0   'False
  17.    StartUpPosition =   1  'CenterOwner
  18.    Begin VB.CommandButton cmdOK 
  19.       Cancel          =   -1  'True
  20.       Caption         =   "Done"
  21.       Default         =   -1  'True
  22.       Height          =   345
  23.       Left            =   3360
  24.       TabIndex        =   0
  25.       Tag             =   "确定"
  26.       Top             =   2160
  27.       Width           =   1467
  28.    End
  29.    Begin VB.CommandButton cmdSysInfo 
  30.       Caption         =   "&System info..."
  31.       Height          =   345
  32.       Left            =   1800
  33.       TabIndex        =   1
  34.       Tag             =   "系统信息(&S)..."
  35.       Top             =   2160
  36.       Width           =   1452
  37.    End
  38.    Begin VB.Frame Frame1 
  39.       Height          =   1935
  40.       Left            =   240
  41.       TabIndex        =   2
  42.       Top             =   120
  43.       Width           =   4695
  44.       Begin VB.Label lblVersion 
  45.          Caption         =   "VB样例程序"
  46.          BeginProperty Font 
  47.             Name            =   "宋体"
  48.             Size            =   9
  49.             Charset         =   0
  50.             Weight          =   400
  51.             Underline       =   0   'False
  52.             Italic          =   0   'False
  53.             Strikethrough   =   0   'False
  54.          EndProperty
  55.          Height          =   225
  56.          Left            =   480
  57.          TabIndex        =   6
  58.          Tag             =   "版本"
  59.          Top             =   720
  60.          Width           =   4095
  61.       End
  62.       Begin VB.Label lblTitle 
  63.          Caption         =   "OPC 数据访问服务器客户端开发工具包"
  64.          BeginProperty Font 
  65.             Name            =   "宋体"
  66.             Size            =   9
  67.             Charset         =   0
  68.             Weight          =   400
  69.             Underline       =   0   'False
  70.             Italic          =   0   'False
  71.             Strikethrough   =   0   'False
  72.          EndProperty
  73.          ForeColor       =   &H00000000&
  74.          Height          =   240
  75.          Left            =   480
  76.          TabIndex        =   5
  77.          Tag             =   "应用程序标题"
  78.          Top             =   360
  79.          Width           =   3615
  80.       End
  81.       Begin VB.Label Label3 
  82.          Caption         =   "http://www.agilewill.com"
  83.          BeginProperty Font 
  84.             Name            =   "宋体"
  85.             Size            =   9
  86.             Charset         =   0
  87.             Weight          =   400
  88.             Underline       =   0   'False
  89.             Italic          =   0   'False
  90.             Strikethrough   =   0   'False
  91.          EndProperty
  92.          ForeColor       =   &H00000000&
  93.          Height          =   210
  94.          Left            =   480
  95.          TabIndex        =   4
  96.          Tag             =   "应用程序描述"
  97.          Top             =   1440
  98.          Width           =   3735
  99.       End
  100.       Begin VB.Label lblDescription 
  101.          Caption         =   "北京安捷尔软件技术有限公司 2005.11"
  102.          BeginProperty Font 
  103.             Name            =   "宋体"
  104.             Size            =   9
  105.             Charset         =   0
  106.             Weight          =   400
  107.             Underline       =   0   'False
  108.             Italic          =   0   'False
  109.             Strikethrough   =   0   'False
  110.          EndProperty
  111.          ForeColor       =   &H00000000&
  112.          Height          =   285
  113.          Left            =   480
  114.          TabIndex        =   3
  115.          Tag             =   "应用程序描述"
  116.          Top             =   1080
  117.          Width           =   3615
  118.       End
  119.    End
  120. End
  121. Attribute VB_Name = "frmAbout"
  122. Attribute VB_GlobalNameSpace = False
  123. Attribute VB_Creatable = False
  124. Attribute VB_PredeclaredId = True
  125. Attribute VB_Exposed = False
  126. Option Explicit
  127. ' 注册键安全选项...
  128. Const KEY_ALL_ACCESS = &H2003F
  129.                                           
  130. ' 注册键根类型...
  131. Const HKEY_LOCAL_MACHINE = &H80000002
  132. Const ERROR_SUCCESS = 0
  133. Const REG_SZ = 1                         ' Unicode 空结尾字符串
  134. Const REG_DWORD = 4                      ' 32位数
  135. Const gREGKEYSYSINFOLOC = "SOFTWAREMicrosoftShared Tools Location"
  136. Const gREGVALSYSINFOLOC = "MSINFO"
  137. Const gREGKEYSYSINFO = "SOFTWAREMicrosoftShared ToolsMSINFO"
  138. Const gREGVALSYSINFO = "PATH"
  139. Private Declare Function RegOpenKeyEx Lib "advapi32" Alias "RegOpenKeyExA" (ByVal hKey As Long, ByVal lpSubKey As String, ByVal ulOptions As Long, ByVal samDesired As Long, ByRef phkResult As Long) As Long
  140. Private Declare Function RegQueryValueEx Lib "advapi32" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, ByRef lpType As Long, ByVal lpData As String, ByRef lpcbData As Long) As Long
  141. Private Declare Function RegCloseKey Lib "advapi32" (ByVal hKey As Long) As Long
  142. Private Sub Form_Load()
  143.     lblVersion.Caption = "Version " & App.Major & "." & App.Minor & "." & App.Revision
  144.     lblTitle.Caption = App.Title
  145. End Sub
  146. Private Sub cmdSysInfo_Click()
  147.         Call StartSysInfo
  148. End Sub
  149. Private Sub cmdOK_Click()
  150.         Unload Me
  151. End Sub
  152. Public Sub StartSysInfo()
  153.     On Error GoTo SysInfoErr
  154.         Dim rc As Long
  155.         Dim SysInfoPath As String
  156.         
  157.         ' 从注册表获得系统信息程序路径名称...
  158.         If GetKeyValue(HKEY_LOCAL_MACHINE, gREGKEYSYSINFO, gREGVALSYSINFO, SysInfoPath) Then
  159.         ' 仅从注册表获得系统信息程序路径...
  160.         ElseIf GetKeyValue(HKEY_LOCAL_MACHINE, gREGKEYSYSINFOLOC, gREGVALSYSINFOLOC, SysInfoPath) Then
  161.                 ' 验证已知的 32 位文件版本的存在
  162.                 If (Dir(SysInfoPath & "MSINFO32.EXE") <> "") Then
  163.                         SysInfoPath = SysInfoPath & "MSINFO32.EXE"
  164.                         
  165.                 ' 错误 - 文件找不到...
  166.                 Else
  167.                         GoTo SysInfoErr
  168.                 End If
  169.         ' 错误 - 注册表项找不到...
  170.         Else
  171.                 GoTo SysInfoErr
  172.         End If
  173.         
  174.         Call Shell(SysInfoPath, vbNormalFocus)
  175.         
  176.         Exit Sub
  177. SysInfoErr:
  178.         MsgBox "此时系统信息不可用", vbOKOnly
  179. End Sub
  180. Public Function GetKeyValue(KeyRoot As Long, KeyName As String, SubKeyRef As String, ByRef KeyVal As String) As Boolean
  181.         Dim I As Long                                           ' 循环记数器
  182.         Dim rc As Long                                          ' 返回代码
  183.         Dim hKey As Long                                        ' 打开的注册表键句柄
  184.         Dim hDepth As Long                                      '
  185.         Dim KeyValType As Long                                  ' 注册表键数据类型
  186.         Dim tmpVal As String                                    ' 临时存储一个注册表键值
  187.         Dim KeyValSize As Long                                  ' 注册表键变量大小
  188.         '------------------------------------------------------------
  189.         ' 在键根{HKEY_LOCAL_MACHINE...}之下打开注册键
  190.         '------------------------------------------------------------
  191.         rc = RegOpenKeyEx(KeyRoot, KeyName, 0, KEY_ALL_ACCESS, hKey) ' 打开注册表键
  192.         
  193.         If (rc <> ERROR_SUCCESS) Then GoTo GetKeyError          ' 错误处理...
  194.         
  195.         tmpVal = String$(1024, 0)                             ' 分配变量空间
  196.         KeyValSize = 1024                                       ' 标记变量大小
  197.         
  198.         '------------------------------------------------------------
  199.         ' 检索注册表键值...
  200.         '------------------------------------------------------------
  201.         rc = RegQueryValueEx(hKey, SubKeyRef, 0, KeyValType, tmpVal, KeyValSize)    ' 获得/创建键值
  202.                                                 
  203.         If (rc <> ERROR_SUCCESS) Then GoTo GetKeyError          ' 错误处理
  204.       
  205.         tmpVal = VBA.Left(tmpVal, InStr(tmpVal, VBA.Chr(0)) - 1)
  206.         '------------------------------------------------------------
  207.         ' 决定转换的键值类型...
  208.         '------------------------------------------------------------
  209.         Select Case KeyValType                                  ' 搜索数据类型...
  210.         Case REG_SZ                                             ' 字符串注册表键数据类型
  211.                 KeyVal = tmpVal                                     ' 复制字符串值
  212.         Case REG_DWORD                                          ' 双精度注册表键数据类型
  213.                 For I = Len(tmpVal) To 1 Step -1                    ' 转换每一页
  214.                         KeyVal = KeyVal + Hex(Asc(Mid(tmpVal, I, 1)))   ' 一个字符一个字符地生成值
  215.                 Next
  216.                 KeyVal = Format$("&h" + KeyVal)                     ' 转换双精度为字符串
  217.         End Select
  218.         
  219.         GetKeyValue = True                                      ' 返回成功
  220.         rc = RegCloseKey(hKey)                                  ' 关闭注册表键
  221.         Exit Function                                           ' 退出
  222.         
  223. GetKeyError:    ' Cleanup After An Error Has Occured...
  224.         KeyVal = ""                                             ' 设返回值为空字符串
  225.         GetKeyValue = False                                     ' 返回失败
  226.         rc = RegCloseKey(hKey)                                  ' 关闭注册表键
  227. End Function