reverted Robert's over-optimisation, correct fix coming soon

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@30779 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Václav Slavík 2004-11-25 08:32:49 +00:00
parent 64631e82fd
commit 2a2e4f4afa
5 changed files with 7 additions and 14 deletions

View File

@ -376,7 +376,7 @@ static void SwitchSelState(wxDC& dc, wxHtmlRenderingInfo& info,
void wxHtmlWordCell::Draw(wxDC& dc, int x, int y, void wxHtmlWordCell::Draw(wxDC& dc, int x, int y,
int WXUNUSED(view_y1), int view_y2, int WXUNUSED(view_y1), int WXUNUSED(view_y2),
wxHtmlRenderingInfo& info) wxHtmlRenderingInfo& info)
{ {
#if 0 // useful for debugging #if 0 // useful for debugging
@ -384,8 +384,6 @@ void wxHtmlWordCell::Draw(wxDC& dc, int x, int y,
dc.DrawRectangle(x+m_PosX,y+m_PosY,m_Width /* VZ: +1? */ ,m_Height); dc.DrawRectangle(x+m_PosX,y+m_PosY,m_Width /* VZ: +1? */ ,m_Height);
#endif #endif
if (y+m_PosY+m_Height > view_y2) return;
bool drawSelectionAfterCell = false; bool drawSelectionAfterCell = false;
if ( info.GetState().GetSelectionState() == wxHTML_SEL_CHANGING ) if ( info.GetState().GetSelectionState() == wxHTML_SEL_CHANGING )

View File

@ -124,17 +124,18 @@ int wxHtmlDCRenderer::Render(int x, int y, int from, int dont_render, int to, in
if(to < hght) if(to < hght)
hght = to; hght = to;
if (!dont_render) if (!dont_render)
{ {
wxHtmlRenderingInfo rinfo; wxHtmlRenderingInfo rinfo;
wxDefaultHtmlRenderingStyle rstyle; wxDefaultHtmlRenderingStyle rstyle;
rinfo.SetStyle(&rstyle); rinfo.SetStyle(&rstyle);
m_DC->SetBrush(*wxWHITE_BRUSH); m_DC->SetBrush(*wxWHITE_BRUSH);
m_DC->SetClippingRegion(x, y, m_Width, hght);
m_Cells->Draw(*m_DC, m_Cells->Draw(*m_DC,
x, (y - from), x, (y - from),
y, y + hght, y, pbreak + (y /*- from*/),
rinfo); rinfo);
m_DC->DestroyClippingRegion();
} }
if (pbreak < m_Cells->GetHeight()) return pbreak; if (pbreak < m_Cells->GetHeight()) return pbreak;

View File

@ -56,11 +56,9 @@ class wxHtmlLineCell : public wxHtmlCell
void wxHtmlLineCell::Draw(wxDC& dc, int x, int y, void wxHtmlLineCell::Draw(wxDC& dc, int x, int y,
int WXUNUSED(view_y1), int view_y2, int WXUNUSED(view_y1), int WXUNUSED(view_y2),
wxHtmlRenderingInfo& WXUNUSED(info)) wxHtmlRenderingInfo& WXUNUSED(info))
{ {
if (y+m_PosY+m_Height > view_y2) return;
wxBrush mybrush(wxT("GREY"), (m_HasShading) ? wxTRANSPARENT : wxSOLID); wxBrush mybrush(wxT("GREY"), (m_HasShading) ? wxTRANSPARENT : wxSOLID);
wxPen mypen(wxT("GREY"), 1, wxSOLID); wxPen mypen(wxT("GREY"), 1, wxSOLID);
dc.SetBrush(mybrush); dc.SetBrush(mybrush);

View File

@ -539,11 +539,9 @@ wxHtmlImageCell::~wxHtmlImageCell()
void wxHtmlImageCell::Draw(wxDC& dc, int x, int y, void wxHtmlImageCell::Draw(wxDC& dc, int x, int y,
int WXUNUSED(view_y1), int view_y2, int WXUNUSED(view_y1), int WXUNUSED(view_y2),
wxHtmlRenderingInfo& WXUNUSED(info)) wxHtmlRenderingInfo& WXUNUSED(info))
{ {
if (y+m_PosY+m_Height > view_y2) return;
if ( m_showFrame ) if ( m_showFrame )
{ {
dc.SetBrush(*wxTRANSPARENT_BRUSH); dc.SetBrush(*wxTRANSPARENT_BRUSH);

View File

@ -59,11 +59,9 @@ wxHtmlListmarkCell::wxHtmlListmarkCell(wxDC* dc, const wxColour& clr) : wxHtmlCe
void wxHtmlListmarkCell::Draw(wxDC& dc, int x, int y, void wxHtmlListmarkCell::Draw(wxDC& dc, int x, int y,
int WXUNUSED(view_y1), int view_y2, int WXUNUSED(view_y1), int WXUNUSED(view_y2),
wxHtmlRenderingInfo& WXUNUSED(info)) wxHtmlRenderingInfo& WXUNUSED(info))
{ {
if (y+m_PosY+m_Height > view_y2) return;
dc.SetBrush(m_Brush); dc.SetBrush(m_Brush);
dc.DrawEllipse(x + m_PosX + m_Width / 3, y + m_PosY + m_Height / 3, dc.DrawEllipse(x + m_PosX + m_Width / 3, y + m_PosY + m_Height / 3,
(m_Width / 3), (m_Width / 3)); (m_Width / 3), (m_Width / 3));