Extract wxPenInfoBase in a separate header
This allows to avoid dependency of wx/graphics.h on wx/pen.h.
This commit is contained in:
@@ -3908,6 +3908,7 @@ COND_USE_GUI_1_ALL_GUI_HEADERS = \
|
||||
wx/collheaderctrl.h \
|
||||
wx/generic/collheaderctrl.h \
|
||||
wx/itemattr.h \
|
||||
wx/peninfobase.h \
|
||||
$(LOWLEVEL_HDR) \
|
||||
$(GUI_CORE_HEADERS) \
|
||||
$(ADVANCED_HDR) \
|
||||
|
@@ -1188,6 +1188,7 @@ IMPORTANT: please read docs/tech/tn0016.txt before modifying this file!
|
||||
wx/collheaderctrl.h
|
||||
wx/generic/collheaderctrl.h
|
||||
wx/itemattr.h
|
||||
wx/peninfobase.h
|
||||
</set>
|
||||
|
||||
<!-- ====================================================================== -->
|
||||
|
@@ -946,6 +946,7 @@ GUI_CMN_HDR =
|
||||
wx/palette.h
|
||||
wx/panel.h
|
||||
wx/pen.h
|
||||
wx/peninfobase.h
|
||||
wx/position.h
|
||||
wx/preferences.h
|
||||
wx/radiobox.h
|
||||
|
@@ -1382,6 +1382,7 @@
|
||||
<ClInclude Include="..\..\include\wx\generic\collheaderctrl.h" />
|
||||
<ClInclude Include="..\..\include\wx\msw\rt\utils.h" />
|
||||
<ClInclude Include="..\..\include\wx\itemattr.h" />
|
||||
<ClInclude Include="..\..\include\wx\peninfobase.h" />
|
||||
</ItemGroup>
|
||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||
<ImportGroup Label="ExtensionTargets">
|
||||
|
@@ -1714,6 +1714,9 @@
|
||||
<ClInclude Include="..\..\include\wx\pen.h">
|
||||
<Filter>Common Headers</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="..\..\include\wx\peninfobase.h">
|
||||
<Filter>Common Headers</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="..\..\include\wx\persist.h">
|
||||
<Filter>Common Headers</Filter>
|
||||
</ClInclude>
|
||||
|
@@ -1,4 +1,3 @@
|
||||
|
||||
Microsoft Visual Studio Solution File, Format Version 8.00
|
||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "wxregex", "wx_vc7_wxregex.vcproj", "{7A1A5354-6DB4-53F1-B75C-FE909D796167}"
|
||||
EndProject
|
||||
|
@@ -2393,6 +2393,9 @@
|
||||
<File
|
||||
RelativePath="..\..\include\wx\pen.h">
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\peninfobase.h">
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\persist.h">
|
||||
</File>
|
||||
|
@@ -1,4 +1,3 @@
|
||||
|
||||
Microsoft Visual Studio Solution File, Format Version 9.00
|
||||
# Visual Studio 2005
|
||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "wxregex", "wx_vc8_wxregex.vcproj", "{078F4E39-D258-54B5-B1B1-4905D10E06DC}"
|
||||
|
@@ -3692,6 +3692,10 @@
|
||||
RelativePath="..\..\include\wx\pen.h"
|
||||
>
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\peninfobase.h"
|
||||
>
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\persist.h"
|
||||
>
|
||||
|
@@ -1,4 +1,3 @@
|
||||
|
||||
Microsoft Visual Studio Solution File, Format Version 10.00
|
||||
# Visual Studio 2008
|
||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "wxregex", "wx_vc9_wxregex.vcproj", "{56A4B526-BB81-5D01-AAA9-16D23BBB169D}"
|
||||
|
@@ -3688,6 +3688,10 @@
|
||||
RelativePath="..\..\include\wx\pen.h"
|
||||
>
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\peninfobase.h"
|
||||
>
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\persist.h"
|
||||
>
|
||||
|
@@ -21,8 +21,8 @@
|
||||
#include "wx/dynarray.h"
|
||||
#include "wx/font.h"
|
||||
#include "wx/image.h"
|
||||
#include "wx/peninfobase.h"
|
||||
#include "wx/vector.h"
|
||||
#include "wx/pen.h"
|
||||
|
||||
enum wxAntialiasMode
|
||||
{
|
||||
@@ -148,20 +148,6 @@ public:
|
||||
m_width = width;
|
||||
}
|
||||
|
||||
static wxGraphicsPenInfo CreateFromPen(const wxPen& pen)
|
||||
{
|
||||
wxDash *dashes;
|
||||
int nb_dashes = pen.GetDashes(&dashes);
|
||||
return wxGraphicsPenInfo()
|
||||
.Colour(pen.GetColour())
|
||||
.Width(pen.GetWidth())
|
||||
.Style(pen.GetStyle())
|
||||
.Stipple(*pen.GetStipple())
|
||||
.Dashes(nb_dashes, dashes)
|
||||
.Join(pen.GetJoin())
|
||||
.Cap(pen.GetCap());
|
||||
}
|
||||
|
||||
// Setters
|
||||
|
||||
wxGraphicsPenInfo& Width(wxDouble width)
|
||||
@@ -171,6 +157,10 @@ public:
|
||||
|
||||
wxDouble GetWidth() const { return m_width; }
|
||||
|
||||
// This is a helper used by wxWidgets itself, it doesn't make much sense to
|
||||
// use it outside of the library.
|
||||
static wxGraphicsPenInfo CreateFromPen(const wxPen& pen);
|
||||
|
||||
private:
|
||||
wxDouble m_width;
|
||||
};
|
||||
|
116
include/wx/pen.h
116
include/wx/pen.h
@@ -11,122 +11,8 @@
|
||||
#ifndef _WX_PEN_H_BASE_
|
||||
#define _WX_PEN_H_BASE_
|
||||
|
||||
#include "wx/bitmap.h"
|
||||
#include "wx/gdiobj.h"
|
||||
#include "wx/gdicmn.h"
|
||||
|
||||
enum wxPenStyle
|
||||
{
|
||||
wxPENSTYLE_INVALID = -1,
|
||||
|
||||
wxPENSTYLE_SOLID = wxSOLID,
|
||||
wxPENSTYLE_DOT = wxDOT,
|
||||
wxPENSTYLE_LONG_DASH = wxLONG_DASH,
|
||||
wxPENSTYLE_SHORT_DASH = wxSHORT_DASH,
|
||||
wxPENSTYLE_DOT_DASH = wxDOT_DASH,
|
||||
wxPENSTYLE_USER_DASH = wxUSER_DASH,
|
||||
|
||||
wxPENSTYLE_TRANSPARENT = wxTRANSPARENT,
|
||||
|
||||
wxPENSTYLE_STIPPLE_MASK_OPAQUE = wxSTIPPLE_MASK_OPAQUE,
|
||||
wxPENSTYLE_STIPPLE_MASK = wxSTIPPLE_MASK,
|
||||
wxPENSTYLE_STIPPLE = wxSTIPPLE,
|
||||
|
||||
wxPENSTYLE_BDIAGONAL_HATCH = wxHATCHSTYLE_BDIAGONAL,
|
||||
wxPENSTYLE_CROSSDIAG_HATCH = wxHATCHSTYLE_CROSSDIAG,
|
||||
wxPENSTYLE_FDIAGONAL_HATCH = wxHATCHSTYLE_FDIAGONAL,
|
||||
wxPENSTYLE_CROSS_HATCH = wxHATCHSTYLE_CROSS,
|
||||
wxPENSTYLE_HORIZONTAL_HATCH = wxHATCHSTYLE_HORIZONTAL,
|
||||
wxPENSTYLE_VERTICAL_HATCH = wxHATCHSTYLE_VERTICAL,
|
||||
wxPENSTYLE_FIRST_HATCH = wxHATCHSTYLE_FIRST,
|
||||
wxPENSTYLE_LAST_HATCH = wxHATCHSTYLE_LAST
|
||||
};
|
||||
|
||||
enum wxPenJoin
|
||||
{
|
||||
wxJOIN_INVALID = -1,
|
||||
|
||||
wxJOIN_BEVEL = 120,
|
||||
wxJOIN_MITER,
|
||||
wxJOIN_ROUND
|
||||
};
|
||||
|
||||
enum wxPenCap
|
||||
{
|
||||
wxCAP_INVALID = -1,
|
||||
|
||||
wxCAP_ROUND = 130,
|
||||
wxCAP_PROJECTING,
|
||||
wxCAP_BUTT
|
||||
};
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// wxPenInfoBase is a common base for wxPenInfo and wxGraphicsPenInfo
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
// This class uses CRTP, the template parameter is the derived class itself.
|
||||
template <class T>
|
||||
class wxPenInfoBase
|
||||
{
|
||||
public:
|
||||
// Setters for the various attributes. All of them return the object itself
|
||||
// so that the calls to them could be chained.
|
||||
|
||||
T& Colour(const wxColour& colour)
|
||||
{ m_colour = colour; return This(); }
|
||||
|
||||
T& Style(wxPenStyle style)
|
||||
{ m_style = style; return This(); }
|
||||
T& Stipple(const wxBitmap& stipple)
|
||||
{ m_stipple = stipple; m_style = wxPENSTYLE_STIPPLE; return This(); }
|
||||
T& Dashes(int nb_dashes, const wxDash *dash)
|
||||
{ m_nb_dashes = nb_dashes; m_dash = (wxDash *)dash; return This(); }
|
||||
T& Join(wxPenJoin join)
|
||||
{ m_join = join; return This(); }
|
||||
T& Cap(wxPenCap cap)
|
||||
{ m_cap = cap; return This(); }
|
||||
|
||||
// Accessors are mostly meant to be used by wxWidgets itself.
|
||||
|
||||
wxColour GetColour() const { return m_colour; }
|
||||
wxBitmap GetStipple() const { return m_stipple; }
|
||||
wxPenStyle GetStyle() const { return m_style; }
|
||||
wxPenJoin GetJoin() const { return m_join; }
|
||||
wxPenCap GetCap() const { return m_cap; }
|
||||
int GetDashes(wxDash **ptr) const { *ptr = m_dash; return m_nb_dashes; }
|
||||
|
||||
int GetDashCount() const { return m_nb_dashes; }
|
||||
wxDash* GetDash() const { return m_dash; }
|
||||
|
||||
// Convenience
|
||||
|
||||
bool IsTransparent() const { return m_style == wxPENSTYLE_TRANSPARENT; }
|
||||
|
||||
protected:
|
||||
wxPenInfoBase(const wxColour& colour, wxPenStyle style)
|
||||
{
|
||||
m_nb_dashes = 0;
|
||||
m_dash = NULL;
|
||||
m_join = wxJOIN_ROUND;
|
||||
m_cap = wxCAP_ROUND;
|
||||
|
||||
m_colour = colour;
|
||||
m_style = style;
|
||||
}
|
||||
|
||||
private:
|
||||
// Helper to return this object itself cast to its real type T.
|
||||
T& This() { return static_cast<T&>(*this); }
|
||||
|
||||
wxColour m_colour;
|
||||
wxBitmap m_stipple;
|
||||
wxPenStyle m_style;
|
||||
wxPenJoin m_join;
|
||||
wxPenCap m_cap;
|
||||
|
||||
int m_nb_dashes;
|
||||
wxDash* m_dash;
|
||||
};
|
||||
#include "wx/peninfobase.h"
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// wxPenInfo contains all parameters describing a wxPen
|
||||
|
130
include/wx/peninfobase.h
Normal file
130
include/wx/peninfobase.h
Normal file
@@ -0,0 +1,130 @@
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
// Name: wx/peninfobase.h
|
||||
// Purpose: Declaration of wxPenInfoBase class and related constants
|
||||
// Author: Adrien Tétar, Vadim Zeitlin
|
||||
// Created: 2017-09-10
|
||||
// Copyright: (c) 2017 Vadim Zeitlin <vadim@wxwidgets.org>
|
||||
// Licence: wxWindows licence
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#ifndef _WX_PENINFOBASE_H_
|
||||
#define _WX_PENINFOBASE_H_
|
||||
|
||||
#include "wx/bitmap.h"
|
||||
#include "wx/colour.h"
|
||||
#include "wx/gdicmn.h" // for wxDash
|
||||
|
||||
enum wxPenStyle
|
||||
{
|
||||
wxPENSTYLE_INVALID = -1,
|
||||
|
||||
wxPENSTYLE_SOLID = wxSOLID,
|
||||
wxPENSTYLE_DOT = wxDOT,
|
||||
wxPENSTYLE_LONG_DASH = wxLONG_DASH,
|
||||
wxPENSTYLE_SHORT_DASH = wxSHORT_DASH,
|
||||
wxPENSTYLE_DOT_DASH = wxDOT_DASH,
|
||||
wxPENSTYLE_USER_DASH = wxUSER_DASH,
|
||||
|
||||
wxPENSTYLE_TRANSPARENT = wxTRANSPARENT,
|
||||
|
||||
wxPENSTYLE_STIPPLE_MASK_OPAQUE = wxSTIPPLE_MASK_OPAQUE,
|
||||
wxPENSTYLE_STIPPLE_MASK = wxSTIPPLE_MASK,
|
||||
wxPENSTYLE_STIPPLE = wxSTIPPLE,
|
||||
|
||||
wxPENSTYLE_BDIAGONAL_HATCH = wxHATCHSTYLE_BDIAGONAL,
|
||||
wxPENSTYLE_CROSSDIAG_HATCH = wxHATCHSTYLE_CROSSDIAG,
|
||||
wxPENSTYLE_FDIAGONAL_HATCH = wxHATCHSTYLE_FDIAGONAL,
|
||||
wxPENSTYLE_CROSS_HATCH = wxHATCHSTYLE_CROSS,
|
||||
wxPENSTYLE_HORIZONTAL_HATCH = wxHATCHSTYLE_HORIZONTAL,
|
||||
wxPENSTYLE_VERTICAL_HATCH = wxHATCHSTYLE_VERTICAL,
|
||||
wxPENSTYLE_FIRST_HATCH = wxHATCHSTYLE_FIRST,
|
||||
wxPENSTYLE_LAST_HATCH = wxHATCHSTYLE_LAST
|
||||
};
|
||||
|
||||
enum wxPenJoin
|
||||
{
|
||||
wxJOIN_INVALID = -1,
|
||||
|
||||
wxJOIN_BEVEL = 120,
|
||||
wxJOIN_MITER,
|
||||
wxJOIN_ROUND
|
||||
};
|
||||
|
||||
enum wxPenCap
|
||||
{
|
||||
wxCAP_INVALID = -1,
|
||||
|
||||
wxCAP_ROUND = 130,
|
||||
wxCAP_PROJECTING,
|
||||
wxCAP_BUTT
|
||||
};
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// wxPenInfoBase is a common base for wxPenInfo and wxGraphicsPenInfo
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
// This class uses CRTP, the template parameter is the derived class itself.
|
||||
template <class T>
|
||||
class wxPenInfoBase
|
||||
{
|
||||
public:
|
||||
// Setters for the various attributes. All of them return the object itself
|
||||
// so that the calls to them could be chained.
|
||||
|
||||
T& Colour(const wxColour& colour)
|
||||
{ m_colour = colour; return This(); }
|
||||
|
||||
T& Style(wxPenStyle style)
|
||||
{ m_style = style; return This(); }
|
||||
T& Stipple(const wxBitmap& stipple)
|
||||
{ m_stipple = stipple; m_style = wxPENSTYLE_STIPPLE; return This(); }
|
||||
T& Dashes(int nb_dashes, const wxDash *dash)
|
||||
{ m_nb_dashes = nb_dashes; m_dash = (wxDash *)dash; return This(); }
|
||||
T& Join(wxPenJoin join)
|
||||
{ m_join = join; return This(); }
|
||||
T& Cap(wxPenCap cap)
|
||||
{ m_cap = cap; return This(); }
|
||||
|
||||
// Accessors are mostly meant to be used by wxWidgets itself.
|
||||
|
||||
wxColour GetColour() const { return m_colour; }
|
||||
wxBitmap GetStipple() const { return m_stipple; }
|
||||
wxPenStyle GetStyle() const { return m_style; }
|
||||
wxPenJoin GetJoin() const { return m_join; }
|
||||
wxPenCap GetCap() const { return m_cap; }
|
||||
int GetDashes(wxDash **ptr) const { *ptr = m_dash; return m_nb_dashes; }
|
||||
|
||||
int GetDashCount() const { return m_nb_dashes; }
|
||||
wxDash* GetDash() const { return m_dash; }
|
||||
|
||||
// Convenience
|
||||
|
||||
bool IsTransparent() const { return m_style == wxPENSTYLE_TRANSPARENT; }
|
||||
|
||||
protected:
|
||||
wxPenInfoBase(const wxColour& colour, wxPenStyle style)
|
||||
{
|
||||
m_nb_dashes = 0;
|
||||
m_dash = NULL;
|
||||
m_join = wxJOIN_ROUND;
|
||||
m_cap = wxCAP_ROUND;
|
||||
|
||||
m_colour = colour;
|
||||
m_style = style;
|
||||
}
|
||||
|
||||
private:
|
||||
// Helper to return this object itself cast to its real type T.
|
||||
T& This() { return static_cast<T&>(*this); }
|
||||
|
||||
wxColour m_colour;
|
||||
wxBitmap m_stipple;
|
||||
wxPenStyle m_style;
|
||||
wxPenJoin m_join;
|
||||
wxPenCap m_cap;
|
||||
|
||||
int m_nb_dashes;
|
||||
wxDash* m_dash;
|
||||
};
|
||||
|
||||
#endif // _WX_PENINFOBASE_H_
|
@@ -26,6 +26,7 @@
|
||||
#include "wx/dcmemory.h"
|
||||
#include "wx/dcprint.h"
|
||||
#include "wx/math.h"
|
||||
#include "wx/pen.h"
|
||||
#include "wx/region.h"
|
||||
#include "wx/log.h"
|
||||
#endif
|
||||
@@ -116,6 +117,21 @@ WXDLLIMPEXP_DATA_CORE(wxGraphicsBrush) wxNullGraphicsBrush;
|
||||
WXDLLIMPEXP_DATA_CORE(wxGraphicsFont) wxNullGraphicsFont;
|
||||
WXDLLIMPEXP_DATA_CORE(wxGraphicsBitmap) wxNullGraphicsBitmap;
|
||||
|
||||
/* static */
|
||||
wxGraphicsPenInfo wxGraphicsPenInfo::CreateFromPen(const wxPen& pen)
|
||||
{
|
||||
wxDash *dashes;
|
||||
int nb_dashes = pen.GetDashes(&dashes);
|
||||
return wxGraphicsPenInfo()
|
||||
.Colour(pen.GetColour())
|
||||
.Width(pen.GetWidth())
|
||||
.Style(pen.GetStyle())
|
||||
.Stipple(*pen.GetStipple())
|
||||
.Dashes(nb_dashes, dashes)
|
||||
.Join(pen.GetJoin())
|
||||
.Cap(pen.GetCap());
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// matrix
|
||||
//-----------------------------------------------------------------------------
|
||||
|
Reference in New Issue
Block a user