added orient parameter to DrawSplitterSash instead of using wxMirrorDC in the splitter (it is now used in generic renderer only)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@22310 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
003b8322f3
commit
62dc9cb4f1
@ -89,7 +89,8 @@ public:
|
|||||||
virtual void DrawSplitterSash(wxWindow *win,
|
virtual void DrawSplitterSash(wxWindow *win,
|
||||||
wxDC& dc,
|
wxDC& dc,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
wxCoord position) = 0;
|
wxCoord position,
|
||||||
|
wxOrientation orient) = 0;
|
||||||
|
|
||||||
|
|
||||||
// geometry functions
|
// geometry functions
|
||||||
@ -144,8 +145,9 @@ public:
|
|||||||
virtual void DrawSplitterSash(wxWindow *win,
|
virtual void DrawSplitterSash(wxWindow *win,
|
||||||
wxDC& dc,
|
wxDC& dc,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
wxCoord position)
|
wxCoord position,
|
||||||
{ m_rendererNative.DrawSplitterSash(win, dc, size, position); }
|
wxOrientation orient)
|
||||||
|
{ m_rendererNative.DrawSplitterSash(win, dc, size, position, orient); }
|
||||||
|
|
||||||
|
|
||||||
virtual wxPoint GetSplitterSashAndBorder(const wxWindow *win)
|
virtual wxPoint GetSplitterSashAndBorder(const wxWindow *win)
|
||||||
|
@ -34,6 +34,8 @@
|
|||||||
#include "wx/settings.h"
|
#include "wx/settings.h"
|
||||||
#include "wx/splitter.h"
|
#include "wx/splitter.h"
|
||||||
|
|
||||||
|
#include "wx/dcmirror.h"
|
||||||
|
|
||||||
#include "wx/renderer.h"
|
#include "wx/renderer.h"
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@ -62,7 +64,8 @@ public:
|
|||||||
virtual void DrawSplitterSash(wxWindow *win,
|
virtual void DrawSplitterSash(wxWindow *win,
|
||||||
wxDC& dc,
|
wxDC& dc,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
wxCoord position);
|
wxCoord position,
|
||||||
|
wxOrientation orient);
|
||||||
|
|
||||||
|
|
||||||
virtual wxPoint GetSplitterSashAndBorder(const wxWindow *win);
|
virtual wxPoint GetSplitterSashAndBorder(const wxWindow *win);
|
||||||
@ -227,10 +230,17 @@ wxRendererGeneric::DrawSplitterBorder(wxWindow *win,
|
|||||||
|
|
||||||
void
|
void
|
||||||
wxRendererGeneric::DrawSplitterSash(wxWindow *win,
|
wxRendererGeneric::DrawSplitterSash(wxWindow *win,
|
||||||
wxDC& dc,
|
wxDC& dcReal,
|
||||||
const wxSize& size,
|
const wxSize& sizeReal,
|
||||||
wxCoord position)
|
wxCoord position,
|
||||||
|
wxOrientation orient)
|
||||||
{
|
{
|
||||||
|
// to avoid duplicating the same code for horizontal and vertical sashes,
|
||||||
|
// simply mirror the DC instead if needed (i.e. if horz splitter)
|
||||||
|
wxMirrorDC dc(dcReal, orient != wxVERTICAL);
|
||||||
|
wxSize size = dc.Reflect(sizeReal);
|
||||||
|
|
||||||
|
|
||||||
// we draw a Win32-like grey sash with possible 3D border here:
|
// we draw a Win32-like grey sash with possible 3D border here:
|
||||||
//
|
//
|
||||||
// ---- this is position
|
// ---- this is position
|
||||||
|
@ -36,7 +36,6 @@
|
|||||||
#include "wx/settings.h"
|
#include "wx/settings.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/dcmirror.h"
|
|
||||||
#include "wx/renderer.h"
|
#include "wx/renderer.h"
|
||||||
|
|
||||||
#include "wx/splitter.h"
|
#include "wx/splitter.h"
|
||||||
@ -382,7 +381,8 @@ bool wxSplitterWindow::SashHitTest(int x, int y, int tolerance)
|
|||||||
|
|
||||||
int z = m_splitMode == wxSPLIT_VERTICAL ? x : y;
|
int z = m_splitMode == wxSPLIT_VERTICAL ? x : y;
|
||||||
|
|
||||||
return z >= m_sashPosition - tolerance && z <= m_sashPosition + tolerance;
|
return z >= m_sashPosition - tolerance &&
|
||||||
|
z <= m_sashPosition + GetSashSize() + tolerance;
|
||||||
}
|
}
|
||||||
|
|
||||||
int wxSplitterWindow::GetSashSize() const
|
int wxSplitterWindow::GetSashSize() const
|
||||||
@ -413,13 +413,15 @@ void wxSplitterWindow::DrawSash(wxDC& dc)
|
|||||||
if ( HasFlag(wxSP_NOSASH) )
|
if ( HasFlag(wxSP_NOSASH) )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
wxMirrorDC dcMirror(dc, m_splitMode != wxSPLIT_VERTICAL);
|
|
||||||
wxRendererNative::Get().DrawSplitterSash
|
wxRendererNative::Get().DrawSplitterSash
|
||||||
(
|
(
|
||||||
this,
|
this,
|
||||||
dcMirror,
|
dc,
|
||||||
dcMirror.Reflect(GetClientSize()),
|
GetClientSize(),
|
||||||
m_sashPosition
|
m_sashPosition,
|
||||||
|
m_splitMode == wxSPLIT_VERTICAL
|
||||||
|
? wxVERTICAL
|
||||||
|
: wxHORIZONTAL
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,7 +56,8 @@ public:
|
|||||||
virtual void DrawSplitterSash(wxWindow *win,
|
virtual void DrawSplitterSash(wxWindow *win,
|
||||||
wxDC& dc,
|
wxDC& dc,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
wxCoord position);
|
wxCoord position,
|
||||||
|
wxOrientation orient);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// the tree buttons
|
// the tree buttons
|
||||||
@ -198,16 +199,18 @@ void
|
|||||||
wxRendererMac::DrawSplitterSash(wxWindow *win,
|
wxRendererMac::DrawSplitterSash(wxWindow *win,
|
||||||
wxDC& dc,
|
wxDC& dc,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
wxCoord position)
|
wxCoord position,
|
||||||
|
wxOrientation orient)
|
||||||
{
|
{
|
||||||
// VZ: we have to somehow determine if we're drawing a normal sash or
|
// VZ: we have to somehow determine if we're drawing a normal sash or
|
||||||
// a brushed metal one as they look quite differently... this is
|
// a brushed metal one as they look quite differently... this is
|
||||||
// completely bogus anyhow, of course (TODO)
|
// completely bogus anyhow, of course (TODO)
|
||||||
|
|
||||||
const wxCoord h = size.y;
|
|
||||||
|
|
||||||
dc.SetPen(*wxLIGHT_GREY_PEN);
|
dc.SetPen(*wxLIGHT_GREY_PEN);
|
||||||
dc.SetBrush(*wxWHITE_BRUSH);
|
dc.SetBrush(*wxWHITE_BRUSH);
|
||||||
dc.DrawRectangle(position, 0, 7, h);
|
if ( orient == wxVERTICAL )
|
||||||
|
dc.DrawRectangle(position, 0, 7, size.y);
|
||||||
|
else
|
||||||
|
dc.DrawRectangle(0, position, size.x, 7);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,7 +56,8 @@ public:
|
|||||||
virtual void DrawSplitterSash(wxWindow *win,
|
virtual void DrawSplitterSash(wxWindow *win,
|
||||||
wxDC& dc,
|
wxDC& dc,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
wxCoord position);
|
wxCoord position,
|
||||||
|
wxOrientation orient);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// the tree buttons
|
// the tree buttons
|
||||||
@ -198,16 +199,18 @@ void
|
|||||||
wxRendererMac::DrawSplitterSash(wxWindow *win,
|
wxRendererMac::DrawSplitterSash(wxWindow *win,
|
||||||
wxDC& dc,
|
wxDC& dc,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
wxCoord position)
|
wxCoord position,
|
||||||
|
wxOrientation orient)
|
||||||
{
|
{
|
||||||
// VZ: we have to somehow determine if we're drawing a normal sash or
|
// VZ: we have to somehow determine if we're drawing a normal sash or
|
||||||
// a brushed metal one as they look quite differently... this is
|
// a brushed metal one as they look quite differently... this is
|
||||||
// completely bogus anyhow, of course (TODO)
|
// completely bogus anyhow, of course (TODO)
|
||||||
|
|
||||||
const wxCoord h = size.y;
|
|
||||||
|
|
||||||
dc.SetPen(*wxLIGHT_GREY_PEN);
|
dc.SetPen(*wxLIGHT_GREY_PEN);
|
||||||
dc.SetBrush(*wxWHITE_BRUSH);
|
dc.SetBrush(*wxWHITE_BRUSH);
|
||||||
dc.DrawRectangle(position, 0, 7, h);
|
if ( orient == wxVERTICAL )
|
||||||
|
dc.DrawRectangle(position, 0, 7, size.y);
|
||||||
|
else
|
||||||
|
dc.DrawRectangle(0, position, size.x, 7);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user