X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c50e42a1223f6da4a07f5c8472a3fe7bf682356a..301e257baf3a227beb587749134bbc40786f761f:/src/common/dlgcmn.cpp diff --git a/src/common/dlgcmn.cpp b/src/common/dlgcmn.cpp index 4894b08cbb..b599012aa5 100644 --- a/src/common/dlgcmn.cpp +++ b/src/common/dlgcmn.cpp @@ -72,9 +72,9 @@ void wxDialogBase::Init() wxSizer *wxDialogBase::CreateTextSizer( const wxString& message ) { bool is_pda = (wxSystemSettings::GetScreenType() <= wxSYS_SCREEN_PDA); - + wxString text = message; - + // I admit that this is complete bogus, but it makes // message boxes work for pda screens temporarily.. int max_width = -1; @@ -83,8 +83,8 @@ wxSizer *wxDialogBase::CreateTextSizer( const wxString& message ) max_width = wxSystemSettings::GetMetric( wxSYS_SCREEN_X ) - 25; text += wxT('\n'); } - - + + wxBoxSizer *box = new wxBoxSizer( wxVERTICAL ); // get line height for empty lines @@ -103,7 +103,7 @@ wxSizer *wxDialogBase::CreateTextSizer( const wxString& message ) case wxT('\n'): if (!line.IsEmpty()) { - wxStaticText *s = new wxStaticText( this, -1, line ); + wxStaticText *s = new wxStaticText( this, wxID_ANY, line ); box->Add( s ); line = wxT(""); } @@ -125,27 +125,27 @@ wxSizer *wxDialogBase::CreateTextSizer( const wxString& message ) default: if (text[pos] == wxT(' ')) last_space = pos; - + line += message[pos]; - + if (is_pda) { int width = 0; GetTextExtent( line, &width, (int*)NULL, (int*)NULL, (int*)NULL, &font ); - + if (width > max_width) { // exception if there was no previous space if (last_space == 0) last_space = pos; - + int diff = pos-last_space; int len = line.Len(); line.Remove( len-diff, diff ); - - wxStaticText *s = new wxStaticText( this, -1, line ); + + wxStaticText *s = new wxStaticText( this, wxID_ANY, line ); box->Add( s ); - + pos = last_space; last_space = 0; line = wxT(""); @@ -157,7 +157,7 @@ wxSizer *wxDialogBase::CreateTextSizer( const wxString& message ) // remaining text behind last '\n' if (!line.IsEmpty()) { - wxStaticText *s2 = new wxStaticText( this, -1, line ); + wxStaticText *s2 = new wxStaticText( this, wxID_ANY, line ); box->Add( s2 ); } @@ -171,13 +171,13 @@ wxSizer *wxDialogBase::CreateTextSizer( const wxString& message ) wxSizer *wxDialogBase::CreateButtonSizer( long flags ) { bool is_pda = (wxSystemSettings::GetScreenType() <= wxSYS_SCREEN_PDA); - - // If we have a PDA screen, put yes/no button over + + // If we have a PDA screen, put yes/no button over // all other buttons, otherwise on the left side. wxBoxSizer *box = is_pda ? new wxBoxSizer( wxVERTICAL ) : new wxBoxSizer( wxHORIZONTAL ); - + wxBoxSizer *inner_yes_no = NULL; - + // Only create sizer containing yes/no // if it is actually required if ( (flags & wxYES_NO) != 0 ) @@ -185,7 +185,7 @@ wxSizer *wxDialogBase::CreateButtonSizer( long flags ) inner_yes_no = new wxBoxSizer( wxHORIZONTAL ); box->Add( inner_yes_no, 0, wxBOTTOM, 10 ); } - + wxBoxSizer *inner_rest = new wxBoxSizer( wxHORIZONTAL ); box->Add( inner_rest, 0, 0, 0 ); @@ -205,33 +205,33 @@ wxSizer *wxDialogBase::CreateButtonSizer( long flags ) if (flags & wxYES) { - yes = new wxButton(this, wxID_YES, wxSTOCK_YES, - wxEmptyString, wxDefaultPosition, wxCLIP_SIBLINGS); + yes = new wxButton(this, wxID_YES, wxEmptyString, + wxDefaultPosition, wxDefaultSize, wxCLIP_SIBLINGS); inner_yes_no->Add( yes, 0, wxLEFT|wxRIGHT, margin ); } if (flags & wxNO) { - no = new wxButton(this, wxID_NO, wxSTOCK_NO, - wxEmptyString, wxDefaultPosition, wxCLIP_SIBLINGS); + no = new wxButton(this, wxID_NO, wxEmptyString, + wxDefaultPosition, wxDefaultSize, wxCLIP_SIBLINGS); inner_yes_no->Add( no, 0, wxLEFT|wxRIGHT, margin ); } if (flags & wxOK) { - ok = new wxButton(this, wxID_OK, wxSTOCK_OK, - wxEmptyString, wxDefaultPosition, wxCLIP_SIBLINGS); + ok = new wxButton(this, wxID_OK, wxEmptyString, + wxDefaultPosition, wxDefaultSize, wxCLIP_SIBLINGS); inner_rest->Add( ok, 0, wxLEFT|wxRIGHT, margin ); } if (flags & wxFORWARD) - inner_rest->Add(new wxButton(this, wxID_FORWARD, wxSTOCK_GO_FORWARD, - wxEmptyString, wxDefaultPosition, + inner_rest->Add(new wxButton(this, wxID_FORWARD, wxEmptyString, + wxDefaultPosition, wxDefaultSize, wxCLIP_SIBLINGS), 0, wxLEFT|wxRIGHT, margin); if (flags & wxBACKWARD) - inner_rest->Add(new wxButton(this, wxID_BACKWARD, wxSTOCK_GO_BACK, - wxEmptyString, wxDefaultPosition, + inner_rest->Add(new wxButton(this, wxID_BACKWARD, wxEmptyString, + wxDefaultPosition, wxDefaultSize, wxCLIP_SIBLINGS), 0, wxLEFT|wxRIGHT, margin); @@ -242,15 +242,15 @@ wxSizer *wxDialogBase::CreateButtonSizer( long flags ) inner_rest->Add( new wxButton( this, wxID_MORE, _("More..."),wxDefaultPosition,wxDefaultSize,wxCLIP_SIBLINGS ), 0, wxLEFT|wxRIGHT, margin ); if (flags & wxHELP) - inner_rest->Add(new wxButton(this, wxID_HELP, wxSTOCK_HELP, - wxEmptyString, wxDefaultPosition, + inner_rest->Add(new wxButton(this, wxID_HELP, wxEmptyString, + wxDefaultPosition, wxDefaultSize, wxCLIP_SIBLINGS), 0, wxLEFT|wxRIGHT, margin); if (flags & wxCANCEL) { - wxButton *cancel = new wxButton(this, wxID_CANCEL, wxSTOCK_CANCEL, - wxEmptyString, wxDefaultPosition, + wxButton *cancel = new wxButton(this, wxID_CANCEL, wxEmptyString, + wxDefaultPosition, wxDefaultSize, wxCLIP_SIBLINGS); inner_rest->Add( cancel, 0, wxLEFT|wxRIGHT, margin ); }