Delpi在MDI視窗中顯示圖形控制元件及指定背景的解決方案 (轉)
Delpi在MDI視窗中顯示圖形控制元件及指定背景的解決方案 (轉)[@more@]
在使用MDI介面時,有時候需要在MDI客戶視窗中顯示一些圖形或封面,使得軟體介面不會顯得空曠,軟體功能也能一目瞭然。然而在中並沒有直接給出這些介面。在MDI窗體中放入任何圖形在執行時都不能顯示。因此需要對MDI窗體進行改造。
申明:
本方案僅針對MDI窗體,如果應用在非MDI窗體中,後果難說,你自已試試吧。
記住,窗體的FormStyle屬性要設定為:fsMDIForm。
解決方案:
1. 在MDI主窗體中無法接收到MDI客戶視窗的訊息(Message),因此,需要自已定義客戶視窗的處理過程(Window Procedure),並接管MDI客戶視窗(需在過載的CreateWnd過程中實現):
procedure TMDIForm.CreateWnd;
begin
inherited;
FNewWndProc := MakeInstance(ClientWndProc);
FOldWndProc := Pointer(GetWindowLong(ClientHandle, GWL_WNDPROC));
SetWindowLong(ClientHandle, GWL_WNDPROC, Longint(FNewWndProc));
end;
其中,ClientWndProc為自定義的視窗過程: procedure ClientWndProc(var Message: TMessage);
FOldWndProc用來存放舊的視窗過程的指標。
2. 實現自已的客戶視窗過程:
procedure TMDIForm.ClientWndProc(var Message: TMessage);
var
R: TRECT;
procedure Default;
begin
with Message do
Result := CallWindowProc(FOldWndProc, ClientHandle, Msg, wParam, lParam);
end;
var
PS: TPaintStruct;
begin
R := ClientRect;
case Message.Msg of
WM_PAINT:
begin
BeginPaint(ClientHandle,PS);
try
Canvas.Lock;
try
Canvas.Handle := PS.hdc;
try
Paint;
if ControlCount > 0 then
PaintControls(PS.hdc,Controls[0]);
finally
Canvas.Handle := 0;
end;
finally
Canvas.Unlock;
end;
finally
EndPaint(ClientHandle,PS);
end;
end;
WM_ERASEBKGND:
begin
DrawBG(TWMEraseBkGnd(Message).DC);
Message.Result := 1;
end;
WM_VSCROLL,WM_HSCROLL:
begin
InvalidateRect(ClientHandle,@R,true);
Default;
end;
WM_SIZE:
begin
InvalidateRect(ClientHandle,@R,true);
Default;
end;
else
Default;
end;
end;
上面的DrawBG是用於畫視窗背景的。
3. 實現視窗背景。
為了可以讓繼承者也能定義自已的背景,故此過程說明為virtual:
protected
procedure DrawBG(DC: HDC); virtual;
在此,DrawBG過程只是簡單的填充視窗背景:
procedure TMDIForm.DrawBG(DC: HDC);
begin
if Brush.Color <> clNone then
FillRect(DC, ClientRect, Brush.Handle);
end;
4. 綜上所述,總結TMDIFrom類定義如下:
TMDIFo= class(TForm)
private
FOldWndProc: TFroc;
FNewWndProc: TFarProc;
procedure ClientWndProc(var Message: TMessage);
protected
procedure DrawBG(DC: HDC);virtual;
procedure CreateWnd; overr;
end;
5. 經過以上改造後,就可以在DrawBG中畫出指定的背景(需直接 的GUI介面),或者直接使用圖形控制元件,或者實現窗體的OnPaint事件,MDI視窗從此多姿多彩。
在使用MDI介面時,有時候需要在MDI客戶視窗中顯示一些圖形或封面,使得軟體介面不會顯得空曠,軟體功能也能一目瞭然。然而在中並沒有直接給出這些介面。在MDI窗體中放入任何圖形在執行時都不能顯示。因此需要對MDI窗體進行改造。
申明:
本方案僅針對MDI窗體,如果應用在非MDI窗體中,後果難說,你自已試試吧。
記住,窗體的FormStyle屬性要設定為:fsMDIForm。
解決方案:
1. 在MDI主窗體中無法接收到MDI客戶視窗的訊息(Message),因此,需要自已定義客戶視窗的處理過程(Window Procedure),並接管MDI客戶視窗(需在過載的CreateWnd過程中實現):
procedure TMDIForm.CreateWnd;
begin
inherited;
FNewWndProc := MakeInstance(ClientWndProc);
FOldWndProc := Pointer(GetWindowLong(ClientHandle, GWL_WNDPROC));
SetWindowLong(ClientHandle, GWL_WNDPROC, Longint(FNewWndProc));
end;
其中,ClientWndProc為自定義的視窗過程: procedure ClientWndProc(var Message: TMessage);
FOldWndProc用來存放舊的視窗過程的指標。
2. 實現自已的客戶視窗過程:
procedure TMDIForm.ClientWndProc(var Message: TMessage);
var
R: TRECT;
procedure Default;
begin
with Message do
Result := CallWindowProc(FOldWndProc, ClientHandle, Msg, wParam, lParam);
end;
var
PS: TPaintStruct;
begin
R := ClientRect;
case Message.Msg of
WM_PAINT:
begin
BeginPaint(ClientHandle,PS);
try
Canvas.Lock;
try
Canvas.Handle := PS.hdc;
try
Paint;
if ControlCount > 0 then
PaintControls(PS.hdc,Controls[0]);
finally
Canvas.Handle := 0;
end;
finally
Canvas.Unlock;
end;
finally
EndPaint(ClientHandle,PS);
end;
end;
WM_ERASEBKGND:
begin
DrawBG(TWMEraseBkGnd(Message).DC);
Message.Result := 1;
end;
WM_VSCROLL,WM_HSCROLL:
begin
InvalidateRect(ClientHandle,@R,true);
Default;
end;
WM_SIZE:
begin
InvalidateRect(ClientHandle,@R,true);
Default;
end;
else
Default;
end;
end;
上面的DrawBG是用於畫視窗背景的。
3. 實現視窗背景。
為了可以讓繼承者也能定義自已的背景,故此過程說明為virtual:
protected
procedure DrawBG(DC: HDC); virtual;
在此,DrawBG過程只是簡單的填充視窗背景:
procedure TMDIForm.DrawBG(DC: HDC);
begin
if Brush.Color <> clNone then
FillRect(DC, ClientRect, Brush.Handle);
end;
4. 綜上所述,總結TMDIFrom類定義如下:
TMDIFo= class(TForm)
private
FOldWndProc: TFroc;
FNewWndProc: TFarProc;
procedure ClientWndProc(var Message: TMessage);
protected
procedure DrawBG(DC: HDC);virtual;
procedure CreateWnd; overr;
end;
5. 經過以上改造後,就可以在DrawBG中畫出指定的背景(需直接 的GUI介面),或者直接使用圖形控制元件,或者實現窗體的OnPaint事件,MDI視窗從此多姿多彩。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752043/viewspace-989774/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 一個問題——在MDI窗體中新增控制元件後顯示子窗體控制元件
- 解決winform中mdi子窗體載入時顯示最大化最小化按鈕的方法ORM
- mfc+最大最小化視窗+控制元件變化+圖片(視訊幀)顯示在控制元件上控制元件
- 想把圖片當背景,但是其他控制元件背景設為透明色後,顯示的是背景顏色的問題解決控制元件
- win7圖片只顯示圖示不顯示預覽圖解決方案Win7圖解
- Qt之彈出介面顯示在父視窗中間QT
- Activity背景顯示app圖示APP
- QT中 視窗部件的 背景圖片 的設定QT
- Qt中設定視窗居中顯示QT
- 人工設定視窗圖示 (轉)
- qt設定視窗在桌面居中顯示QT
- Qt視窗在螢幕上居中顯示QT
- JSP顯示中文問題的解決方案(轉)JS
- QT使用scrollarea顯示圖片,完美解決方案QT
- VC中給樹形控制元件的圖示加上工具提示 (轉)控制元件
- 在工作列上顯示圖示 (轉)
- 完美解決IE中PNG格式透明背景圖片顯示異常的各種方法【Z】
- qt視窗居中顯示QT
- Qt的視窗背景及視窗風格統一與煥膚QT
- Word表格在WPS中顯示不全的解決
- wps演示中在工作列中顯示所有視窗怎麼設定
- html中背景圖按比例縮放全屏顯示HTML
- mac 文件顯示圖示和軟體圖示不一致 解決方案Mac
- 直播帶貨原始碼,背景圖片顯示鋪滿但不變形原始碼
- 在RFT中查詢視窗中指定名稱的物件物件
- Linux下jdk1.5的安裝及中文顯示問題解決方案(轉)LinuxJDK
- 解決WinForm(C#)中MDI子窗體最大化跑偏的問題ORMC#
- 解決vi 在FC5中沒有高亮顯示的問題(轉)
- 子視窗控制元件(轉)控制元件
- Android之改變控制元件的背景及形態Android控制元件
- 在Delphi中實現任意形狀的窗體 (轉)
- asp.net 呼叫echarts顯示圖表控制元件隨瀏覽器自適應解決方案ASP.NETEcharts控制元件瀏覽器
- 小程式button背景顯示圖片
- Extjs 在GridPanel中顯示圖示的方法JS
- DOS視窗中顯示UTF-8字元字元
- 解決Raize日曆控制元件顯示的問題AI控制元件
- Qt 設定視窗居中顯示QT
- Qt5:視窗居中顯示QT