| 首页 | 技术文章 | 软件下载 | 博客 | 论坛 | 精品教程 | 黑客动画 | 视频资源 | 在线服务 | 黑客游戏 | 

您现在的位置: 中国X黑客小组 >> 技术文章 >> 编程技术 >> 程序设计 >> 文章正文 用户登录 新用户注册
  Win32汇编教程八          【字体:
Win32汇编教程八
作者:不详    文章来源:CnXHacker.Net    点击数:    更新时间:2007-7-24    
Mem,0,0,SRCCOPY
   invoke ReleaseDC,hWinDesktop,@hDcDesktop
   invoke ReleaseDC,hWinPic,@hDcPic
  .else
;********************************************************************
; 注意:对话框的消息处理后,要返回 TRUE,对没有处理的消息
; 要返回 FALSE
;********************************************************************
   mov eax,FALSE
   ret
  .endif    
  mov eax,TRUE
  ret
  
_ProcDlgMain endp
;********************************************************************
start:
  invoke GetModuleHandle,NULL
  mov hInstance,eax
  invoke DialogBoxParam,hInstance,DLG_MAIN,NULL,offset _ProcDlgMain,0
  invoke ExitProcess,NULL

  end start

程序的分析和要点

    在程序的初始化中,我们用GetDc 取的桌面的屏幕的 DC,再用 CreateCompatibleDC 建立一个内存DC做缓冲区,建立一个位图再用 SelectObject 把 hDcMem 设置为这个位图是为了是 hDcMem 的大小变为 80x80。

   invoke GetDC,hWinDesktop
   mov @hDcDesktop,eax
   invoke CreateCompatibleDC,@hDcDesktop
   mov hDcMem,eax
   invoke CreateCompatibleBitmap,@hDcDesktop,80,80
   mov hBitmap,eax
   invoke SelectObject,hDcMem,hBitmap
   invoke ReleaseDC,hWinDesktop,@hDcDesktop
然后在程序的每 0.1 秒一次的 WM_TIMER 定时器消息中,我们先用 GetDC 取得桌面和对话框中文本框的句柄,然后用 PatBlt 把内存DC清除为黑色,再用 StretchBlt 从桌面DC中拷贝 40x40的区域到内存 DC 中,新的大小是 80x80(放大功能就是这样实现的),拷贝的位置是用 GetCursorPos 取得的,也就是鼠标的当前位置,最后用 BitBlt 把内存DC 拷贝到对话框中。如果直接把桌面DC 拷贝到对话框中也可以,但是当鼠标移动到屏幕边缘上时,由于屏幕外的点是无效的,所以对话框中的一部分会花屏,大家可以改动程序试试。

   invoke GetCursorPos,addr @stPoint
   invoke GetDC,hWinDesktop
   mov @hDcDesktop,eax
   invoke GetDC,hWinPic
   mov @hDcPic,eax
   invoke PatBlt,hDcMem,0,0,80,80,BLACKNESS
   invoke StretchBlt,hDcMem,0,0,80,80,\
    @hDcDesktop,@stPoint.x,@stPoint.y,40,40,SRCCOPY
   invoke BitBlt,@hDcPic,0,0,80,80,\
    hDcMem,0,0,SRCCOPY
   invoke ReleaseDC,hWinDesktop,@hDcDesktop
   invoke ReleaseDC,hWinPic,@hDcPic

上一页  [1] [2] 

文章录入:IceRiver    责任编辑:IceRiver 
  • 上一篇文章:

  • 下一篇文章:
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    最新热点 最新推荐 相关文章
    如何分级防御针对Linux服务器
    活地运用SQL Injection做数据
    Skype用户须警惕新Windows蠕
    McAfee发布Windows Mobile风
    Windows Vista对付ARP病毒有
    非主流入侵之会话劫持winnt/
    US CERT:谷歌eBay雅虎网站均
    微软今日发布Windows Live测
    SIDVault Simple_Bind 函数多
    Thomson SpeedTouch 2030 SI
      网友评论:(只显示最新5条。评论内容只代表网友观点,与本站立场无关!)
    Powered by ICE RIVER - STUDIO
    » CnXHacker.CoM   © CopyRight 2002-2006, CnXHacker.CoM™, Inc. All Rights Reserved.