added more tests for MDI frame size/position

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/branches/WX_2_2_BRANCH@8003 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2000-08-10 08:42:34 +00:00
parent 0a78ba3df5
commit 517444edb1
2 changed files with 52 additions and 1 deletions

View File

@@ -81,6 +81,11 @@ BEGIN_EVENT_TABLE(MyChild, wxMDIChildFrame)
EVT_MENU(MDI_CHILD_QUIT, MyChild::OnQuit) EVT_MENU(MDI_CHILD_QUIT, MyChild::OnQuit)
EVT_MENU(MDI_REFRESH, MyChild::OnRefresh) EVT_MENU(MDI_REFRESH, MyChild::OnRefresh)
EVT_MENU(MDI_CHANGE_TITLE, MyChild::OnChangeTitle) EVT_MENU(MDI_CHANGE_TITLE, MyChild::OnChangeTitle)
EVT_MENU(MDI_CHANGE_POSITION, MyChild::OnChangePosition)
EVT_MENU(MDI_CHANGE_SIZE, MyChild::OnChangeSize)
EVT_SIZE(MyChild::OnSize)
EVT_MOVE(MyChild::OnMove)
EVT_CLOSE(MyChild::OnClose) EVT_CLOSE(MyChild::OnClose)
END_EVENT_TABLE() END_EVENT_TABLE()
@@ -236,6 +241,9 @@ void MyFrame::OnNewWindow(wxCommandEvent& WXUNUSED(event) )
option_menu->Append(MDI_REFRESH, "&Refresh picture"); option_menu->Append(MDI_REFRESH, "&Refresh picture");
option_menu->Append(MDI_CHANGE_TITLE, "Change &title...\tCtrl-T"); option_menu->Append(MDI_CHANGE_TITLE, "Change &title...\tCtrl-T");
option_menu->AppendSeparator();
option_menu->Append(MDI_CHANGE_POSITION, "Move frame\tCtrl-M");
option_menu->Append(MDI_CHANGE_SIZE, "Resize frame\tCtrl-S");
wxMenu *help_menu = new wxMenu; wxMenu *help_menu = new wxMenu;
help_menu->Append(MDI_ABOUT, "&About"); help_menu->Append(MDI_ABOUT, "&About");
@@ -243,7 +251,7 @@ void MyFrame::OnNewWindow(wxCommandEvent& WXUNUSED(event) )
wxMenuBar *menu_bar = new wxMenuBar; wxMenuBar *menu_bar = new wxMenuBar;
menu_bar->Append(file_menu, "&File"); menu_bar->Append(file_menu, "&File");
menu_bar->Append(option_menu, "&Options"); menu_bar->Append(option_menu, "&Child");
menu_bar->Append(help_menu, "&Help"); menu_bar->Append(help_menu, "&Help");
// Associate the menu bar with the frame // Associate the menu bar with the frame
@@ -422,6 +430,16 @@ void MyChild::OnRefresh(wxCommandEvent& WXUNUSED(event))
canvas->Refresh(); canvas->Refresh();
} }
void MyChild::OnChangePosition(wxCommandEvent& WXUNUSED(event))
{
Move(10, 10);
}
void MyChild::OnChangeSize(wxCommandEvent& WXUNUSED(event))
{
SetClientSize(100, 100);
}
void MyChild::OnChangeTitle(wxCommandEvent& WXUNUSED(event)) void MyChild::OnChangeTitle(wxCommandEvent& WXUNUSED(event))
{ {
static wxString s_title = _T("Canvas Frame"); static wxString s_title = _T("Canvas Frame");
@@ -443,6 +461,33 @@ void MyChild::OnActivate(wxActivateEvent& event)
canvas->SetFocus(); canvas->SetFocus();
} }
void MyChild::OnMove(wxMoveEvent& event)
{
// VZ: here everything is totally wrong under MSW, the positions are
// different and both wrong (pos2 is off by 2 pixels for me which seems
// to be the width of the MDI canvas border)
wxPoint pos1 = event.GetPosition(),
pos2 = GetPosition();
wxLogStatus("position from event: (%d, %d), from frame (%d, %d)",
pos1.x, pos1.y, pos2.x, pos2.y);
event.Skip();
}
void MyChild::OnSize(wxSizeEvent& event)
{
// VZ: under MSW the size event carries the client size (quite
// unexpectedly) *except* for the very first one which has the full
// size... what should it really be? TODO: check under wxGTK
wxSize size1 = event.GetSize(),
size2 = GetSize(),
size3 = GetClientSize();
wxLogStatus("size from event: %dx%d, from frame %dx%d, client %dx%d",
size1.x, size1.y, size2.x, size2.y, size3.x, size3.y);
event.Skip();
}
void MyChild::OnClose(wxCloseEvent& event) void MyChild::OnClose(wxCloseEvent& event)
{ {
if ( canvas && canvas->IsDirty() ) if ( canvas && canvas->IsDirty() )

View File

@@ -65,7 +65,11 @@ public:
void OnRefresh(wxCommandEvent& event); void OnRefresh(wxCommandEvent& event);
void OnChangeTitle(wxCommandEvent& event); void OnChangeTitle(wxCommandEvent& event);
void OnChangePosition(wxCommandEvent& event);
void OnChangeSize(wxCommandEvent& event);
void OnQuit(wxCommandEvent& event); void OnQuit(wxCommandEvent& event);
void OnSize(wxSizeEvent& event);
void OnMove(wxMoveEvent& event);
void OnClose(wxCloseEvent& event); void OnClose(wxCloseEvent& event);
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()
@@ -78,6 +82,8 @@ enum
MDI_NEW_WINDOW, MDI_NEW_WINDOW,
MDI_REFRESH, MDI_REFRESH,
MDI_CHANGE_TITLE, MDI_CHANGE_TITLE,
MDI_CHANGE_POSITION,
MDI_CHANGE_SIZE,
MDI_CHILD_QUIT, MDI_CHILD_QUIT,
MDI_ABOUT MDI_ABOUT
}; };