ページ 1 / 1
「ウィンドウ背景色の維持」について
Posted: 2005年11月10日(木) 09:04
by KICO
何時も、お世話に成っています。
子ウィンドウ同士重ねると背景色が重なった部分だけ相手の色に変わってしまいます。
背景色を維持する方法を教えて下さい。
[ここをクリックすると内容が表示されます] [ここをクリックすると非表示にします]
[サンプル]
プロジェクト名:BackGroundTest
メインウィンドウ (通常ウィンドウ)
ID:MainWnd ボタン1個
子ウィンドウ (モーダル ダイアログ)
ID:Dlg1 ボタン1個
ID:Dlg2
コード: 全て選択
' ウィンドウ ハンドル: hMainWnd
' TODO: この位置にグローバルな変数、構造体、定数、関数を定義します。
Dim hBF1 As DWord
Dim hBF2 As DWord
Dim BGC1 As DWord
Dim BGC2 As DWord
BGC1=&hff 'ダイアログ ボックス1の背景色
BGC2=&hffff 'ダイアログ ボックス2の背景色
'--------------------------------------------------------------------
' ここから下は、イベントプロシージャを記述するための領域になります。
Sub MainWnd_Destroy()
BackGroundTest_DestroyObjects()
PostQuitMessage(0)
End Sub
Sub MainWnd_CommandButton1_Click()
'ダイアログ ボックス1を表示する
DialogBox(hMainWnd, "Dlg1")
End Sub
コード: 全て選択
' ウィンドウ ハンドル: hDlg1
' ここから下は、イベントプロシージャを記述するための領域になります。
Sub Dlg1_Create(ByRef CreateStruct As CREATESTRUCT)
'Dlg1のウィンドウ背景色変更
hBF1=CreateSolidBrush(BGC1)
SetClassLong(hDlg1, GCL_HBRBACKGROUND, hBF1)
End Sub
Sub Dlg1_Destroy()
DeleteObject(hBF1)
End Sub
Sub Dlg1_CommandButton1_Click()
'ダイアログ ボックス2を表示
DialogBox(hMainWnd, "Dlg2")
End Sub
コード: 全て選択
' ウィンドウ ハンドル: hDlg2
' ここから下は、イベントプロシージャを記述するための領域になります。
Sub Dlg2_Create(ByRef CreateStruct As CREATESTRUCT)
'Dlg2のウィンドウ背景色変更
hBF2=CreateSolidBrush(BGC2)
SetClassLong(hDlg2, GCL_HBRBACKGROUND, hBF2)
End Sub
Sub Dlg2_Destroy()
DeleteObject(hBF2)
End Sub
宜しくお願いします。
こんな感じでしょうか?
Posted: 2005年11月11日(金) 16:33
by hanchan
長方形を描画して対応してみました。
これでよいのか不安ですが。。。
[ここをクリックすると内容が表示されます] [ここをクリックすると非表示にします]
MainWnd
コード: 全て選択
'-----------------------------------------------------------------------------
' イベント プロシージャ
'-----------------------------------------------------------------------------
' このファイルには、ウィンドウ [MainWnd] に関するイベントをコーディングします。
' ウィンドウ ハンドル: hMainWnd
' TODO: この位置にグローバルな変数、構造体、定数、関数を定義します。
Const BGC1 = &hff 'ダイアログ ボックス1の背景色
Const BGC2 = &hffff 'ダイアログ ボックス2の背景色
'-----------------------------------------------------------------------------
' ウィンドウメッセージを処理するためのコールバック関数
Function MainWndProc(hWnd As HWND, dwMsg As DWord, wParam As WPARAM, lParam As LPARAM) As DWord
' TODO: この位置にウィンドウメッセージを処理するためのコードを記述します。
' イベントプロシージャの呼び出しを行います。
MainWndProc=EventCall_MainWnd(hWnd,dwMsg,wParam,lParam)
End Function
'-----------------------------------------------------------------------------
' ここから下は、イベントプロシージャを記述するための領域になります。
Sub MainWnd_Destroy()
BackGroundTest_DestroyObjects()
PostQuitMessage(0)
End Sub
Sub MainWnd_CommandButton1_Click()
'ダイアログ ボックス1を表示する
DialogBox(hMainWnd, "Dlg1")
End Sub
Dlg1
コード: 全て選択
'-----------------------------------------------------------------------------
' イベント プロシージャ
'-----------------------------------------------------------------------------
' このファイルには、ウィンドウ [Dlg1] に関するイベントをコーディングします。
' ウィンドウ ハンドル: hDlg1
' TODO: この位置にグローバルな変数、構造体、定数、関数を定義します。
'-----------------------------------------------------------------------------
' ウィンドウメッセージを処理するためのコールバック関数
Function Dlg1Proc(hWnd As HWND, dwMsg As DWord, wParam As WPARAM, lParam As LPARAM) As DWord
' TODO: この位置にウィンドウメッセージを処理するためのコードを記述します。
' イベントプロシージャの呼び出しを行います。
Dlg1Proc=EventCall_Dlg1(hWnd,dwMsg,wParam,lParam)
End Function
'-----------------------------------------------------------------------------
' ここから下は、イベントプロシージャを記述するための領域になります。
Sub Dlg1_CommandButton1_Click()
'ダイアログ ボックス2を表示
DialogBox(hMainWnd, "Dlg2")
End Sub
Sub Dlg1_Create(ByRef CreateStruct As CREATESTRUCT)
End Sub
Sub Dlg1_Paint(hDC As HDC)
Dim hBF As HBRUSH
Dim rBF As RECT
rBF.left = 0
rBF.top = 0
rBF.right = 200 'ウインドウ幅
rBF.bottom = 100 'ウインドウ高さ
hBF = CreateSolidBrush(BGC1)
FillRect(hDC, rBF, hBF)
DeleteObject(hBF)
End Sub
Dlg2
コード: 全て選択
'-----------------------------------------------------------------------------
' イベント プロシージャ
'-----------------------------------------------------------------------------
' このファイルには、ウィンドウ [Dlg2] に関するイベントをコーディングします。
' ウィンドウ ハンドル: hDlg2
' TODO: この位置にグローバルな変数、構造体、定数、関数を定義します。
'-----------------------------------------------------------------------------
' ウィンドウメッセージを処理するためのコールバック関数
Function Dlg2Proc(hWnd As HWND, dwMsg As DWord, wParam As WPARAM, lParam As LPARAM) As DWord
' TODO: この位置にウィンドウメッセージを処理するためのコードを記述します。
' イベントプロシージャの呼び出しを行います。
Dlg2Proc=EventCall_Dlg2(hWnd,dwMsg,wParam,lParam)
End Function
'-----------------------------------------------------------------------------
' ここから下は、イベントプロシージャを記述するための領域になります。
Sub Dlg2_Paint(hDC As HDC)
Dim hBF As HBRUSH
Dim rBF As RECT
rBF.left = 0
rBF.top = 0
rBF.right = 200 'ウインドウ幅
rBF.bottom = 100 'ウインドウ高さ
hBF = CreateSolidBrush(BGC2)
FillRect(hDC, rBF, hBF)
DeleteObject(hBF)
End Sub
Re:「ウィンドウ背景色の維持」について
Posted: 2005年11月11日(金) 18:37
by KICO
hanchan様、ありがとう御座います。
頂いたコードで、背景色を維持する事が出来ました。(^o^)
[質問]
"SetClassLong(hxx, GCL_HBRBACKGROUND, xxx)"は、どういった時に使用するのでしょうか?
又、なぜ維持出来無いのでしょうか?
宜しくお願いします。
Re:「ウィンドウ背景色の維持」について
Posted: 2005年11月17日(木) 10:18
by hanchan
> "SetClassLong(hxx, GCL_HBRBACKGROUND, xxx)"は、どういった時に使用するのでしょうか?
SetClassLong()はウインドウクラスの値を変更する関数です。
その為、ウインドウクラスの背景色を変更したり、カーソルを変更したりすることが可能です。
ウインドウクラスを意識するのはCreateWindowEx()でウインドウを作成した場合ですので、CreateWindowEx()でウインドウを作成した場合に使用します。
> 又、なぜ維持出来無いのでしょうか?
Callback.wbpを開いてみれば解りますが、RADツールでウインドウを作成した場合、各ウインドウで同一のウインドウクラスを使用しています。
(ダイアログで共通?)
その為、1ウインドウの背景色を変更すると他のウインドウの背景色も変更
されてしまいます。
このような場合は、ウインドウクラスを別々に作成することで回避できるようです。
以下のURLにウインドウクラスを別々に作成した際のサンプルを公開します。
参考にしてください。
http://briefcase.yahoo.co.jp/bc/hanchan ... ip&.src=bc
MainWnd.sbpの先頭にある
#define TESTMODE
をコメントアウトすると、別々のウインドウクラスを使用して画面を動かします。
コメントアウトしないと、ウインドウクラスを共有した動きになります。
解決 :「ウィンドウ背景色の維持」について
Posted: 2005年11月18日(金) 12:23
by KICO
hanchan様、ありがとう御座います。
ウインドウクラスを意識するのはCreateWindowEx()でウインドウを作成した場合ですので、
CreateWindowEx()でウインドウを作成した場合に使用します。
RADツールでウインドウを作成した場合、各ウインドウで同一のウインドウクラスを
使用しています。
ウインドウクラスを別々に作成することで回避できるようです。
RADツールでウインドウを作成した場合は、前回で頂いたサンプルの様に"WM_PRINT"で
再描画するしか無いって言う事ですネ。(^_-)
サンプルまで作って頂きまして、ありがとう御座いました。
今後共、宜しくお願いします。
Re: 「ウィンドウ背景色の維持」について
Posted: 2005年11月18日(金) 19:07
by A passer-by
> 子ウィンドウ同士重ねると背景色が重なった部分だけ相手の色に変わってしまいます。
Read this;
WS_CLIPSIBLINGS Clips child windows relative to each other; that is, when a particular child window receives a WM_PAINT message, the WS_CLIPSIBLINGS style clips all other overlapping child windows out of the region of the child window to be updated. If WS_CLIPSIBLINGS is not specified and child windows overlap, it is possible, when drawing within the client area of a child window, to draw within the client area of a neighboring child window.
also;
WS_CLIPCHILDREN Excludes the area occupied by child windows when drawing occurs within the parent window. This style is used when creating the parent window.