对学delphi的来说,不知这算不算有点挑战性? 300分只送一人(300分)

  • 主题发起人 主题发起人 一少
  • 开始时间 开始时间

一少

Unregistered / Unconfirmed
GUEST, unregistred user!
完全以api实现<br><br>一个窗口,标题为“演示窗口”,大小 400*300,背景色clGreen,<br>上面放一个文本框和一个按钮,文本框中显示数字,初值为0,每秒递增1<br>单击按钮时以messageBox显示文本框中的内容,<br>关闭“演示窗口”时出现提示窗口,询问是否决定关闭
 
不知道目的是什么?学API吗?
 
win32 SDK 编程<br><br>学这个干吗?你为什么不去学VC啊!
 
对,学习用,请大家赐教!
 
to 青萍<br>曾经听一位高手比较过三种工具的特点:<br>&nbsp; VB逼人懒惰 &nbsp;(无法构造一些低层的东西)<br>&nbsp; VC逼人勤奋 &nbsp;(很多东西都要自己构造)<br>&nbsp; delphi引诱人懒惰 &nbsp;(很多东西都有现成的,让人不想去构造;其实它能像VC一样构造出想要的东西)<br>当然这里的“懒惰”并非真正意义上的懒惰<br>我只是想了解一下如何以delphi这款开发工具去实现VC那样的“构造”<br><br>
 
[:D]我也想知道
 
很简单的,使用CreateWindow就可以了!<br>另外需要自己构建一个消息循环,总之VC中的写法<br>你可以完全照般到Delphi中。仔细的阅读Delphi中的<br>Windows, Messages, SysUtils这三个单元,你就会<br>作了
 
[red]给你一段例程吧!来自hubdog的宝典[/red]<br><br>象C语言一样,用Delphi也能写出只有几十K、十几K、甚至只有几K的小程序,本文将 <br>以一个能将Win95桌面藏起来的仅有38K的小程序为例教会读者这一技巧,同时本文还 <br>将涉及Win95 TrayIcon的显示。 <br><br>本程序能写得很小的诀窍是:根本没有用任何的 Form 。也就是说,源程序只有一个 <br>Desktop.dpr 文件,程序完全用标准的 WINAPI 写成,由于用到的资源很少,所以程 <br>序的体积也很小。当然,用这样的方法编程时不能使用 Delphi的所见即所得的编程方 <br>式。} <br><br>&nbsp; <br><br>{首先看看程序头的写法:} <br><br>&nbsp; &nbsp; program DeskPop; <br><br>&nbsp; &nbsp; uses Windows, Messages, ShellAPI, sysutils; <br><br>&nbsp; &nbsp; {$R *.RES} <br><br>&nbsp; <br><br>{可以看出本程序比普通的 Delphi 程序用到的 Unit 少的多。 下面声明了全局常量和变 <br><br>量,暂时可以 <br><br>不管他们。} <br><br>&nbsp; &nbsp; const <br><br>&nbsp; &nbsp; AppName = 'DeskTop Hide'; <br><br>&nbsp; &nbsp; var <br><br>&nbsp; &nbsp; x: integer; <br><br>&nbsp; &nbsp; tid: TNotifyIconData; <br><br>&nbsp; &nbsp; WndClass: array[0..50] of char; <br><br>&nbsp; <br><br>{现在进入程序的主要部分,首先是定义了一批过程,为了能让读者更好地理解,我们先 <br><br>把这些过程跳过 <br><br>去,先说主程序。主程序位于程序的最后,这样做的好处是可以直接使用程序中定义的过 <br><br>程。主程序十分 <br><br>简单:} <br><br>&nbsp; &nbsp; begin <br><br>&nbsp; &nbsp; WinMain; <br><br>&nbsp; &nbsp; end. <br><br>{看来所有的工作都由 WinMain 完成了。这个 WinMain 使用标准的 WinAPI 函数进行编 <br><br>程,主要步骤 <br><br>是:先声明一个窗口类,然后创建一个主窗口,最后进入消息循环,直到程序结束。} <br><br>&nbsp; <br><br>procedure WinMain; <br><br>var <br><br>Wnd: hWnd; {声明窗口句柄(Handle)变量} <br><br>Msg: TMsg; {声明消息变量} <br><br>cls: TWndClass; {窗口类变量} <br><br>begin <br><br>{ Previous instance running ? If so, exit } <br><br>{ 检查是否程序已经运行,如果已经运行则调用Panic过程退出 } <br><br>if FindWindow (AppName, Nil) &lt;&gt; 0 then <br><br>Panic (AppName + ' is already running.'); <br><br>&nbsp; <br><br>{ Register the window class } <br><br>{ 这里的注册窗口类程序是例行公事,照抄即可} <br><br>FillChar (cls, sizeof (cls), 0); {用这一句将窗口类变量cls清零) <br><br>cls.lpfnWndProc := @DummyWindowProc; {取回调函数DummyWindowProc的地址} <br><br>cls.hInstance := hInstance; {实例句柄} <br><br>cls.lpszClassName := AppName; {窗口类名} <br><br>RegisterClass (cls); {注册窗口类cls} <br><br>&nbsp; <br><br>{ 现在可以创建程序的主窗口了-在本程序中是个虚拟窗口} <br><br>{ Now create the dummy window } <br><br>Wnd := CreateWindow (AppName, AppName, ws_OverlappedWindow, <br><br>cw_UseDefault, cw_UseDefault, cw_UseDefault, cw_UseDefault, <br><br>0, 0, hInstance, Nil); <br><br>x:= 0; {变量X其实是个开关变量,记录现在是否已经隐藏了桌面} <br><br>&nbsp; <br><br>{ 如果窗口创建成功,则显示窗口,并进入消息循环 } <br><br>if Wnd &lt;&gt; 0 then <br><br>begin <br><br>ShowWindow (Wnd, sw_Hide);{本例中窗口是隐藏的} <br><br>{ 下面进入消息循环,该循环将不断运行直到 GetMessage返回0 } <br><br>while GetMessage (Msg, 0, 0, 0) do <br><br>begin <br><br>TranslateMessage (Msg); <br><br>DispatchMessage (Msg); <br><br>end; <br><br>end; <br><br>end; <br><br>&nbsp; <br><br>{现在看来,程序的主框架很明了,但是它还不能完成任何任务。过程 Panic将显示一个 <br><br>对话框后退出程 <br><br>序,它在 Winmain 过程的开始部分被调用,其实 Panic的功能很简单,之所以要写成一 <br><br>个函数的原因恐 <br><br>怕一方面是结构化编程的需要,另一方面借此避开了 String 和 PChar 的转换。} <br><br>procedure Panic (szMessage: PChar); <br><br>begin <br><br>if szMessage &lt;&gt; Nil then <br><br>MessageBox (0, szMessage, AppName, mb_ok); <br><br>Halt (0); <br><br>end; <br><br>&nbsp; <br><br>{下面是回调(Callback)函数 DummyWindowProc,如果说 Winmain 过程是本程序-或者说 <br><br>是本应用或实 <br><br>例的生命,那么这个回调函数可以说是主窗口的灵魂。每一个标准的或者说是规范的 <br><br>Windows窗口都有一 <br><br>个回调函数,以处理发给该窗口的消息。所谓“回调”的意思是这个函数不是由程序直接 <br><br>调用的,而是由 <br><br>Windows 系统调用(还记得我们在窗口类中给lpfnWndProc赋过值吗), 这就是事件驱动编 <br><br>程。} <br><br>function DummyWindowProc (Wnd: hWnd; Msg, wParam: Word; lParam: LongInt) <br><br>: LongInt; stdcall; {注意这里有一个 stdcall;定义了回调函数} <br><br>var <br><br>TrayHandle: THandle; <br><br>dc: hDC; <br><br>i: Integer; <br><br>pm: HMenu; <br><br>pt: TPoint; <br><br>begin <br><br>DummyWindowProc := 0; <br><br>{下面两句是找到 Win95 任务栏的句柄} <br><br>StrPCopy(@WndClass[0], 'Progman'); <br><br>TrayHandle := FindWindow(@WndClass[0], nil); <br><br>{下面开始处理消息} <br><br>case Msg of <br><br>{收到窗口创建消息 - 在任务栏上显示一个图标} <br><br>wm_Create: // Program initialisation - just set up a tray icon <br><br>begin <br><br><br>tid.cbSize := sizeof (tid); <br><br>tid.Wnd := Wnd; <br><br>tid.uID := 1; <br><br>tid.uFlags := nif_Message or nif_Icon or nif_Tip; <br><br>tid.uCallBackMessage := wm_User; <br><br>tid.hIcon := LoadIcon (hInstance, 'MAINICON'); <br><br>lstrcpy (tid.szTip,'Desktop is on'); <br><br>Shell_NotifyIcon (nim_Add, @tid); <br><br>end; <br><br>&nbsp; <br><br>wm_Destroy: {收到关闭窗口消息时的处理} <br><br>begin <br><br>Shell_NotifyIcon (nim_Delete, @tid); <br><br>PostQuitMessage (0); <br><br>ShowWindow(TrayHandle, SW_RESTORE); <br><br>end; <br><br>{收到菜单消息时调用 HandleCommand 过程,并退出函数} <br><br>wm_Command: // Command notification <br><br>begin <br><br>HandleCommand (Wnd, LoWord (wParam)); <br><br>Exit; <br><br>end; <br><br>{收到其他用户消息时的处理} <br><br>wm_User: // Had a tray notification - see what to do <br><br>{如果单击了鼠标左键, 则打开或关闭桌面} <br><br>if (lParam = wm_LButtonDown) then <br><br>begin <br><br>if x = 0 then <br><br>begin <br><br>ShowWindow(TrayHandle, SW_HIDE); <br><br>tid.hIcon := LoadIcon (hInstance, 'offICON'); <br><br>lstrcpy (tid.szTip,'Desktop is off'); <br><br>Shell_NotifyIcon (NIM_MODIFY, @tid); <br><br>x:=1 <br><br>end else <br><br>begin <br><br>ShowWindow(TrayHandle, SW_RESTORE); <br><br>tid.hIcon := LoadIcon (hInstance, 'ONICON'); <br><br>lstrcpy (tid.szTip,'Desktop is on'); <br><br>Shell_NotifyIcon (NIM_MODIFY, @tid); <br><br>x:= 0; <br><br>end; {end of if} <br><br>end else <br><br>{如果是鼠标右键,则动态生成一个弹出式菜单} <br><br>if (lParam = wm_RButtonDown) then <br><br>begin <br><br>GetCursorPos (pt); <br><br>pm := CreatePopupMenu; <br><br>AppendMenu (pm, 0, Ord ('A'), 'About DeskTop Hide...'); <br><br>AppendMenu (pm, mf_Separator, 0, Nil); <br><br>AppendMenu (pm, 0, Ord ('E'), 'Exit DeskTop Hide'); <br><br>SetForegroundWindow (Wnd); <br><br>dc := GetDC (0); <br><br>if TrackPopupMenu (pm, tpm_BottomAlign or tpm_RightAlign, <br><br>pt.x,GetDeviceCaps(dc,HORZRES){pt.y}, 0, Wnd, Nil) <br><br>then SetForegroundWindow (Wnd); <br><br>DestroyMenu (pm) <br><br>end; {end of if} <br><br>end; {end of case} <br><br>{在处理过消息之后,还要调用默认函数,以完成标准的Windows程序应该执行的任务,所 <br><br>以这一句非常重 <br><br>要} <br><br>DummyWindowProc := DefWindowProc (Wnd, Msg, wParam, lParam); <br><br>end; <br><br>&nbsp; <br><br>{这个就是处理菜单消息的过程} <br><br>procedure HandleCommand (Wnd: hWnd; Cmd: Word); <br><br>begin <br><br>case Cmd of <br><br>Ord ('A'): MessageBox (0, 'Freeware brian.slack@strath.ac.uk 1997', <br><br>AppName, mb_ok); <br><br>Ord ('E'): PostMessage (Wnd, wm_Close, 0, 0); <br><br>end; <br><br>end; <br><br>&nbsp; <br><br>至此我们已经完成了这个只有38K的能将Win95桌面隐藏起来的程序,只要将本文中所 <br><br>有的函数和过程的顺序倒置,并将主程序放到最后,即可编译通过。<br>
 
use api<br>find in win api<br>you can look windows programme
 
用delphi实现这些功能当然没问题了<br>这些功能即使全用汇编都没多大难度
 
接受答案了.
 

Similar threads

S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
D
回复
0
查看
2K
DelphiTeacher的专栏
D
D
回复
0
查看
2K
DelphiTeacher的专栏
D
后退
顶部