鱼C论坛

 找回密码
 立即注册
查看: 3023|回复: 2

【代码】VB6.0一些比较常用的代码

[复制链接]
发表于 2011-2-10 15:56:56 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 ljq5555 于 2011-2-12 10:44 编辑

这些都是我个人收集感觉有用的,不过大多不是我写的,只是作为一个集合存放起来,

一、获取屏幕分辨率:
  1. MsgBox Screen.Width / Screen.TwipsPerPixelX & "x" & Screen.Height / Screen.TwipsPerPixelY
复制代码
二、窗体的简单美化:
函数SetLayeredWindowAttributes
  使用这个函数,可以轻松的实现半透明窗体。按照微软的要求,透明窗体窗体在创建时应使用WS_EX_LAYERED参数(用CreateWindowEx),或者在创建后设置该参数(用SetWindowLong),我选用后者。全部函数、常量声明如下:
  1. Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long  
  2. Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
  3. Private Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long' 其中hwnd是透明窗体的句柄,crKey为颜色值,bAlpha是透明度,取值范围是[0,255],dwFlags是透明方式,可以取两个值:当取值为LWA_ALPHA时,crKey参数无效,bAlpha参数有效;当取值为LWA_COLORKEY时,bAlpha参数有效而窗体中的所有颜色为crKey的地方将变为透明--这个功能很有用:我们不必再为建立不规则形状的窗体而调用一大堆区域分析、创建、合并函数了,只需指定透明处的颜色值即可,哈哈哈哈!请看具体代码。
  4. Private Const WS_EX_LAYERED = &H80000
  5. Private Const GWL_EXSTYLE = (-20)
  6. Private Const LWA_ALPHA = &H2
  7. Private Const LWA_COLORKEY = &H1
  8. '代码一:一个半透明窗体
  9. Private Sub Form_Load()
  10.   Dim rtn As Long
  11.   rtn = GetWindowLong(hwnd, GWL_EXSTYLE)
  12.   rtn = rtn Or WS_EX_LAYERED
  13.   SetWindowLong hwnd, GWL_EXSTYLE, rtn
  14.   SetLayeredWindowAttributes hwnd, 0, 200, LWA_ALPHA
  15. End Sub

  16. '代码二:形状不规则的窗体
  17. Private Sub Form_Load()
  18.   Dim rtn As Long
  19.   BorderStyler=0
  20.   rtn = GetWindowLong(hwnd, GWL_EXSTYLE)
  21.   rtn = rtn Or WS_EX_LAYERED
  22.   SetWindowLong hwnd, GWL_EXSTYLE, rtn
  23.   SetLayeredWindowAttributes hwnd, &HFF0000, 0, LWA_COLORKEY '将扣去窗口中的蓝色
  24. End Sub   
复制代码
三、用 VB 为文件创建快捷方式
  1. '下面的例子在桌面为文件 C:\a.txt 创建一个快捷方式

  2. Dim nPath As String, sh, ShortCut
  3.     '获取当前用户的桌面目录
  4.     Set sh = CreateObject("wscript.shell")
  5.     nPath = sh.RegRead("HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders\Desktop")
  6.     ''如果要在开始菜单的程序组中创建快捷方式,将上面的语句换为下面的语句:
  7.     'nPath = sh.RegRead("HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders\Programs")
  8.     If Right(nPath, 1) <> "" Then nPath = nPath & ""
  9.    
  10.     '创建快捷方式
  11.     ShortF = nPath & "文本文档.lnk"
  12.     Set ShortCut = sh.CreateShortcut(ShortF) '创建一个快捷方式对象
  13.     ShortCut.TargetPath = "C:\a.txt"                  '快捷方式指向的目标,可以是任意文件
  14.     ShortCut.Save                                                '保存快捷方式
复制代码
四、窗体内控件随窗体的变化而自适应位置和大小(字体不变)
  1. Option Explicit
  2. Private FormOldWidth As Long
  3. '保存窗体的原始宽度
  4. Private FormOldHeight As Long
  5. '保存窗体的原始高度

  6. '在调用ResizeForm前先调用本函数
  7. Public Sub ResizeInit(FormName As Form)
  8. Dim Obj As Control
  9. FormOldWidth = FormName.ScaleWidth
  10. FormOldHeight = FormName.ScaleHeight
  11. On Error Resume Next
  12. For Each Obj In FormName
  13. Obj.Tag = Obj.Left & " " & Obj.Top & " " _
  14. & Obj.Width & " " & Obj.Height & " "
  15. Next Obj
  16. On Error GoTo 0
  17. End Sub

  18. '按比例改变表单内各元件的大小,在调用ReSizeForm前先调用ReSizeInit函数
  19. Public Sub ResizeForm(FormName As Form)
  20. Dim Pos(4) As Double
  21. Dim I As Long, TempPos As Long, StartPos As Long
  22. Dim Obj As Control
  23. Dim ScaleX As Double, ScaleY As Double

  24. ScaleX = FormName.ScaleWidth / FormOldWidth
  25. '保存窗体宽度缩放比例
  26. ScaleY = FormName.ScaleHeight / FormOldHeight
  27. '保存窗体高度缩放比例
  28. On Error Resume Next
  29. For Each Obj In FormName
  30. StartPos = 1
  31. For I = 0 To 4
  32. '读取控件的原始位置与大小

  33. TempPos = InStr(StartPos, Obj.Tag, " ", vbTextCompare)
  34. If TempPos > 0 Then
  35. Pos(I) = Mid(Obj.Tag, StartPos, TempPos - StartPos)
  36. StartPos = TempPos + 1
  37. Else
  38. Pos(I) = 0
  39. End If
  40. '根据控件的原始位置及窗体改变大小的比例对控件重新定位与改变大小
  41. Obj.Move Pos(0) * ScaleX, Pos(1) * ScaleY, _
  42. Pos(2) * ScaleX, Pos(3) * ScaleY
  43. Next I
  44. Next Obj
  45. On Error GoTo 0
  46. End Sub

  47. Private Sub Form_Load()
  48. Call ResizeInit(Me) '在程序装入时必须加入
  49. End Sub

  50. Private Sub Form_Resize()
  51. Call ResizeForm(Me) '确保窗体改变时控件随之改变
  52. End Sub
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2011-4-9 19:50:30 | 显示全部楼层
要学,还是一个字一个字打吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2013-9-15 10:44:49 | 显示全部楼层
淡定...淡定...淡定...
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-26 12:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表