龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 软件开发 > VB开发 >

VB中拖动没有标题栏的窗体

时间:2009-12-30 15:42来源:未知 作者:admin 点击:
分享到:
程序代码: Module1 OptionExplicit PublicConstGWL_WNDPROC=(-4) PublicConstWM_NCHITTEST=H84 PublicConstHTCLIENT=1 PublicConstHTCAPTION=2 DeclareFunctionCallWindowProcLib"user32"Alias"CallWindowProcA"(ByVallpPrevWndFuncAsLong,ByValhWndAsLong
程序代码:

Module1
  OptionExplicit
  PublicConstGWL_WNDPROC=(-4)

PublicConstWM_NCHITTEST=&H84
  PublicConstHTCLIENT=1
  PublicConstHTCAPTION=2

DeclareFunctionCallWindowProcLib"user32"Alias"CallWindowProcA"(ByVallpPrevWndFuncAsLong,ByValhWndAsLong,ByValMsgAsLong,ByValwParamAsLong,ByVallParamAsLong)AsLong
  DeclareFunctionGetWindowLongLib"user32"Alias"GetWindowLongA"(ByValhWndAsLong,ByValnIndexAsLong)AsLong
  DeclareFunctionSetWindowLongLib"user32"Alias"SetWindowLongA"(ByValhWndAsLong,ByValnIndexAsLong,ByValdwNewLongAsLong)AsLong

PublicprevWndProcAsLong

FunctionWndProc(ByValhWndAsLong,ByValMsgAsLong,ByValwParamAsLong,ByVallParamAsLong)AsLong
  WndProc=CallWindowProc(prevWndProc,hWnd,Msg,wParam,lParam)
  IfMsg=WM_NCHITTESTAndWndProc=HTCLIENTThen
  WndProc=HTCAPTION
  EndIf
  EndFunction
  

  程序首先调用CallWindowProc,这样就可以从还回值的知当前的鼠标位置位于那一个区域,接着判断返回值是否等于HTCLENT(工作区)内,如果是,则将返回值设置成TICAPTION(标题区),这样就可以瞒过Windows,让Windows以为鼠标位于标题区内

Form1

OptionExplicit

PrivateSubCommand1_Click()
  UnloadMe
  EndSub

PrivateSubForm_Load()
  prevWndProc=GetWindowLong(Me.hWnd,GWL_WNDPROC)
  SetWindowLongMe.hWnd,GWL_WNDPROC,AddressOfWndProc
  EndSub

PrivateSubForm_Unload(CancelAsInteger)
  SetWindowLongMe.hWnd,GWL_WNDPROC,prevWndProc
  EndSub

->

精彩图集

赞助商链接