X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0c551f1c232840bda79b0b7106b9c11a2773ffaf..cfcc39321282c5877cbb45248bb8004ced24516b:/src/generic/gridg.cpp diff --git a/src/generic/gridg.cpp b/src/generic/gridg.cpp index 9ef503b3bb..a4d53fc435 100644 --- a/src/generic/gridg.cpp +++ b/src/generic/gridg.cpp @@ -25,6 +25,8 @@ #pragma hdrstop #endif +#if wxUSE_GRID && !(wxUSE_NEW_GRID) + #ifndef WX_PRECOMP #include "wx/utils.h" #include "wx/dcclient.h" @@ -49,6 +51,13 @@ #define wxUSE_DOUBLE_BUFFERING 1 #endif +#ifdef __WXPM__ +#define wxIPE_ADJUST -1 +#define wxIPE_STYLE wxNO_BORDER +#define wxIPE_HIGHLIGHT 1 +#define wxUSE_DOUBLE_BUFFERING 1 +#endif + #ifdef __WXGTK__ #define wxIPE_ADJUST -1 #define wxIPE_STYLE wxNO_BORDER @@ -116,7 +125,7 @@ wxGenericGrid::wxGenericGrid() m_cellBackgroundColour = *wxWHITE; m_labelTextColour = *wxBLACK; // m_labelBackgroundColour = *wxLIGHT_GREY; - m_labelBackgroundColour = wxSystemSettings::GetSystemColour( wxSYS_COLOUR_BTNFACE ); + m_labelBackgroundColour = wxSystemSettings::GetColour( wxSYS_COLOUR_BTNFACE ); m_labelBackgroundBrush = wxNullBrush; m_labelTextFont = wxNullFont; m_cellTextFont = wxNullFont; @@ -129,9 +138,9 @@ wxGenericGrid::wxGenericGrid() m_inScroll = FALSE; #if defined(__WIN95__) - m_scrollWidth = wxSystemSettings::GetSystemMetric(wxSYS_VSCROLL_X); + m_scrollWidth = wxSystemSettings::GetMetric(wxSYS_VSCROLL_X); #elif defined(__WXGTK__) - m_scrollWidth = wxSystemSettings::GetSystemMetric(wxSYS_VSCROLL_X); + m_scrollWidth = wxSystemSettings::GetMetric(wxSYS_VSCROLL_X); #else m_scrollWidth = 16; #endif @@ -186,7 +195,7 @@ bool wxGenericGrid::Create(wxWindow *parent, m_cellBackgroundColour = *wxWHITE; m_labelTextColour = *wxBLACK; // m_labelBackgroundColour = *wxLIGHT_GREY; - m_labelBackgroundColour = wxSystemSettings::GetSystemColour( wxSYS_COLOUR_BTNFACE ); + m_labelBackgroundColour = wxSystemSettings::GetColour( wxSYS_COLOUR_BTNFACE ); m_labelBackgroundBrush = wxNullBrush; m_labelTextFont = * wxTheFontList->FindOrCreateFont(10, wxSWISS, wxNORMAL, wxBOLD); m_cellTextFont = * wxTheFontList->FindOrCreateFont(10, wxSWISS, wxNORMAL, wxNORMAL); @@ -197,9 +206,9 @@ bool wxGenericGrid::Create(wxWindow *parent, m_inOnTextInPlace = FALSE; m_inScroll = FALSE; #if defined(__WIN95__) - m_scrollWidth = wxSystemSettings::GetSystemMetric(wxSYS_VSCROLL_X); + m_scrollWidth = wxSystemSettings::GetMetric(wxSYS_VSCROLL_X); #elif defined(__WXGTK__) - m_scrollWidth = wxSystemSettings::GetSystemMetric(wxSYS_VSCROLL_X); + m_scrollWidth = wxSystemSettings::GetMetric(wxSYS_VSCROLL_X); #else m_scrollWidth = 16; #endif @@ -207,7 +216,7 @@ bool wxGenericGrid::Create(wxWindow *parent, m_dragRowOrCol = 0; m_dragStartPosition = 0; m_dragLastPosition = 0; - m_divisionPen = * wxThePenList->FindOrCreatePen("LIGHT GREY", 1, wxSOLID); + m_divisionPen = * wxThePenList->FindOrCreatePen(wxT("LIGHT GREY"), 1, wxSOLID); m_highlightPen = * wxBLACK_PEN; m_doubleBufferingBitmap = (wxBitmap *) NULL; @@ -258,7 +267,7 @@ bool wxGenericGrid::Create(wxWindow *parent, m_editingPanel = new wxPanel(this); - m_textItem = new wxTextCtrl(m_editingPanel, wxGRID_TEXT_CTRL, "", + m_textItem = new wxTextCtrl(m_editingPanel, wxGRID_TEXT_CTRL, wxT(""), wxPoint(m_editControlPosition.x, m_editControlPosition.y), wxSize(m_editControlPosition.width, -1), wxTE_PROCESS_ENTER); @@ -278,7 +287,7 @@ bool wxGenericGrid::Create(wxWindow *parent, // SetSize(pos.x, pos.y, size.x, size.y); - m_inPlaceTextItem = new wxTextCtrl( (wxPanel*)this, wxGRID_EDIT_IN_PLACE_TEXT_CTRL, "", + m_inPlaceTextItem = new wxTextCtrl( (wxPanel*)this, wxGRID_EDIT_IN_PLACE_TEXT_CTRL, wxT(""), wxPoint( m_currentRect.x-wxIPE_ADJUST, m_currentRect.y-wxIPE_ADJUST ), wxSize( m_currentRect.width+wxIPE_ADJUST*2, m_currentRect.height+wxIPE_ADJUST*2 ), wxNO_BORDER | wxTE_PROCESS_ENTER ); @@ -1468,7 +1477,7 @@ void wxGenericGrid::OnSelectCellImplementation(wxDC *dc, int row, int col) if (cell) { if ( cell->GetTextValue().IsNull() ) - m_textItem->SetValue(""); + m_textItem->SetValue(wxT("")); else m_textItem->SetValue(cell->GetTextValue()); } @@ -1509,7 +1518,7 @@ void wxGenericGrid::OnSelectCellImplementation(wxDC *dc, int row, int col) m_inPlaceTextItem->SetForegroundColour(cell->GetTextColour()); if ( cell->GetTextValue().IsNull() ) { - m_inPlaceTextItem->SetValue( "" ); + m_inPlaceTextItem->SetValue( wxT("") ); } else { m_inPlaceTextItem->SetValue( cell->GetTextValue() ); @@ -1518,10 +1527,18 @@ void wxGenericGrid::OnSelectCellImplementation(wxDC *dc, int row, int col) m_inPlaceTextItem->Show(TRUE); m_inPlaceTextItem->SetFocus(); - if (wxIPE_HIGHLIGHT) +#if defined(__VISAGECPP__) + { + int highlight = wxIPE_HIGHLIGHT; + if (highlight != 0) + HighlightCell(dc, TRUE); + } +#else + if (wxIPE_HIGHLIGHT != 0) HighlightCell(dc, TRUE); +#endif } - else + else if (!wxIPE_HIGHLIGHT) { // 1) Why isn't this needed for Windows?? // Probably because of the SetValue?? JS. @@ -1530,10 +1547,11 @@ void wxGenericGrid::OnSelectCellImplementation(wxDC *dc, int row, int col) // // 3) It *is* needed for Motif - michael // -#if defined(__WXMOTIF__) - if ((wxIPE_HIGHLIGHT || !(m_editable && m_editInPlace))) + // 4) It *seems* to be needed whenever + // wxIPE_HIGHLIGHT is not set (i.e. + // for both wxGTK and wxMOTIF)... SN. + if (!(m_editable && m_editInPlace))) HighlightCell(dc, TRUE); -#endif } dc->DestroyClippingRegion(); @@ -1554,7 +1572,7 @@ void wxGenericGrid::OnChangeLabels() int i; for (i = 0; i < m_totalRows; i++) { - sprintf(buf, "%d", i+1); + sprintf(buf, wxT("%d"), i+1); SetLabelValue(wxVERTICAL, buf, i); } // A...Z,AA...ZZ,AAA...ZZZ, etc. @@ -1567,7 +1585,7 @@ void wxGenericGrid::OnChangeLabels() for (j = 0; j < noTimes; j++) { char buf2[20]; - sprintf(buf2, "%c", (char)ch); + sprintf(buf2, wxT("%c"), (char)ch); strcat(buf, buf2); } SetLabelValue(wxHORIZONTAL, buf, i); @@ -1648,7 +1666,7 @@ void wxGenericGrid::DrawCellText() rect.height -= 4; // FIXME: what's this string of spaces supposed to represent? - DrawTextRect(& dc, " ", &rect, wxLEFT); + DrawTextRect(& dc, wxT(" "), &rect, wxLEFT); DrawTextRect(& dc, editValue, &rect, cell->GetAlignment()); dc.DestroyClippingRegion(); @@ -1771,21 +1789,21 @@ void wxGenericGrid::DrawTextRect(wxDC *dc, const wxString& text, wxRect *rect, i { case wxRIGHT: { - x = (rect->x + rect->width - textWidth - 1.0); - y = (rect->y + (rect->height - textHeight)/2.0); + x = (rect->x + rect->width - textWidth - (float)1.0); + y = (rect->y + (rect->height - textHeight)/(float)2.0); break; } case wxCENTRE: { - x = (rect->x + (rect->width - textWidth)/2.0); - y = (rect->y + (rect->height - textHeight)/2.0); + x = (rect->x + (rect->width - textWidth)/(float)2.0); + y = (rect->y + (rect->height - textHeight)/(float)2.0); break; } case wxLEFT: default: { - x = (rect->x + 1.0); - y = (rect->y + (rect->height - textHeight)/2.0); + x = (rect->x + (float)1.0); + y = (rect->y + (rect->height - textHeight)/(float)2.0); break; } } @@ -1944,7 +1962,7 @@ void wxGenericGrid::RefreshCell(int row, int col, bool setText) wxString& wxGenericGrid::GetCellValue(int row, int col) const { - static wxString emptyString(""); + static wxString emptyString(wxT("")); wxGridCell *cell = GetCell(row, col); if (cell) @@ -2026,7 +2044,7 @@ void wxGenericGrid::SetLabelValue(int orientation, const wxString& val, int pos) wxString& wxGenericGrid::GetLabelValue(int orientation, int pos) const { - static wxString emptyString = ""; + static wxString emptyString = wxT(""); wxGridCell *cell = GetLabelCell(orientation, pos); if (cell) return cell->GetTextValue(); @@ -2143,7 +2161,7 @@ void wxGenericGrid::SetEditInPlace(bool edit) m_inPlaceTextItem->SetForegroundColour(cell->GetTextColour()); if ( cell->GetTextValue().IsNull() ) { - m_inPlaceTextItem->SetValue( "" ); + m_inPlaceTextItem->SetValue( wxT("") ); } else { m_inPlaceTextItem->SetValue( cell->GetTextValue() ); @@ -2837,3 +2855,4 @@ void *wxGenericGrid::GetCellData(int row, int col) return rc; } +#endif // wxUSE_GRID && !(wxUSE_NEW_GRID)