- int x = 5;
- int y = 5;
- int gap = 5;
-
- m_closeButton = new wxButton(this, wxID_PREVIEW_CLOSE, _("Close"),
- wxPoint(x, y), wxSize(buttonWidth, buttonHeight));
-
- x += gap + buttonWidth;
-
- if (m_buttonFlags & wxPREVIEW_PRINT)
- {
- m_printButton = new wxButton(this, wxID_PREVIEW_PRINT, _("Print..."), wxPoint(x, y),
- wxSize(buttonWidth, buttonHeight));
- x += gap + buttonWidth;
- }
-
- if (m_buttonFlags & wxPREVIEW_PREVIOUS)
- {
- m_previousPageButton = new wxButton(this, wxID_PREVIEW_PREVIOUS, "<<", wxPoint(x, y),
- wxSize(buttonWidth, buttonHeight));
- x += gap + buttonWidth;
- }
-
- if (m_buttonFlags & wxPREVIEW_NEXT)
- {
- m_nextPageButton = new wxButton(this, wxID_PREVIEW_NEXT, ">>",
- wxPoint(x, y), wxSize(buttonWidth, buttonHeight));
- x += gap + buttonWidth;
- }
-
- // Yes, this look stupid, but this is because gcc gives up otherwise.
- wxString *choices = new wxString[23];
- choices[0] = "10%";
- choices[1] = "15%";
- choices[2] = "20%";
- choices[3] = "25%";
- choices[4] = "30%";
- choices[5] = "35%";
- choices[6] = "40%";
- choices[7] = "45%";
- choices[8] = "50%";
- choices[9] = "55%";
- choices[10] = "60%";
- choices[11] = "65%";
- choices[12] = "70%";
- choices[13] = "75%";
- choices[14] = "80%";
- choices[15] = "85%";
- choices[16] = "90%";
- choices[17] = "95%";
- choices[18] = "100%";
- choices[19] = "110%";
- choices[20] = "120%";
- choices[21] = "150%";
- choices[22] = "200%";
-
- int n = 23;
- if (m_buttonFlags & wxPREVIEW_ZOOM)
- {
- m_zoomControl = new wxChoice(this, wxID_PREVIEW_ZOOM, wxPoint(x, y),
- wxSize(100, -1), n, (wxString *)choices);
- SetZoomControl(m_printPreview->GetZoom());
- }
-
- delete[] choices;
-
- m_closeButton->SetDefault();
+ wxBoxSizer *item0 = new wxBoxSizer( wxHORIZONTAL );
+
+ int smallButtonWidth = 45;
+
+ m_closeButton = new wxButton( this, wxID_PREVIEW_CLOSE, _("&Close"), wxDefaultPosition, wxDefaultSize, 0 );
+ item0->Add( m_closeButton, 0, wxALIGN_CENTRE|wxALL, 5 );
+
+ if (m_buttonFlags & wxPREVIEW_PRINT)
+ {
+ m_printButton = new wxButton( this, wxID_PREVIEW_PRINT, _("&Print..."), wxDefaultPosition, wxDefaultSize, 0 );
+ item0->Add( m_printButton, 0, wxALIGN_CENTRE|wxALL, 5 );
+ }
+
+ if (m_buttonFlags & wxPREVIEW_FIRST)
+ {
+ m_firstPageButton = new wxButton( this, wxID_PREVIEW_FIRST, _("|<<"), wxDefaultPosition, wxSize(smallButtonWidth,-1), 0 );
+ item0->Add( m_firstPageButton, 0, wxALIGN_CENTRE|wxALL, 5 );
+ }
+
+ if (m_buttonFlags & wxPREVIEW_PREVIOUS)
+ {
+ m_previousPageButton = new wxButton( this, wxID_PREVIEW_PREVIOUS, _("<<"), wxDefaultPosition, wxSize(smallButtonWidth,-1), 0 );
+ item0->Add( m_previousPageButton, 0, wxALIGN_CENTRE|wxRIGHT|wxTOP|wxBOTTOM, 5 );
+ }
+
+ if (m_buttonFlags & wxPREVIEW_NEXT)
+ {
+ m_nextPageButton = new wxButton( this, wxID_PREVIEW_NEXT, _(">>"), wxDefaultPosition, wxSize(smallButtonWidth,-1), 0 );
+ item0->Add( m_nextPageButton, 0, wxALIGN_CENTRE|wxRIGHT|wxTOP|wxBOTTOM, 5 );
+ }
+
+ if (m_buttonFlags & wxPREVIEW_LAST)
+ {
+ m_lastPageButton = new wxButton( this, wxID_PREVIEW_LAST, _(">>|"), wxDefaultPosition, wxSize(smallButtonWidth,-1), 0 );
+ item0->Add( m_lastPageButton, 0, wxALIGN_CENTRE|wxRIGHT|wxTOP|wxBOTTOM, 5 );
+ }
+
+ if (m_buttonFlags & wxPREVIEW_GOTO)
+ {
+ m_gotoPageButton = new wxButton( this, wxID_PREVIEW_GOTO, _("&Goto..."), wxDefaultPosition, wxDefaultSize, 0 );
+ item0->Add( m_gotoPageButton, 0, wxALIGN_CENTRE|wxALL, 5 );
+ }
+
+ if (m_buttonFlags & wxPREVIEW_ZOOM)
+ {
+ wxString choices[] =
+ {
+ wxT("10%"), wxT("15%"), wxT("20%"), wxT("25%"), wxT("30%"), wxT("35%"), wxT("40%"), wxT("45%"), wxT("50%"), wxT("55%"),
+ wxT("60%"), wxT("65%"), wxT("70%"), wxT("75%"), wxT("80%"), wxT("85%"), wxT("90%"), wxT("95%"), wxT("100%"), wxT("110%"),
+ wxT("120%"), wxT("150%"), wxT("200%")
+ };
+ int n = WXSIZEOF(choices);
+
+ m_zoomControl = new wxChoice( this, wxID_PREVIEW_ZOOM, wxDefaultPosition, wxSize(70,-1), n, choices, 0 );
+ item0->Add( m_zoomControl, 0, wxALIGN_CENTRE|wxALL, 5 );
+ SetZoomControl(m_printPreview->GetZoom());
+ }
+
+ SetSizer(item0);
+ item0->Fit(this);