Merge pull request #1455 from wxWidgets/gradient-pen
Add support for gradients in wxGraphicsPen
This commit is contained in:
@@ -155,6 +155,9 @@ All (GUI):
|
|||||||
in wxPGArrayEditorDialog.
|
in wxPGArrayEditorDialog.
|
||||||
- Fix wxPropertyGrid issues with horizontal scrolling.
|
- Fix wxPropertyGrid issues with horizontal scrolling.
|
||||||
- Add wxPG_DIALOG_TITLE wxPGProperty attribute.
|
- Add wxPG_DIALOG_TITLE wxPGProperty attribute.
|
||||||
|
- Add support for creating a wxGraphicsPen with a gradient.
|
||||||
|
- Add support for applying a transformation matrix to a gradient.
|
||||||
|
|
||||||
|
|
||||||
wxGTK:
|
wxGTK:
|
||||||
|
|
||||||
|
@@ -71,6 +71,14 @@ enum wxCompositionMode
|
|||||||
wxCOMPOSITION_ADD /* R = S + D */
|
wxCOMPOSITION_ADD /* R = S + D */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum wxGradientType
|
||||||
|
{
|
||||||
|
wxGRADIENT_NONE,
|
||||||
|
wxGRADIENT_LINEAR,
|
||||||
|
wxGRADIENT_RADIAL
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
class WXDLLIMPEXP_FWD_CORE wxDC;
|
class WXDLLIMPEXP_FWD_CORE wxDC;
|
||||||
class WXDLLIMPEXP_FWD_CORE wxWindowDC;
|
class WXDLLIMPEXP_FWD_CORE wxWindowDC;
|
||||||
class WXDLLIMPEXP_FWD_CORE wxMemoryDC;
|
class WXDLLIMPEXP_FWD_CORE wxMemoryDC;
|
||||||
@@ -92,6 +100,7 @@ class WXDLLIMPEXP_FWD_CORE wxGraphicsBrush;
|
|||||||
class WXDLLIMPEXP_FWD_CORE wxGraphicsFont;
|
class WXDLLIMPEXP_FWD_CORE wxGraphicsFont;
|
||||||
class WXDLLIMPEXP_FWD_CORE wxGraphicsBitmap;
|
class WXDLLIMPEXP_FWD_CORE wxGraphicsBitmap;
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* notes about the graphics context apis
|
* notes about the graphics context apis
|
||||||
*
|
*
|
||||||
@@ -133,33 +142,7 @@ protected:
|
|||||||
wxDECLARE_DYNAMIC_CLASS(wxGraphicsObject);
|
wxDECLARE_DYNAMIC_CLASS(wxGraphicsObject);
|
||||||
};
|
};
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxGraphicsPenInfo describes a wxGraphicsPen
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
class wxGraphicsPenInfo : public wxPenInfoBase<wxGraphicsPenInfo>
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
explicit wxGraphicsPenInfo(const wxColour& colour = wxColour(),
|
|
||||||
wxDouble width = 1.0,
|
|
||||||
wxPenStyle style = wxPENSTYLE_SOLID)
|
|
||||||
: wxPenInfoBase<wxGraphicsPenInfo>(colour, style)
|
|
||||||
{
|
|
||||||
m_width = width;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Setters
|
|
||||||
|
|
||||||
wxGraphicsPenInfo& Width(wxDouble width)
|
|
||||||
{ m_width = width; return *this; }
|
|
||||||
|
|
||||||
// Accessors
|
|
||||||
|
|
||||||
wxDouble GetWidth() const { return m_width; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
wxDouble m_width;
|
|
||||||
};
|
|
||||||
|
|
||||||
class WXDLLIMPEXP_CORE wxGraphicsPen : public wxGraphicsObject
|
class WXDLLIMPEXP_CORE wxGraphicsPen : public wxGraphicsObject
|
||||||
{
|
{
|
||||||
@@ -286,6 +269,201 @@ private:
|
|||||||
|
|
||||||
extern WXDLLIMPEXP_DATA_CORE(wxGraphicsMatrix) wxNullGraphicsMatrix;
|
extern WXDLLIMPEXP_DATA_CORE(wxGraphicsMatrix) wxNullGraphicsMatrix;
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxGradientStop and wxGradientStops: Specify what intermediate colors are used
|
||||||
|
// and how they are spread out in a gradient
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// Describes a single gradient stop.
|
||||||
|
class wxGraphicsGradientStop
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxGraphicsGradientStop(wxColour col = wxTransparentColour,
|
||||||
|
float pos = 0.)
|
||||||
|
: m_col(col),
|
||||||
|
m_pos(pos)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
// default copy ctor, assignment operator and dtor are ok
|
||||||
|
|
||||||
|
const wxColour& GetColour() const { return m_col; }
|
||||||
|
void SetColour(const wxColour& col) { m_col = col; }
|
||||||
|
|
||||||
|
float GetPosition() const { return m_pos; }
|
||||||
|
void SetPosition(float pos)
|
||||||
|
{
|
||||||
|
wxASSERT_MSG( pos >= 0 && pos <= 1, "invalid gradient stop position" );
|
||||||
|
|
||||||
|
m_pos = pos;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
// The colour of this gradient band.
|
||||||
|
wxColour m_col;
|
||||||
|
|
||||||
|
// Its starting position: 0 is the beginning and 1 is the end.
|
||||||
|
float m_pos;
|
||||||
|
};
|
||||||
|
|
||||||
|
// A collection of gradient stops ordered by their positions (from lowest to
|
||||||
|
// highest). The first stop (index 0, position 0.0) is always the starting
|
||||||
|
// colour and the last one (index GetCount() - 1, position 1.0) is the end
|
||||||
|
// colour.
|
||||||
|
class WXDLLIMPEXP_CORE wxGraphicsGradientStops
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxGraphicsGradientStops(wxColour startCol = wxTransparentColour,
|
||||||
|
wxColour endCol = wxTransparentColour)
|
||||||
|
{
|
||||||
|
// we can't use Add() here as it relies on having start/end stops as
|
||||||
|
// first/last array elements so do it manually
|
||||||
|
m_stops.push_back(wxGraphicsGradientStop(startCol, 0.f));
|
||||||
|
m_stops.push_back(wxGraphicsGradientStop(endCol, 1.f));
|
||||||
|
}
|
||||||
|
|
||||||
|
// default copy ctor, assignment operator and dtor are ok for this class
|
||||||
|
|
||||||
|
|
||||||
|
// Add a stop in correct order.
|
||||||
|
void Add(const wxGraphicsGradientStop& stop);
|
||||||
|
void Add(wxColour col, float pos) { Add(wxGraphicsGradientStop(col, pos)); }
|
||||||
|
|
||||||
|
// Get the number of stops.
|
||||||
|
size_t GetCount() const { return m_stops.size(); }
|
||||||
|
|
||||||
|
// Return the stop at the given index (which must be valid).
|
||||||
|
wxGraphicsGradientStop Item(unsigned n) const { return m_stops.at(n); }
|
||||||
|
|
||||||
|
// Get/set start and end colours.
|
||||||
|
void SetStartColour(wxColour col)
|
||||||
|
{ m_stops[0].SetColour(col); }
|
||||||
|
wxColour GetStartColour() const
|
||||||
|
{ return m_stops[0].GetColour(); }
|
||||||
|
void SetEndColour(wxColour col)
|
||||||
|
{ m_stops[m_stops.size() - 1].SetColour(col); }
|
||||||
|
wxColour GetEndColour() const
|
||||||
|
{ return m_stops[m_stops.size() - 1].GetColour(); }
|
||||||
|
|
||||||
|
private:
|
||||||
|
// All the stops stored in ascending order of positions.
|
||||||
|
wxVector<wxGraphicsGradientStop> m_stops;
|
||||||
|
};
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxGraphicsPenInfo describes a wxGraphicsPen
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class wxGraphicsPenInfo : public wxPenInfoBase<wxGraphicsPenInfo>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
explicit wxGraphicsPenInfo(const wxColour& colour = wxColour(),
|
||||||
|
wxDouble width = 1.0,
|
||||||
|
wxPenStyle style = wxPENSTYLE_SOLID)
|
||||||
|
: wxPenInfoBase<wxGraphicsPenInfo>(colour, style)
|
||||||
|
{
|
||||||
|
m_width = width;
|
||||||
|
m_gradientType = wxGRADIENT_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Setters
|
||||||
|
|
||||||
|
wxGraphicsPenInfo& Width(wxDouble width)
|
||||||
|
{ m_width = width; return *this; }
|
||||||
|
|
||||||
|
wxGraphicsPenInfo&
|
||||||
|
LinearGradient(wxDouble x1, wxDouble y1, wxDouble x2, wxDouble y2,
|
||||||
|
const wxColour& c1, const wxColour& c2,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix)
|
||||||
|
{
|
||||||
|
m_gradientType = wxGRADIENT_LINEAR;
|
||||||
|
m_x1 = x1;
|
||||||
|
m_y1 = y1;
|
||||||
|
m_x2 = x2;
|
||||||
|
m_y2 = y2;
|
||||||
|
m_stops.SetStartColour(c1);
|
||||||
|
m_stops.SetEndColour(c2);
|
||||||
|
m_matrix = matrix;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxGraphicsPenInfo&
|
||||||
|
LinearGradient(wxDouble x1, wxDouble y1, wxDouble x2, wxDouble y2,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix)
|
||||||
|
{
|
||||||
|
m_gradientType = wxGRADIENT_LINEAR;
|
||||||
|
m_x1 = x1;
|
||||||
|
m_y1 = y1;
|
||||||
|
m_x2 = x2;
|
||||||
|
m_y2 = y2;
|
||||||
|
m_stops = stops;
|
||||||
|
m_matrix = matrix;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxGraphicsPenInfo&
|
||||||
|
RadialGradient(wxDouble startX, wxDouble startY,
|
||||||
|
wxDouble endX, wxDouble endY, wxDouble radius,
|
||||||
|
const wxColour& oColor, const wxColour& cColor,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix)
|
||||||
|
{
|
||||||
|
m_gradientType = wxGRADIENT_RADIAL;
|
||||||
|
m_x1 = startX;
|
||||||
|
m_y1 = startY;
|
||||||
|
m_x2 = endX;
|
||||||
|
m_y2 = endY;
|
||||||
|
m_radius = radius;
|
||||||
|
m_stops.SetStartColour(oColor);
|
||||||
|
m_stops.SetEndColour(cColor);
|
||||||
|
m_matrix = matrix;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxGraphicsPenInfo&
|
||||||
|
RadialGradient(wxDouble startX, wxDouble startY,
|
||||||
|
wxDouble endX, wxDouble endY,
|
||||||
|
wxDouble radius, const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix)
|
||||||
|
{
|
||||||
|
m_gradientType = wxGRADIENT_RADIAL;
|
||||||
|
m_x1 = startX;
|
||||||
|
m_y1 = startY;
|
||||||
|
m_x2 = endX;
|
||||||
|
m_y2 = endY;
|
||||||
|
m_radius = radius;
|
||||||
|
m_stops = stops;
|
||||||
|
m_matrix = matrix;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Accessors
|
||||||
|
|
||||||
|
wxDouble GetWidth() const { return m_width; }
|
||||||
|
wxGradientType GetGradientType() const { return m_gradientType; }
|
||||||
|
wxDouble GetX1() const { return m_x1; }
|
||||||
|
wxDouble GetY1() const { return m_y1; }
|
||||||
|
wxDouble GetX2() const { return m_x2; }
|
||||||
|
wxDouble GetY2() const { return m_y2; }
|
||||||
|
wxDouble GetStartX() const { return m_x1; }
|
||||||
|
wxDouble GetStartY() const { return m_y1; }
|
||||||
|
wxDouble GetEndX() const { return m_x2; }
|
||||||
|
wxDouble GetEndY() const { return m_y2; }
|
||||||
|
wxDouble GetRadius() const { return m_radius; }
|
||||||
|
const wxGraphicsGradientStops& GetStops() const { return m_stops; }
|
||||||
|
const wxGraphicsMatrix& GetMatrix() const { return m_matrix; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
wxDouble m_width;
|
||||||
|
wxGradientType m_gradientType;
|
||||||
|
wxDouble m_x1, m_y1, m_x2, m_y2; // also used for m_xo, m_yo, m_xc, m_yc
|
||||||
|
wxDouble m_radius;
|
||||||
|
wxGraphicsGradientStops m_stops;
|
||||||
|
wxGraphicsMatrix m_matrix;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class WXDLLIMPEXP_CORE wxGraphicsPath : public wxGraphicsObject
|
class WXDLLIMPEXP_CORE wxGraphicsPath : public wxGraphicsObject
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@@ -373,82 +551,6 @@ private:
|
|||||||
extern WXDLLIMPEXP_DATA_CORE(wxGraphicsPath) wxNullGraphicsPath;
|
extern WXDLLIMPEXP_DATA_CORE(wxGraphicsPath) wxNullGraphicsPath;
|
||||||
|
|
||||||
|
|
||||||
// Describes a single gradient stop.
|
|
||||||
class wxGraphicsGradientStop
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
wxGraphicsGradientStop(wxColour col = wxTransparentColour,
|
|
||||||
float pos = 0.)
|
|
||||||
: m_col(col),
|
|
||||||
m_pos(pos)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
// default copy ctor, assignment operator and dtor are ok
|
|
||||||
|
|
||||||
const wxColour& GetColour() const { return m_col; }
|
|
||||||
void SetColour(const wxColour& col) { m_col = col; }
|
|
||||||
|
|
||||||
float GetPosition() const { return m_pos; }
|
|
||||||
void SetPosition(float pos)
|
|
||||||
{
|
|
||||||
wxASSERT_MSG( pos >= 0 && pos <= 1, "invalid gradient stop position" );
|
|
||||||
|
|
||||||
m_pos = pos;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
// The colour of this gradient band.
|
|
||||||
wxColour m_col;
|
|
||||||
|
|
||||||
// Its starting position: 0 is the beginning and 1 is the end.
|
|
||||||
float m_pos;
|
|
||||||
};
|
|
||||||
|
|
||||||
// A collection of gradient stops ordered by their positions (from lowest to
|
|
||||||
// highest). The first stop (index 0, position 0.0) is always the starting
|
|
||||||
// colour and the last one (index GetCount() - 1, position 1.0) is the end
|
|
||||||
// colour.
|
|
||||||
class WXDLLIMPEXP_CORE wxGraphicsGradientStops
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
wxGraphicsGradientStops(wxColour startCol = wxTransparentColour,
|
|
||||||
wxColour endCol = wxTransparentColour)
|
|
||||||
{
|
|
||||||
// we can't use Add() here as it relies on having start/end stops as
|
|
||||||
// first/last array elements so do it manually
|
|
||||||
m_stops.push_back(wxGraphicsGradientStop(startCol, 0.f));
|
|
||||||
m_stops.push_back(wxGraphicsGradientStop(endCol, 1.f));
|
|
||||||
}
|
|
||||||
|
|
||||||
// default copy ctor, assignment operator and dtor are ok for this class
|
|
||||||
|
|
||||||
|
|
||||||
// Add a stop in correct order.
|
|
||||||
void Add(const wxGraphicsGradientStop& stop);
|
|
||||||
void Add(wxColour col, float pos) { Add(wxGraphicsGradientStop(col, pos)); }
|
|
||||||
|
|
||||||
// Get the number of stops.
|
|
||||||
size_t GetCount() const { return m_stops.size(); }
|
|
||||||
|
|
||||||
// Return the stop at the given index (which must be valid).
|
|
||||||
wxGraphicsGradientStop Item(unsigned n) const { return m_stops.at(n); }
|
|
||||||
|
|
||||||
// Get/set start and end colours.
|
|
||||||
void SetStartColour(wxColour col)
|
|
||||||
{ m_stops[0].SetColour(col); }
|
|
||||||
wxColour GetStartColour() const
|
|
||||||
{ return m_stops[0].GetColour(); }
|
|
||||||
void SetEndColour(wxColour col)
|
|
||||||
{ m_stops[m_stops.size() - 1].SetColour(col); }
|
|
||||||
wxColour GetEndColour() const
|
|
||||||
{ return m_stops[m_stops.size() - 1].GetColour(); }
|
|
||||||
|
|
||||||
private:
|
|
||||||
// All the stops stored in ascending order of positions.
|
|
||||||
wxVector<wxGraphicsGradientStop> m_stops;
|
|
||||||
};
|
|
||||||
|
|
||||||
class WXDLLIMPEXP_CORE wxGraphicsContext : public wxGraphicsObject
|
class WXDLLIMPEXP_CORE wxGraphicsContext : public wxGraphicsObject
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@@ -523,24 +625,28 @@ public:
|
|||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxColour& c1, const wxColour& c2) const;
|
const wxColour& c1, const wxColour& c2,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) const;
|
||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops) const;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) const;
|
||||||
|
|
||||||
// sets the brush to a radial gradient originating at (xo,yc) and ending
|
// sets the brush to a radial gradient originating at (xo,yc) and ending
|
||||||
// on a circle around (xc,yc) with the given radius; the colours may be
|
// on a circle around (xc,yc) with the given radius; the colours may be
|
||||||
// specified by just the two extremes or the full array of gradient stops
|
// specified by just the two extremes or the full array of gradient stops
|
||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc, wxDouble radius,
|
wxDouble endX, wxDouble endY, wxDouble radius,
|
||||||
const wxColour& oColor, const wxColour& cColor) const;
|
const wxColour& oColor, const wxColour& cColor,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) const;
|
||||||
|
|
||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc, wxDouble radius,
|
wxDouble endX, wxDouble endY, wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops) const;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) const;
|
||||||
|
|
||||||
// creates a font
|
// creates a font
|
||||||
virtual wxGraphicsFont CreateFont( const wxFont &font , const wxColour &col = *wxBLACK ) const;
|
virtual wxGraphicsFont CreateFont( const wxFont &font , const wxColour &col = *wxBLACK ) const;
|
||||||
@@ -916,13 +1022,15 @@ public:
|
|||||||
virtual wxGraphicsBrush
|
virtual wxGraphicsBrush
|
||||||
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops) = 0;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) = 0;
|
||||||
|
|
||||||
virtual wxGraphicsBrush
|
virtual wxGraphicsBrush
|
||||||
CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops) = 0;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) = 0;
|
||||||
|
|
||||||
// sets the font
|
// sets the font
|
||||||
virtual wxGraphicsFont CreateFont( const wxFont &font , const wxColour &col = *wxBLACK ) = 0;
|
virtual wxGraphicsFont CreateFont( const wxFont &font , const wxColour &col = *wxBLACK ) = 0;
|
||||||
|
@@ -305,6 +305,19 @@ enum wxCompositionMode
|
|||||||
wxCOMPOSITION_ADD /**< @e R = @e S + @e D */
|
wxCOMPOSITION_ADD /**< @e R = @e S + @e D */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
Used to indicate what kind of gradient is set in a wxGraphicsPenInfo
|
||||||
|
object.
|
||||||
|
|
||||||
|
@since 3.1.3
|
||||||
|
*/
|
||||||
|
enum wxGradientType {
|
||||||
|
wxGRADIENT_NONE,
|
||||||
|
wxGRADIENT_LINEAR,
|
||||||
|
wxGRADIENT_RADIAL
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Represents a bitmap.
|
Represents a bitmap.
|
||||||
|
|
||||||
@@ -633,11 +646,14 @@ public:
|
|||||||
of gradient @a stops can be specified.
|
of gradient @a stops can be specified.
|
||||||
|
|
||||||
The version taking wxGraphicsGradientStops is new in wxWidgets 2.9.1.
|
The version taking wxGraphicsGradientStops is new in wxWidgets 2.9.1.
|
||||||
|
|
||||||
|
The @a matrix parameter was added in wxWidgets 3.1.3
|
||||||
*/
|
*/
|
||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxColour& c1, const wxColour& c2) const;
|
const wxColour& c1, const wxColour& c2,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@overload
|
@overload
|
||||||
@@ -645,34 +661,39 @@ public:
|
|||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops) const;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Creates a native brush with a radial gradient.
|
Creates a native brush with a radial gradient.
|
||||||
|
|
||||||
The brush originates at (@a xo, @a yc) and ends on a circle around
|
The brush originates at (@a startX, @a startY) and ends on a circle around
|
||||||
(@a xc, @a yc) with the given @a radius.
|
(@a endX, @a endY) with the given @a radius.
|
||||||
|
|
||||||
The gradient may be specified either by its start and end colours @a
|
The gradient may be specified either by its start and end colours @a
|
||||||
oColor and @a cColor or by a full set of gradient @a stops.
|
oColor and @a cColor or by a full set of gradient @a stops.
|
||||||
|
|
||||||
The version taking wxGraphicsGradientStops is new in wxWidgets 2.9.1.
|
The version taking wxGraphicsGradientStops is new in wxWidgets 2.9.1.
|
||||||
|
|
||||||
|
The ability to apply a transformation matrix to the gradient was added in 3.1.3
|
||||||
*/
|
*/
|
||||||
virtual wxGraphicsBrush
|
virtual wxGraphicsBrush
|
||||||
CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxColour& oColor,
|
const wxColour& oColor,
|
||||||
const wxColour& cColor) const;
|
const wxColour& cColor,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@overload
|
@overload
|
||||||
*/
|
*/
|
||||||
virtual wxGraphicsBrush
|
virtual wxGraphicsBrush
|
||||||
CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops) = 0;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Sets the brush for filling paths.
|
Sets the brush for filling paths.
|
||||||
@@ -1444,12 +1465,16 @@ public:
|
|||||||
|
|
||||||
Stops support is new since wxWidgets 2.9.1, previously only the start
|
Stops support is new since wxWidgets 2.9.1, previously only the start
|
||||||
and end colours could be specified.
|
and end colours could be specified.
|
||||||
|
|
||||||
|
The ability to apply a transformation matrix to the gradient was added in 3.1.3
|
||||||
|
|
||||||
*/
|
*/
|
||||||
virtual wxGraphicsBrush CreateLinearGradientBrush(wxDouble x1,
|
virtual wxGraphicsBrush CreateLinearGradientBrush(wxDouble x1,
|
||||||
wxDouble y1,
|
wxDouble y1,
|
||||||
wxDouble x2,
|
wxDouble x2,
|
||||||
wxDouble y2,
|
wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops) = 0;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Creates a native affine transformation matrix from the passed in
|
Creates a native affine transformation matrix from the passed in
|
||||||
@@ -1477,11 +1502,14 @@ public:
|
|||||||
|
|
||||||
Stops support is new since wxWidgets 2.9.1, previously only the start
|
Stops support is new since wxWidgets 2.9.1, previously only the start
|
||||||
and end colours could be specified.
|
and end colours could be specified.
|
||||||
|
|
||||||
|
The ability to apply a transformation matrix to the gradient was added in 3.1.3
|
||||||
*/
|
*/
|
||||||
virtual wxGraphicsBrush CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
virtual wxGraphicsBrush CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops) = 0;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Extracts a sub-bitmap from an existing bitmap.
|
Extracts a sub-bitmap from an existing bitmap.
|
||||||
@@ -1620,6 +1648,50 @@ public:
|
|||||||
wxGraphicsPenInfo& Join(wxPenJoin join);
|
wxGraphicsPenInfo& Join(wxPenJoin join);
|
||||||
|
|
||||||
wxGraphicsPenInfo& Cap(wxPenCap cap);
|
wxGraphicsPenInfo& Cap(wxPenCap cap);
|
||||||
|
|
||||||
|
wxGraphicsPenInfo&
|
||||||
|
LinearGradient(wxDouble x1, wxDouble y1, wxDouble x2, wxDouble y2,
|
||||||
|
const wxColour& c1, const wxColour& c2,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix);
|
||||||
|
|
||||||
|
wxGraphicsPenInfo&
|
||||||
|
LinearGradient(wxDouble x1, wxDouble y1, wxDouble x2, wxDouble y2,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix);
|
||||||
|
|
||||||
|
wxGraphicsPenInfo&
|
||||||
|
RadialGradient(wxDouble startX, wxDouble startY,
|
||||||
|
wxDouble endX, wxDouble endY, wxDouble radius,
|
||||||
|
const wxColour& oColor, const wxColour& cColor,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix);
|
||||||
|
|
||||||
|
wxGraphicsPenInfo&
|
||||||
|
RadialGradient(wxDouble startX, wxDouble startY,
|
||||||
|
wxDouble endX, wxDouble endY,
|
||||||
|
wxDouble radius, const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix);
|
||||||
|
|
||||||
|
wxColour GetColour() const;
|
||||||
|
wxBitmap GetStipple() const;
|
||||||
|
wxPenStyle GetStyle() const;
|
||||||
|
wxPenJoin GetJoin() const;
|
||||||
|
wxPenCap GetCap() const;
|
||||||
|
int GetDashes(wxDash **ptr);
|
||||||
|
int GetDashCount() const;
|
||||||
|
wxDash* GetDash() const;
|
||||||
|
bool IsTransparent() const;
|
||||||
|
wxDouble GetWidth() const;
|
||||||
|
wxGradientType GetGradientType() const;
|
||||||
|
wxDouble GetX1() const;
|
||||||
|
wxDouble GetY1() const;
|
||||||
|
wxDouble GetX2() const;
|
||||||
|
wxDouble GetY2() const;
|
||||||
|
wxDouble GetStartX() const;
|
||||||
|
wxDouble GetStartY() const;
|
||||||
|
wxDouble GetEndX() const;
|
||||||
|
wxDouble GetEndY() const;
|
||||||
|
wxDouble GetRadius() const;
|
||||||
|
const wxGraphicsGradientStops& GetStops() const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@@ -137,6 +137,17 @@ public:
|
|||||||
wxPenInfo& Join(wxPenJoin join);
|
wxPenInfo& Join(wxPenJoin join);
|
||||||
|
|
||||||
wxPenInfo& Cap(wxPenCap cap);
|
wxPenInfo& Cap(wxPenCap cap);
|
||||||
|
|
||||||
|
wxColour GetColour() const;
|
||||||
|
wxBitmap GetStipple() const;
|
||||||
|
wxPenStyle GetStyle() const;
|
||||||
|
wxPenJoin GetJoin() const;
|
||||||
|
wxPenCap GetCap() const;
|
||||||
|
int GetDashes(wxDash **ptr);
|
||||||
|
int GetDashCount() const;
|
||||||
|
wxDash* GetDash() const;
|
||||||
|
bool IsTransparent() const;
|
||||||
|
int GetWidth() const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@@ -1638,6 +1638,29 @@ void MyCanvas::DrawGradients(wxDC& dc)
|
|||||||
pth.GetBox(&boxX, &boxY, &boxWidth, &boxHeight);
|
pth.GetBox(&boxX, &boxY, &boxWidth, &boxHeight);
|
||||||
dc.CalcBoundingBox(wxRound(boxX), wxRound(boxY));
|
dc.CalcBoundingBox(wxRound(boxX), wxRound(boxY));
|
||||||
dc.CalcBoundingBox(wxRound(boxX+boxWidth), wxRound(boxY+boxHeight));
|
dc.CalcBoundingBox(wxRound(boxX+boxWidth), wxRound(boxY+boxHeight));
|
||||||
|
|
||||||
|
gfr.Offset(0, gfr.height + 10);
|
||||||
|
dc.DrawText("Stroked path with a gradient pen", gfr.x, gfr.y);
|
||||||
|
gfr.Offset(0, TEXT_HEIGHT);
|
||||||
|
|
||||||
|
pth = gc->CreatePath();
|
||||||
|
pth.MoveToPoint(gfr.x + gfr.width/2, gfr.y);
|
||||||
|
pth.AddLineToPoint(gfr.x + gfr.width, gfr.y + gfr.height/2);
|
||||||
|
pth.AddLineToPoint(gfr.x + gfr.width/2, gfr.y + gfr.height);
|
||||||
|
pth.AddLineToPoint(gfr.x, gfr.y + gfr.height/2);
|
||||||
|
pth.CloseSubpath();
|
||||||
|
|
||||||
|
stops = wxGraphicsGradientStops(*wxRED, *wxBLUE);
|
||||||
|
stops.Add(wxColour(255,255,0), 0.33f);
|
||||||
|
stops.Add(*wxGREEN, 0.67f);
|
||||||
|
|
||||||
|
wxGraphicsPen pen = gc->CreatePen(
|
||||||
|
wxGraphicsPenInfo(wxColour(0,0,0)).Width(6).Join(wxJOIN_BEVEL).LinearGradient(
|
||||||
|
gfr.x + gfr.width/2, gfr.y,
|
||||||
|
gfr.x + gfr.width/2, gfr.y + gfr.height,
|
||||||
|
stops));
|
||||||
|
gc->SetPen(pen);
|
||||||
|
gc->StrokePath(pth);
|
||||||
}
|
}
|
||||||
#endif // wxUSE_GRAPHICS_CONTEXT
|
#endif // wxUSE_GRAPHICS_CONTEXT
|
||||||
}
|
}
|
||||||
|
@@ -110,6 +110,8 @@
|
|||||||
(cairo_pattern_t *pattern, cairo_extend_t extend), (pattern, extend) ) \
|
(cairo_pattern_t *pattern, cairo_extend_t extend), (pattern, extend) ) \
|
||||||
m( cairo_pattern_set_filter, \
|
m( cairo_pattern_set_filter, \
|
||||||
(cairo_pattern_t *pattern, cairo_filter_t filter), (pattern, filter) ) \
|
(cairo_pattern_t *pattern, cairo_filter_t filter), (pattern, filter) ) \
|
||||||
|
m( cairo_pattern_set_matrix, \
|
||||||
|
(cairo_pattern_t *pattern, const cairo_matrix_t *matrix), (pattern, matrix) ) \
|
||||||
m( cairo_pop_group_to_source, \
|
m( cairo_pop_group_to_source, \
|
||||||
(cairo_t *cr), (cr) ) \
|
(cairo_t *cr), (cr) ) \
|
||||||
m( cairo_push_group, \
|
m( cairo_push_group, \
|
||||||
|
@@ -883,13 +883,15 @@ wxGraphicsBrush
|
|||||||
wxGraphicsContext::CreateLinearGradientBrush(
|
wxGraphicsContext::CreateLinearGradientBrush(
|
||||||
wxDouble x1, wxDouble y1,
|
wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxColour& c1, const wxColour& c2) const
|
const wxColour& c1, const wxColour& c2,
|
||||||
|
const wxGraphicsMatrix& matrix) const
|
||||||
{
|
{
|
||||||
return GetRenderer()->CreateLinearGradientBrush
|
return GetRenderer()->CreateLinearGradientBrush
|
||||||
(
|
(
|
||||||
x1, y1,
|
x1, y1,
|
||||||
x2, y2,
|
x2, y2,
|
||||||
wxGraphicsGradientStops(c1,c2)
|
wxGraphicsGradientStops(c1,c2),
|
||||||
|
matrix
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -897,36 +899,47 @@ wxGraphicsBrush
|
|||||||
wxGraphicsContext::CreateLinearGradientBrush(
|
wxGraphicsContext::CreateLinearGradientBrush(
|
||||||
wxDouble x1, wxDouble y1,
|
wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& gradientStops) const
|
const wxGraphicsGradientStops& gradientStops,
|
||||||
|
const wxGraphicsMatrix& matrix) const
|
||||||
{
|
{
|
||||||
return GetRenderer()->CreateLinearGradientBrush(x1,y1,x2,y2, gradientStops);
|
return GetRenderer()->CreateLinearGradientBrush
|
||||||
}
|
|
||||||
|
|
||||||
wxGraphicsBrush
|
|
||||||
wxGraphicsContext::CreateRadialGradientBrush(
|
|
||||||
wxDouble xo, wxDouble yo,
|
|
||||||
wxDouble xc, wxDouble yc, wxDouble radius,
|
|
||||||
const wxColour &oColor, const wxColour &cColor) const
|
|
||||||
{
|
|
||||||
return GetRenderer()->CreateRadialGradientBrush
|
|
||||||
(
|
(
|
||||||
xo, yo,
|
x1, y1,
|
||||||
xc, yc, radius,
|
x2, y2,
|
||||||
wxGraphicsGradientStops(oColor, cColor)
|
gradientStops,
|
||||||
|
matrix
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
wxGraphicsContext::CreateRadialGradientBrush(
|
wxGraphicsContext::CreateRadialGradientBrush(
|
||||||
wxDouble xo, wxDouble yo,
|
wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc, wxDouble radius,
|
wxDouble endX, wxDouble endY, wxDouble radius,
|
||||||
const wxGraphicsGradientStops& gradientStops) const
|
const wxColour &oColor, const wxColour &cColor,
|
||||||
|
const wxGraphicsMatrix& matrix) const
|
||||||
{
|
{
|
||||||
return GetRenderer()->CreateRadialGradientBrush
|
return GetRenderer()->CreateRadialGradientBrush
|
||||||
(
|
(
|
||||||
xo, yo,
|
startX, startY,
|
||||||
xc, yc, radius,
|
endX, endY, radius,
|
||||||
gradientStops
|
wxGraphicsGradientStops(oColor, cColor),
|
||||||
|
matrix
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
wxGraphicsBrush
|
||||||
|
wxGraphicsContext::CreateRadialGradientBrush(
|
||||||
|
wxDouble startX, wxDouble startY,
|
||||||
|
wxDouble endX, wxDouble endY, wxDouble radius,
|
||||||
|
const wxGraphicsGradientStops& gradientStops,
|
||||||
|
const wxGraphicsMatrix& matrix) const
|
||||||
|
{
|
||||||
|
return GetRenderer()->CreateRadialGradientBrush
|
||||||
|
(
|
||||||
|
startX, startY,
|
||||||
|
endX, endY, radius,
|
||||||
|
gradientStops,
|
||||||
|
matrix
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -260,6 +260,15 @@ public:
|
|||||||
|
|
||||||
virtual void Apply( wxGraphicsContext* context );
|
virtual void Apply( wxGraphicsContext* context );
|
||||||
|
|
||||||
|
void CreateLinearGradientPattern(wxDouble x1, wxDouble y1,
|
||||||
|
wxDouble x2, wxDouble y2,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix);
|
||||||
|
void CreateRadialGradientPattern(wxDouble startX, wxDouble startY,
|
||||||
|
wxDouble endX, wxDouble endY, wxDouble radius,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// Call this to use the given bitmap as stipple. Bitmap must be non-null
|
// Call this to use the given bitmap as stipple. Bitmap must be non-null
|
||||||
// and valid.
|
// and valid.
|
||||||
@@ -268,6 +277,8 @@ protected:
|
|||||||
// Call this to use the given hatch style. Hatch style must be valid.
|
// Call this to use the given hatch style. Hatch style must be valid.
|
||||||
void InitHatch(wxHatchStyle hatchStyle);
|
void InitHatch(wxHatchStyle hatchStyle);
|
||||||
|
|
||||||
|
// common part of Create{Linear,Radial}GradientPattern()
|
||||||
|
void AddGradientStops(const wxGraphicsGradientStops& stops);
|
||||||
|
|
||||||
double m_red;
|
double m_red;
|
||||||
double m_green;
|
double m_green;
|
||||||
@@ -316,18 +327,8 @@ public:
|
|||||||
wxCairoBrushData( wxGraphicsRenderer* renderer );
|
wxCairoBrushData( wxGraphicsRenderer* renderer );
|
||||||
wxCairoBrushData( wxGraphicsRenderer* renderer, const wxBrush &brush );
|
wxCairoBrushData( wxGraphicsRenderer* renderer, const wxBrush &brush );
|
||||||
|
|
||||||
void CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
|
||||||
wxDouble x2, wxDouble y2,
|
|
||||||
const wxGraphicsGradientStops& stops);
|
|
||||||
void CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
|
||||||
wxDouble xc, wxDouble yc, wxDouble radius,
|
|
||||||
const wxGraphicsGradientStops& stops);
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void Init();
|
void Init();
|
||||||
|
|
||||||
// common part of Create{Linear,Radial}GradientBrush()
|
|
||||||
void AddGradientStops(const wxGraphicsGradientStops& stops);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class wxCairoFontData : public wxGraphicsObjectRefData
|
class wxCairoFontData : public wxGraphicsObjectRefData
|
||||||
@@ -721,6 +722,66 @@ void wxCairoPenBrushBaseData::Apply( wxGraphicsContext* context )
|
|||||||
cairo_set_source_rgba(ctext, m_red, m_green, m_blue, m_alpha);
|
cairo_set_source_rgba(ctext, m_red, m_green, m_blue, m_alpha);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxCairoPenBrushBaseData::AddGradientStops(const wxGraphicsGradientStops& stops)
|
||||||
|
{
|
||||||
|
// loop over all the stops, they include the beginning and ending ones
|
||||||
|
const unsigned numStops = stops.GetCount();
|
||||||
|
for ( unsigned n = 0; n < numStops; n++ )
|
||||||
|
{
|
||||||
|
const wxGraphicsGradientStop stop = stops.Item(n);
|
||||||
|
|
||||||
|
const wxColour col = stop.GetColour();
|
||||||
|
|
||||||
|
cairo_pattern_add_color_stop_rgba
|
||||||
|
(
|
||||||
|
m_pattern,
|
||||||
|
stop.GetPosition(),
|
||||||
|
col.Red()/255.0,
|
||||||
|
col.Green()/255.0,
|
||||||
|
col.Blue()/255.0,
|
||||||
|
col.Alpha()/255.0
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
wxASSERT_MSG(cairo_pattern_status(m_pattern) == CAIRO_STATUS_SUCCESS,
|
||||||
|
wxT("Couldn't create cairo pattern"));
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
wxCairoPenBrushBaseData::CreateLinearGradientPattern(wxDouble x1, wxDouble y1,
|
||||||
|
wxDouble x2, wxDouble y2,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
|
{
|
||||||
|
m_pattern = cairo_pattern_create_linear(x1,y1,x2,y2);
|
||||||
|
|
||||||
|
if ( !matrix.IsNull() )
|
||||||
|
{
|
||||||
|
cairo_matrix_t m = *((cairo_matrix_t*) matrix.GetNativeMatrix());
|
||||||
|
cairo_pattern_set_matrix(m_pattern, &m);
|
||||||
|
}
|
||||||
|
|
||||||
|
AddGradientStops(stops);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
wxCairoPenBrushBaseData::CreateRadialGradientPattern(wxDouble startX, wxDouble startY,
|
||||||
|
wxDouble endX, wxDouble endY,
|
||||||
|
wxDouble radius,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
|
{
|
||||||
|
m_pattern = cairo_pattern_create_radial(startX,startY,0.0,endX,endY,radius);
|
||||||
|
|
||||||
|
if ( !matrix.IsNull() )
|
||||||
|
{
|
||||||
|
cairo_matrix_t m = *((cairo_matrix_t*) matrix.GetNativeMatrix());
|
||||||
|
cairo_pattern_set_matrix(m_pattern, &m);
|
||||||
|
}
|
||||||
|
|
||||||
|
AddGradientStops(stops);
|
||||||
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// wxCairoPenData implementation
|
// wxCairoPenData implementation
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -732,6 +793,7 @@ wxCairoPenData::~wxCairoPenData()
|
|||||||
|
|
||||||
void wxCairoPenData::Init()
|
void wxCairoPenData::Init()
|
||||||
{
|
{
|
||||||
|
m_pattern = NULL;
|
||||||
m_lengths = NULL;
|
m_lengths = NULL;
|
||||||
m_userLengths = NULL;
|
m_userLengths = NULL;
|
||||||
m_width = 0;
|
m_width = 0;
|
||||||
@@ -867,6 +929,27 @@ wxCairoPenData::wxCairoPenData( wxGraphicsRenderer* renderer, const wxGraphicsPe
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch ( info.GetGradientType() )
|
||||||
|
{
|
||||||
|
case wxGRADIENT_NONE:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case wxGRADIENT_LINEAR:
|
||||||
|
CreateLinearGradientPattern(info.GetX1(), info.GetY1(),
|
||||||
|
info.GetX2(), info.GetY2(),
|
||||||
|
info.GetStops(),
|
||||||
|
info.GetMatrix());
|
||||||
|
break;
|
||||||
|
|
||||||
|
case wxGRADIENT_RADIAL:
|
||||||
|
CreateRadialGradientPattern(info.GetStartX(), info.GetStartY(),
|
||||||
|
info.GetEndX(), info.GetEndY(),
|
||||||
|
info.GetRadius(),
|
||||||
|
info.GetStops(),
|
||||||
|
info.GetMatrix());
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxCairoPenData::Apply( wxGraphicsContext* context )
|
void wxCairoPenData::Apply( wxGraphicsContext* context )
|
||||||
@@ -911,52 +994,6 @@ wxCairoBrushData::wxCairoBrushData( wxGraphicsRenderer* renderer,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxCairoBrushData::AddGradientStops(const wxGraphicsGradientStops& stops)
|
|
||||||
{
|
|
||||||
// loop over all the stops, they include the beginning and ending ones
|
|
||||||
const unsigned numStops = stops.GetCount();
|
|
||||||
for ( unsigned n = 0; n < numStops; n++ )
|
|
||||||
{
|
|
||||||
const wxGraphicsGradientStop stop = stops.Item(n);
|
|
||||||
|
|
||||||
const wxColour col = stop.GetColour();
|
|
||||||
|
|
||||||
cairo_pattern_add_color_stop_rgba
|
|
||||||
(
|
|
||||||
m_pattern,
|
|
||||||
stop.GetPosition(),
|
|
||||||
col.Red()/255.0,
|
|
||||||
col.Green()/255.0,
|
|
||||||
col.Blue()/255.0,
|
|
||||||
col.Alpha()/255.0
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
wxASSERT_MSG(cairo_pattern_status(m_pattern) == CAIRO_STATUS_SUCCESS,
|
|
||||||
wxT("Couldn't create cairo pattern"));
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
wxCairoBrushData::CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
|
||||||
wxDouble x2, wxDouble y2,
|
|
||||||
const wxGraphicsGradientStops& stops)
|
|
||||||
{
|
|
||||||
m_pattern = cairo_pattern_create_linear(x1,y1,x2,y2);
|
|
||||||
|
|
||||||
AddGradientStops(stops);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
wxCairoBrushData::CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
|
||||||
wxDouble xc, wxDouble yc,
|
|
||||||
wxDouble radius,
|
|
||||||
const wxGraphicsGradientStops& stops)
|
|
||||||
{
|
|
||||||
m_pattern = cairo_pattern_create_radial(xo,yo,0.0,xc,yc,radius);
|
|
||||||
|
|
||||||
AddGradientStops(stops);
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxCairoBrushData::Init()
|
void wxCairoBrushData::Init()
|
||||||
{
|
{
|
||||||
m_pattern = NULL;
|
m_pattern = NULL;
|
||||||
@@ -2956,13 +2993,15 @@ public :
|
|||||||
virtual wxGraphicsBrush
|
virtual wxGraphicsBrush
|
||||||
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops) wxOVERRIDE;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) wxOVERRIDE;
|
||||||
|
|
||||||
virtual wxGraphicsBrush
|
virtual wxGraphicsBrush
|
||||||
CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops) wxOVERRIDE;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) wxOVERRIDE;
|
||||||
|
|
||||||
// sets the font
|
// sets the font
|
||||||
virtual wxGraphicsFont CreateFont( const wxFont &font , const wxColour &col = *wxBLACK ) wxOVERRIDE ;
|
virtual wxGraphicsFont CreateFont( const wxFont &font , const wxColour &col = *wxBLACK ) wxOVERRIDE ;
|
||||||
@@ -3150,29 +3189,32 @@ wxGraphicsBrush wxCairoRenderer::CreateBrush(const wxBrush& brush )
|
|||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
wxCairoRenderer::CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
wxCairoRenderer::CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
{
|
{
|
||||||
wxGraphicsBrush p;
|
wxGraphicsBrush p;
|
||||||
ENSURE_LOADED_OR_RETURN(p);
|
ENSURE_LOADED_OR_RETURN(p);
|
||||||
wxCairoBrushData* d = new wxCairoBrushData( this );
|
wxCairoBrushData* d = new wxCairoBrushData( this );
|
||||||
d->CreateLinearGradientBrush(x1, y1, x2, y2, stops);
|
d->CreateLinearGradientPattern(x1, y1, x2, y2, stops, matrix);
|
||||||
p.SetRefData(d);
|
p.SetRefData(d);
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
wxCairoRenderer::CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
wxCairoRenderer::CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc, wxDouble r,
|
wxDouble endX, wxDouble endY, wxDouble r,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
{
|
{
|
||||||
wxGraphicsBrush p;
|
wxGraphicsBrush p;
|
||||||
ENSURE_LOADED_OR_RETURN(p);
|
ENSURE_LOADED_OR_RETURN(p);
|
||||||
wxCairoBrushData* d = new wxCairoBrushData( this );
|
wxCairoBrushData* d = new wxCairoBrushData( this );
|
||||||
d->CreateRadialGradientBrush(xo, yo, xc, yc, r, stops);
|
d->CreateRadialGradientPattern(startX, startY, endX, endY, r, stops, matrix);
|
||||||
p.SetRefData(d);
|
p.SetRefData(d);
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
wxGraphicsFont wxCairoRenderer::CreateFont( const wxFont &font , const wxColour &col )
|
wxGraphicsFont wxCairoRenderer::CreateFont( const wxFont &font , const wxColour &col )
|
||||||
{
|
{
|
||||||
wxGraphicsFont p;
|
wxGraphicsFont p;
|
||||||
|
@@ -255,44 +255,31 @@ private:
|
|||||||
Matrix* m_matrix ;
|
Matrix* m_matrix ;
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
class wxGDIPlusPenData : public wxGraphicsObjectRefData
|
|
||||||
|
// Things that pens and brushes have in common
|
||||||
|
class wxGDIPlusPenBrushBaseData : public wxGraphicsObjectRefData
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
wxGDIPlusPenData( wxGraphicsRenderer* renderer, const wxGraphicsPenInfo &info );
|
wxGDIPlusPenBrushBaseData(wxGraphicsRenderer* renderer);
|
||||||
~wxGDIPlusPenData();
|
|
||||||
|
|
||||||
void Init();
|
virtual void Init();
|
||||||
|
|
||||||
virtual wxDouble GetWidth() { return m_width; }
|
|
||||||
virtual Pen* GetGDIPlusPen() { return m_pen; }
|
|
||||||
|
|
||||||
protected :
|
|
||||||
Pen* m_pen;
|
|
||||||
Image* m_penImage;
|
|
||||||
Brush* m_penBrush;
|
|
||||||
|
|
||||||
wxDouble m_width;
|
|
||||||
};
|
|
||||||
|
|
||||||
class wxGDIPlusBrushData : public wxGraphicsObjectRefData
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
wxGDIPlusBrushData( wxGraphicsRenderer* renderer );
|
|
||||||
wxGDIPlusBrushData( wxGraphicsRenderer* renderer, const wxBrush &brush );
|
|
||||||
~wxGDIPlusBrushData ();
|
|
||||||
|
|
||||||
void CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
void CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops);
|
const wxGraphicsGradientStops& stops,
|
||||||
void CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix);
|
||||||
wxDouble xc, wxDouble yc,
|
void CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops);
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix);
|
||||||
virtual Brush* GetGDIPlusBrush() { return m_brush; }
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void Init();
|
virtual ~wxGDIPlusPenBrushBaseData();
|
||||||
|
|
||||||
|
Brush* m_brush;
|
||||||
|
GraphicsPath* m_brushPath;
|
||||||
|
Image* m_image;
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// common part of Create{Linear,Radial}GradientBrush()
|
// common part of Create{Linear,Radial}GradientBrush()
|
||||||
@@ -300,10 +287,35 @@ private:
|
|||||||
void SetGradientStops(T *brush,
|
void SetGradientStops(T *brush,
|
||||||
const wxGraphicsGradientStops& stops,
|
const wxGraphicsGradientStops& stops,
|
||||||
bool reversed = false);
|
bool reversed = false);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class wxGDIPlusPenData : public wxGDIPlusPenBrushBaseData
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxGDIPlusPenData( wxGraphicsRenderer* renderer, const wxGraphicsPenInfo &info );
|
||||||
|
~wxGDIPlusPenData();
|
||||||
|
|
||||||
|
virtual void Init() wxOVERRIDE;
|
||||||
|
|
||||||
|
virtual wxDouble GetWidth() { return m_width; }
|
||||||
|
virtual Pen* GetGDIPlusPen() { return m_pen; }
|
||||||
|
|
||||||
|
protected :
|
||||||
|
Pen* m_pen;
|
||||||
|
wxDouble m_width;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class wxGDIPlusBrushData : public wxGDIPlusPenBrushBaseData
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxGDIPlusBrushData( wxGraphicsRenderer* renderer );
|
||||||
|
wxGDIPlusBrushData( wxGraphicsRenderer* renderer, const wxBrush &brush );
|
||||||
|
~wxGDIPlusBrushData ();
|
||||||
|
|
||||||
|
virtual Brush* GetGDIPlusBrush() { return m_brush; }
|
||||||
|
|
||||||
Brush* m_brush;
|
|
||||||
Image* m_brushImage;
|
|
||||||
GraphicsPath* m_brushPath;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class WXDLLIMPEXP_CORE wxGDIPlusBitmapData : public wxGraphicsBitmapData
|
class WXDLLIMPEXP_CORE wxGDIPlusBitmapData : public wxGraphicsBitmapData
|
||||||
@@ -624,13 +636,15 @@ public :
|
|||||||
virtual wxGraphicsBrush
|
virtual wxGraphicsBrush
|
||||||
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops) wxOVERRIDE;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) wxOVERRIDE;
|
||||||
|
|
||||||
virtual wxGraphicsBrush
|
virtual wxGraphicsBrush
|
||||||
CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops) wxOVERRIDE;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) wxOVERRIDE;
|
||||||
|
|
||||||
// create a native bitmap representation
|
// create a native bitmap representation
|
||||||
virtual wxGraphicsBitmap CreateBitmap( const wxBitmap &bitmap ) wxOVERRIDE;
|
virtual wxGraphicsBitmap CreateBitmap( const wxBitmap &bitmap ) wxOVERRIDE;
|
||||||
@@ -669,6 +683,136 @@ private :
|
|||||||
wxDECLARE_DYNAMIC_CLASS_NO_COPY(wxGDIPlusRenderer);
|
wxDECLARE_DYNAMIC_CLASS_NO_COPY(wxGDIPlusRenderer);
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// wxGDIPlusPenBrushBaseData implementation
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
wxGDIPlusPenBrushBaseData::wxGDIPlusPenBrushBaseData(wxGraphicsRenderer* renderer)
|
||||||
|
: wxGraphicsObjectRefData(renderer)
|
||||||
|
{
|
||||||
|
Init();
|
||||||
|
}
|
||||||
|
|
||||||
|
wxGDIPlusPenBrushBaseData::~wxGDIPlusPenBrushBaseData()
|
||||||
|
{
|
||||||
|
delete m_brush;
|
||||||
|
delete m_brushPath;
|
||||||
|
delete m_image;
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxGDIPlusPenBrushBaseData::Init()
|
||||||
|
{
|
||||||
|
m_brush = NULL;
|
||||||
|
m_brushPath = NULL;
|
||||||
|
m_image = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void
|
||||||
|
wxGDIPlusPenBrushBaseData::SetGradientStops(T *brush,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
bool reversed)
|
||||||
|
{
|
||||||
|
const unsigned numStops = stops.GetCount();
|
||||||
|
if ( numStops <= 2 )
|
||||||
|
{
|
||||||
|
// initial and final colours are set during the brush creation, nothing
|
||||||
|
// more to do
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxVector<Color> colors(numStops);
|
||||||
|
wxVector<REAL> positions(numStops);
|
||||||
|
|
||||||
|
if ( reversed )
|
||||||
|
{
|
||||||
|
for ( unsigned i = 0; i < numStops; i++ )
|
||||||
|
{
|
||||||
|
wxGraphicsGradientStop stop = stops.Item(numStops - i - 1);
|
||||||
|
|
||||||
|
colors[i] = wxColourToColor(stop.GetColour());
|
||||||
|
positions[i] = 1.0 - stop.GetPosition();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for ( unsigned i = 0; i < numStops; i++ )
|
||||||
|
{
|
||||||
|
wxGraphicsGradientStop stop = stops.Item(i);
|
||||||
|
|
||||||
|
colors[i] = wxColourToColor(stop.GetColour());
|
||||||
|
positions[i] = stop.GetPosition();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
brush->SetInterpolationColors(&colors[0], &positions[0], numStops);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
wxGDIPlusPenBrushBaseData::CreateLinearGradientBrush(
|
||||||
|
wxDouble x1, wxDouble y1,
|
||||||
|
wxDouble x2, wxDouble y2,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
|
{
|
||||||
|
LinearGradientBrush * const
|
||||||
|
brush = new LinearGradientBrush(PointF(x1, y1) , PointF(x2, y2),
|
||||||
|
wxColourToColor(stops.GetStartColour()),
|
||||||
|
wxColourToColor(stops.GetEndColour()));
|
||||||
|
|
||||||
|
// Tell the brush how to draw what's beyond the ends of the gradient
|
||||||
|
brush->SetWrapMode(WrapModeTileFlipXY);
|
||||||
|
|
||||||
|
// Apply the matrix if there is one
|
||||||
|
if ( !matrix.IsNull() )
|
||||||
|
{
|
||||||
|
Matrix* m = static_cast<Matrix*>(matrix.GetNativeMatrix());
|
||||||
|
m->Invert();
|
||||||
|
brush->MultiplyTransform(m);
|
||||||
|
}
|
||||||
|
|
||||||
|
SetGradientStops(brush, stops);
|
||||||
|
m_brush = brush;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
wxGDIPlusPenBrushBaseData::CreateRadialGradientBrush(
|
||||||
|
wxDouble startX, wxDouble startY,
|
||||||
|
wxDouble endX, wxDouble endY,
|
||||||
|
wxDouble radius,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
|
{
|
||||||
|
m_brushPath = new GraphicsPath();
|
||||||
|
m_brushPath->AddEllipse( (REAL)(endX-radius), (REAL)(endY-radius),
|
||||||
|
(REAL)(2*radius), (REAL)(2*radius));
|
||||||
|
|
||||||
|
PathGradientBrush * const brush = new PathGradientBrush(m_brushPath);
|
||||||
|
brush->SetCenterPoint(PointF(startX, startY));
|
||||||
|
brush->SetCenterColor(wxColourToColor(stops.GetStartColour()));
|
||||||
|
|
||||||
|
const Color col(wxColourToColor(stops.GetEndColour()));
|
||||||
|
int count = 1;
|
||||||
|
brush->SetSurroundColors(&col, &count);
|
||||||
|
|
||||||
|
// TODO: There doesn't seem to be an equivallent for SetWrapMode, so
|
||||||
|
// the area outside of the gradient's radius is not getting painted.
|
||||||
|
|
||||||
|
// Apply the matrix if there is one
|
||||||
|
if ( !matrix.IsNull() )
|
||||||
|
{
|
||||||
|
Matrix* m = static_cast<Matrix*>(matrix.GetNativeMatrix());
|
||||||
|
m->Invert();
|
||||||
|
brush->SetTransform(m);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Because the GDI+ API draws radial gradients from outside towards the
|
||||||
|
// center we have to reverse the order of the gradient stops.
|
||||||
|
SetGradientStops(brush, stops, true);
|
||||||
|
m_brush = brush;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// wxGDIPlusPen implementation
|
// wxGDIPlusPen implementation
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -676,20 +820,16 @@ private :
|
|||||||
wxGDIPlusPenData::~wxGDIPlusPenData()
|
wxGDIPlusPenData::~wxGDIPlusPenData()
|
||||||
{
|
{
|
||||||
delete m_pen;
|
delete m_pen;
|
||||||
delete m_penImage;
|
|
||||||
delete m_penBrush;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxGDIPlusPenData::Init()
|
void wxGDIPlusPenData::Init()
|
||||||
{
|
{
|
||||||
m_pen = NULL ;
|
m_pen = NULL ;
|
||||||
m_penImage = NULL;
|
|
||||||
m_penBrush = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
wxGDIPlusPenData::wxGDIPlusPenData( wxGraphicsRenderer* renderer,
|
wxGDIPlusPenData::wxGDIPlusPenData( wxGraphicsRenderer* renderer,
|
||||||
const wxGraphicsPenInfo &info )
|
const wxGraphicsPenInfo &info )
|
||||||
: wxGraphicsObjectRefData(renderer)
|
: wxGDIPlusPenBrushBaseData(renderer)
|
||||||
{
|
{
|
||||||
Init();
|
Init();
|
||||||
m_width = info.GetWidth();
|
m_width = info.GetWidth();
|
||||||
@@ -786,15 +926,15 @@ wxGDIPlusPenData::wxGDIPlusPenData( wxGraphicsRenderer* renderer,
|
|||||||
wxBitmap bmp = info.GetStipple();
|
wxBitmap bmp = info.GetStipple();
|
||||||
if ( bmp.IsOk() )
|
if ( bmp.IsOk() )
|
||||||
{
|
{
|
||||||
m_penImage = Bitmap::FromHBITMAP((HBITMAP)bmp.GetHBITMAP(),
|
m_image = Bitmap::FromHBITMAP((HBITMAP)bmp.GetHBITMAP(),
|
||||||
#if wxUSE_PALETTE
|
#if wxUSE_PALETTE
|
||||||
(HPALETTE)bmp.GetPalette()->GetHPALETTE()
|
(HPALETTE)bmp.GetPalette()->GetHPALETTE()
|
||||||
#else
|
#else
|
||||||
NULL
|
NULL
|
||||||
#endif
|
#endif
|
||||||
);
|
);
|
||||||
m_penBrush = new TextureBrush(m_penImage);
|
m_brush = new TextureBrush(m_image);
|
||||||
m_pen->SetBrush( m_penBrush );
|
m_pen->SetBrush( m_brush );
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -827,18 +967,43 @@ wxGDIPlusPenData::wxGDIPlusPenData( wxGraphicsRenderer* renderer,
|
|||||||
default:
|
default:
|
||||||
style = HatchStyleHorizontal;
|
style = HatchStyleHorizontal;
|
||||||
}
|
}
|
||||||
m_penBrush = new HatchBrush
|
m_brush = new HatchBrush
|
||||||
(
|
(
|
||||||
style,
|
style,
|
||||||
wxColourToColor(info.GetColour()),
|
wxColourToColor(info.GetColour()),
|
||||||
Color::Transparent
|
Color::Transparent
|
||||||
);
|
);
|
||||||
m_pen->SetBrush( m_penBrush );
|
m_pen->SetBrush( m_brush );
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if ( dashStyle != DashStyleSolid )
|
if ( dashStyle != DashStyleSolid )
|
||||||
m_pen->SetDashStyle(dashStyle);
|
m_pen->SetDashStyle(dashStyle);
|
||||||
|
|
||||||
|
switch (info.GetGradientType() )
|
||||||
|
{
|
||||||
|
case wxGRADIENT_NONE:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case wxGRADIENT_LINEAR:
|
||||||
|
if (m_brush)
|
||||||
|
delete m_brush;
|
||||||
|
CreateLinearGradientBrush(info.GetX1(), info.GetY1(),
|
||||||
|
info.GetX2(), info.GetY2(),
|
||||||
|
info.GetStops());
|
||||||
|
m_pen->SetBrush(m_brush);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case wxGRADIENT_RADIAL:
|
||||||
|
if (m_brush)
|
||||||
|
delete m_brush;
|
||||||
|
CreateRadialGradientBrush(info.GetStartX(), info.GetStartY(),
|
||||||
|
info.GetEndX(), info.GetEndY(),
|
||||||
|
info.GetRadius(),
|
||||||
|
info.GetStops());
|
||||||
|
m_pen->SetBrush(m_brush);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -846,13 +1011,13 @@ wxGDIPlusPenData::wxGDIPlusPenData( wxGraphicsRenderer* renderer,
|
|||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
wxGDIPlusBrushData::wxGDIPlusBrushData( wxGraphicsRenderer* renderer )
|
wxGDIPlusBrushData::wxGDIPlusBrushData( wxGraphicsRenderer* renderer )
|
||||||
: wxGraphicsObjectRefData(renderer)
|
: wxGDIPlusPenBrushBaseData(renderer)
|
||||||
{
|
{
|
||||||
Init();
|
Init();
|
||||||
}
|
}
|
||||||
|
|
||||||
wxGDIPlusBrushData::wxGDIPlusBrushData( wxGraphicsRenderer* renderer , const wxBrush &brush )
|
wxGDIPlusBrushData::wxGDIPlusBrushData( wxGraphicsRenderer* renderer , const wxBrush &brush )
|
||||||
: wxGraphicsObjectRefData(renderer)
|
: wxGDIPlusPenBrushBaseData(renderer)
|
||||||
{
|
{
|
||||||
Init();
|
Init();
|
||||||
if ( brush.GetStyle() == wxBRUSHSTYLE_SOLID)
|
if ( brush.GetStyle() == wxBRUSHSTYLE_SOLID)
|
||||||
@@ -897,111 +1062,23 @@ wxGDIPlusBrushData::wxGDIPlusBrushData( wxGraphicsRenderer* renderer , const wxB
|
|||||||
wxBitmap* bmp = brush.GetStipple();
|
wxBitmap* bmp = brush.GetStipple();
|
||||||
if ( bmp && bmp->IsOk() )
|
if ( bmp && bmp->IsOk() )
|
||||||
{
|
{
|
||||||
wxDELETE( m_brushImage );
|
wxDELETE( m_image );
|
||||||
m_brushImage = Bitmap::FromHBITMAP((HBITMAP)bmp->GetHBITMAP(),
|
m_image = Bitmap::FromHBITMAP((HBITMAP)bmp->GetHBITMAP(),
|
||||||
#if wxUSE_PALETTE
|
#if wxUSE_PALETTE
|
||||||
(HPALETTE)bmp->GetPalette()->GetHPALETTE()
|
(HPALETTE)bmp->GetPalette()->GetHPALETTE()
|
||||||
#else
|
#else
|
||||||
NULL
|
NULL
|
||||||
#endif
|
#endif
|
||||||
);
|
);
|
||||||
m_brush = new TextureBrush(m_brushImage);
|
m_brush = new TextureBrush(m_image);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
wxGDIPlusBrushData::~wxGDIPlusBrushData()
|
wxGDIPlusBrushData::~wxGDIPlusBrushData()
|
||||||
{
|
{
|
||||||
delete m_brush;
|
|
||||||
delete m_brushImage;
|
|
||||||
delete m_brushPath;
|
|
||||||
};
|
|
||||||
|
|
||||||
void wxGDIPlusBrushData::Init()
|
|
||||||
{
|
|
||||||
m_brush = NULL;
|
|
||||||
m_brushImage= NULL;
|
|
||||||
m_brushPath= NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
void
|
|
||||||
wxGDIPlusBrushData::SetGradientStops(T *brush,
|
|
||||||
const wxGraphicsGradientStops& stops,
|
|
||||||
bool reversed)
|
|
||||||
{
|
|
||||||
const unsigned numStops = stops.GetCount();
|
|
||||||
if ( numStops <= 2 )
|
|
||||||
{
|
|
||||||
// initial and final colours are set during the brush creation, nothing
|
|
||||||
// more to do
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxVector<Color> colors(numStops);
|
|
||||||
wxVector<REAL> positions(numStops);
|
|
||||||
|
|
||||||
if ( reversed )
|
|
||||||
{
|
|
||||||
for ( unsigned i = 0; i < numStops; i++ )
|
|
||||||
{
|
|
||||||
wxGraphicsGradientStop stop = stops.Item(numStops - i - 1);
|
|
||||||
|
|
||||||
colors[i] = wxColourToColor(stop.GetColour());
|
|
||||||
positions[i] = 1.0 - stop.GetPosition();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for ( unsigned i = 0; i < numStops; i++ )
|
|
||||||
{
|
|
||||||
wxGraphicsGradientStop stop = stops.Item(i);
|
|
||||||
|
|
||||||
colors[i] = wxColourToColor(stop.GetColour());
|
|
||||||
positions[i] = stop.GetPosition();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
brush->SetInterpolationColors(&colors[0], &positions[0], numStops);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
wxGDIPlusBrushData::CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
|
||||||
wxDouble x2, wxDouble y2,
|
|
||||||
const wxGraphicsGradientStops& stops)
|
|
||||||
{
|
|
||||||
LinearGradientBrush * const
|
|
||||||
brush = new LinearGradientBrush(PointF(x1, y1) , PointF(x2, y2),
|
|
||||||
wxColourToColor(stops.GetStartColour()),
|
|
||||||
wxColourToColor(stops.GetEndColour()));
|
|
||||||
m_brush = brush;
|
|
||||||
|
|
||||||
SetGradientStops(brush, stops);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
wxGDIPlusBrushData::CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
|
||||||
wxDouble xc, wxDouble yc,
|
|
||||||
wxDouble radius,
|
|
||||||
const wxGraphicsGradientStops& stops)
|
|
||||||
{
|
|
||||||
m_brushPath = new GraphicsPath();
|
|
||||||
m_brushPath->AddEllipse( (REAL)(xc-radius), (REAL)(yc-radius),
|
|
||||||
(REAL)(2*radius), (REAL)(2*radius));
|
|
||||||
|
|
||||||
PathGradientBrush * const brush = new PathGradientBrush(m_brushPath);
|
|
||||||
m_brush = brush;
|
|
||||||
brush->SetCenterPoint(PointF(xo, yo));
|
|
||||||
brush->SetCenterColor(wxColourToColor(stops.GetStartColour()));
|
|
||||||
|
|
||||||
const Color col(wxColourToColor(stops.GetEndColour()));
|
|
||||||
int count = 1;
|
|
||||||
brush->SetSurroundColors(&col, &count);
|
|
||||||
|
|
||||||
// Because the GDI+ API draws radial gradients from outside towards the
|
|
||||||
// center we have to reverse the order of the gradient stops.
|
|
||||||
SetGradientStops(brush, stops, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Support for adding private fonts
|
// Support for adding private fonts
|
||||||
@@ -2613,26 +2690,28 @@ wxGraphicsBrush wxGDIPlusRenderer::CreateBrush(const wxBrush& brush )
|
|||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
wxGDIPlusRenderer::CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
wxGDIPlusRenderer::CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
{
|
{
|
||||||
ENSURE_LOADED_OR_RETURN(wxNullGraphicsBrush);
|
ENSURE_LOADED_OR_RETURN(wxNullGraphicsBrush);
|
||||||
wxGraphicsBrush p;
|
wxGraphicsBrush p;
|
||||||
wxGDIPlusBrushData* d = new wxGDIPlusBrushData( this );
|
wxGDIPlusBrushData* d = new wxGDIPlusBrushData( this );
|
||||||
d->CreateLinearGradientBrush(x1, y1, x2, y2, stops);
|
d->CreateLinearGradientBrush(x1, y1, x2, y2, stops, matrix);
|
||||||
p.SetRefData(d);
|
p.SetRefData(d);
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxGraphicsBrush
|
wxGraphicsBrush
|
||||||
wxGDIPlusRenderer::CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
wxGDIPlusRenderer::CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
{
|
{
|
||||||
ENSURE_LOADED_OR_RETURN(wxNullGraphicsBrush);
|
ENSURE_LOADED_OR_RETURN(wxNullGraphicsBrush);
|
||||||
wxGraphicsBrush p;
|
wxGraphicsBrush p;
|
||||||
wxGDIPlusBrushData* d = new wxGDIPlusBrushData( this );
|
wxGDIPlusBrushData* d = new wxGDIPlusBrushData( this );
|
||||||
d->CreateRadialGradientBrush(xo,yo,xc,yc,radius,stops);
|
d->CreateRadialGradientBrush(startX,startY,endX,endY,radius,stops,matrix);
|
||||||
p.SetRefData(d);
|
p.SetRefData(d);
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
@@ -1772,9 +1772,6 @@ void wxD2DPathData::AddPath(const wxGraphicsPathData* path)
|
|||||||
GeometryStateData curStateSrc;
|
GeometryStateData curStateSrc;
|
||||||
pathSrc->SaveGeometryState(curStateSrc);
|
pathSrc->SaveGeometryState(curStateSrc);
|
||||||
|
|
||||||
// Raise warning if appended path has an open non-empty sub-path.
|
|
||||||
wxASSERT_MSG( pathSrc->IsStateSafeForFlush(),
|
|
||||||
wxS("Sub-path in appended path should be closed prior to this operation") );
|
|
||||||
// Close appended geometry.
|
// Close appended geometry.
|
||||||
pathSrc->Flush();
|
pathSrc->Flush();
|
||||||
|
|
||||||
@@ -1893,8 +1890,7 @@ void wxD2DPathData::Transform(const wxGraphicsMatrixData* matrix)
|
|||||||
// constraints this can be fully done only if open figure was empty.
|
// constraints this can be fully done only if open figure was empty.
|
||||||
// So, Transform() can be safely called if path doesn't contain the open
|
// So, Transform() can be safely called if path doesn't contain the open
|
||||||
// sub-path or if open sub-path is empty.
|
// sub-path or if open sub-path is empty.
|
||||||
wxASSERT_MSG( IsStateSafeForFlush(),
|
|
||||||
wxS("Consider closing sub-path before calling Transform()") );
|
|
||||||
// Close current geometry.
|
// Close current geometry.
|
||||||
Flush();
|
Flush();
|
||||||
|
|
||||||
@@ -2425,27 +2421,46 @@ class wxD2DLinearGradientBrushResourceHolder : public wxD2DResourceHolder<ID2D1L
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
struct LinearGradientInfo {
|
struct LinearGradientInfo {
|
||||||
const wxRect direction;
|
const wxDouble x1;
|
||||||
|
const wxDouble y1;
|
||||||
|
const wxDouble x2;
|
||||||
|
const wxDouble y2;
|
||||||
const wxGraphicsGradientStops stops;
|
const wxGraphicsGradientStops stops;
|
||||||
LinearGradientInfo(wxDouble& x1, wxDouble& y1, wxDouble& x2, wxDouble& y2, const wxGraphicsGradientStops& stops_)
|
const wxGraphicsMatrix matrix;
|
||||||
: direction(x1, y1, x2, y2), stops(stops_) {}
|
LinearGradientInfo(wxDouble& x1_, wxDouble& y1_,
|
||||||
|
wxDouble& x2_, wxDouble& y2_,
|
||||||
|
const wxGraphicsGradientStops& stops_,
|
||||||
|
const wxGraphicsMatrix& matrix_)
|
||||||
|
: x1(x1_), y1(y1_), x2(x2_), y2(y2_), stops(stops_), matrix(matrix_) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
wxD2DLinearGradientBrushResourceHolder(wxDouble& x1, wxDouble& y1, wxDouble& x2, wxDouble& y2, const wxGraphicsGradientStops& stops)
|
wxD2DLinearGradientBrushResourceHolder(wxDouble& x1, wxDouble& y1,
|
||||||
: m_linearGradientInfo(x1, y1, x2, y2, stops) {}
|
wxDouble& x2, wxDouble& y2,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
|
: m_linearGradientInfo(x1, y1, x2, y2, stops, matrix) {}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void DoAcquireResource() wxOVERRIDE
|
void DoAcquireResource() wxOVERRIDE
|
||||||
{
|
{
|
||||||
wxD2DGradientStopsHelper helper(m_linearGradientInfo.stops, GetContext());
|
wxD2DGradientStopsHelper helper(m_linearGradientInfo.stops, GetContext());
|
||||||
|
ID2D1LinearGradientBrush *linearGradientBrush;
|
||||||
|
|
||||||
HRESULT hr = GetContext()->CreateLinearGradientBrush(
|
HRESULT hr = GetContext()->CreateLinearGradientBrush(
|
||||||
D2D1::LinearGradientBrushProperties(
|
D2D1::LinearGradientBrushProperties(
|
||||||
D2D1::Point2F(m_linearGradientInfo.direction.GetX(), m_linearGradientInfo.direction.GetY()),
|
D2D1::Point2F(m_linearGradientInfo.x1, m_linearGradientInfo.y1),
|
||||||
D2D1::Point2F(m_linearGradientInfo.direction.GetWidth(), m_linearGradientInfo.direction.GetHeight())),
|
D2D1::Point2F(m_linearGradientInfo.x2, m_linearGradientInfo.y2)),
|
||||||
helper.GetGradientStopCollection(),
|
helper.GetGradientStopCollection(),
|
||||||
&m_nativeResource);
|
&linearGradientBrush);
|
||||||
wxCHECK_HRESULT_RET(hr);
|
wxCHECK_HRESULT_RET(hr);
|
||||||
|
|
||||||
|
if (! m_linearGradientInfo.matrix.IsNull())
|
||||||
|
{
|
||||||
|
D2D1::Matrix3x2F matrix = wxGetD2DMatrixData(m_linearGradientInfo.matrix)->GetMatrix3x2F();
|
||||||
|
matrix.Invert();
|
||||||
|
linearGradientBrush->SetTransform(matrix);
|
||||||
|
}
|
||||||
|
m_nativeResource = linearGradientBrush;
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
const LinearGradientInfo m_linearGradientInfo;
|
const LinearGradientInfo m_linearGradientInfo;
|
||||||
@@ -2455,33 +2470,54 @@ class wxD2DRadialGradientBrushResourceHolder : public wxD2DResourceHolder<ID2D1R
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
struct RadialGradientInfo {
|
struct RadialGradientInfo {
|
||||||
const wxRect direction;
|
const wxDouble x1;
|
||||||
|
const wxDouble y1;
|
||||||
|
const wxDouble x2;
|
||||||
|
const wxDouble y2;
|
||||||
const wxDouble radius;
|
const wxDouble radius;
|
||||||
const wxGraphicsGradientStops stops;
|
const wxGraphicsGradientStops stops;
|
||||||
|
const wxGraphicsMatrix matrix;
|
||||||
|
|
||||||
RadialGradientInfo(wxDouble x1, wxDouble y1, wxDouble x2, wxDouble y2, wxDouble r, const wxGraphicsGradientStops& stops_)
|
RadialGradientInfo(wxDouble x1_, wxDouble y1_,
|
||||||
: direction(x1, y1, x2, y2), radius(r), stops(stops_) {}
|
wxDouble x2_, wxDouble y2_,
|
||||||
|
wxDouble r,
|
||||||
|
const wxGraphicsGradientStops& stops_,
|
||||||
|
const wxGraphicsMatrix& matrix_)
|
||||||
|
: x1(x1_), y1(y1_), x2(x2_), y2(y2_), radius(r), stops(stops_), matrix(matrix_) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
wxD2DRadialGradientBrushResourceHolder(wxDouble& x1, wxDouble& y1, wxDouble& x2, wxDouble& y2, wxDouble& r, const wxGraphicsGradientStops& stops)
|
wxD2DRadialGradientBrushResourceHolder(wxDouble& x1, wxDouble& y1,
|
||||||
: m_radialGradientInfo(x1, y1, x2, y2, r, stops) {}
|
wxDouble& x2, wxDouble& y2,
|
||||||
|
wxDouble& r,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
|
: m_radialGradientInfo(x1, y1, x2, y2, r, stops, matrix) {}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void DoAcquireResource() wxOVERRIDE
|
void DoAcquireResource() wxOVERRIDE
|
||||||
{
|
{
|
||||||
wxD2DGradientStopsHelper helper(m_radialGradientInfo.stops, GetContext());
|
wxD2DGradientStopsHelper helper(m_radialGradientInfo.stops, GetContext());
|
||||||
|
ID2D1RadialGradientBrush *radialGradientBrush;
|
||||||
|
|
||||||
int xo = m_radialGradientInfo.direction.GetLeft() - m_radialGradientInfo.direction.GetWidth();
|
wxDouble xo = m_radialGradientInfo.x1 - m_radialGradientInfo.x2;
|
||||||
int yo = m_radialGradientInfo.direction.GetTop() - m_radialGradientInfo.direction.GetHeight();
|
wxDouble yo = m_radialGradientInfo.y1 - m_radialGradientInfo.y2;
|
||||||
|
|
||||||
HRESULT hr = GetContext()->CreateRadialGradientBrush(
|
HRESULT hr = GetContext()->CreateRadialGradientBrush(
|
||||||
D2D1::RadialGradientBrushProperties(
|
D2D1::RadialGradientBrushProperties(
|
||||||
D2D1::Point2F(m_radialGradientInfo.direction.GetLeft(), m_radialGradientInfo.direction.GetTop()),
|
D2D1::Point2F(m_radialGradientInfo.x1, m_radialGradientInfo.y1),
|
||||||
D2D1::Point2F(xo, yo),
|
D2D1::Point2F(xo, yo),
|
||||||
m_radialGradientInfo.radius, m_radialGradientInfo.radius),
|
m_radialGradientInfo.radius, m_radialGradientInfo.radius),
|
||||||
helper.GetGradientStopCollection(),
|
helper.GetGradientStopCollection(),
|
||||||
&m_nativeResource);
|
&radialGradientBrush);
|
||||||
wxCHECK_HRESULT_RET(hr);
|
wxCHECK_HRESULT_RET(hr);
|
||||||
|
|
||||||
|
if (! m_radialGradientInfo.matrix.IsNull())
|
||||||
|
{
|
||||||
|
D2D1::Matrix3x2F matrix = wxGetD2DMatrixData(m_radialGradientInfo.matrix)->GetMatrix3x2F();
|
||||||
|
matrix.Invert();
|
||||||
|
radialGradientBrush->SetTransform(matrix);
|
||||||
|
}
|
||||||
|
m_nativeResource = radialGradientBrush;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@@ -2499,9 +2535,16 @@ public:
|
|||||||
|
|
||||||
wxD2DBrushData(wxGraphicsRenderer* renderer);
|
wxD2DBrushData(wxGraphicsRenderer* renderer);
|
||||||
|
|
||||||
void CreateLinearGradientBrush(wxDouble x1, wxDouble y1, wxDouble x2, wxDouble y2, const wxGraphicsGradientStops& stops);
|
void CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
|
wxDouble x2, wxDouble y2,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix);
|
||||||
|
|
||||||
void CreateRadialGradientBrush(wxDouble xo, wxDouble yo, wxDouble xc, wxDouble yc, wxDouble radius, const wxGraphicsGradientStops& stops);
|
void CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
|
wxDouble endX, wxDouble endY,
|
||||||
|
wxDouble radius,
|
||||||
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix);
|
||||||
|
|
||||||
ID2D1Brush* GetBrush() const
|
ID2D1Brush* GetBrush() const
|
||||||
{
|
{
|
||||||
@@ -2546,18 +2589,22 @@ wxD2DBrushData::wxD2DBrushData(wxGraphicsRenderer* renderer)
|
|||||||
void wxD2DBrushData::CreateLinearGradientBrush(
|
void wxD2DBrushData::CreateLinearGradientBrush(
|
||||||
wxDouble x1, wxDouble y1,
|
wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
{
|
{
|
||||||
m_brushResourceHolder = new wxD2DLinearGradientBrushResourceHolder(x1, y1, x2, y2, stops);
|
m_brushResourceHolder = new wxD2DLinearGradientBrushResourceHolder(
|
||||||
|
x1, y1, x2, y2, stops, matrix);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxD2DBrushData::CreateRadialGradientBrush(
|
void wxD2DBrushData::CreateRadialGradientBrush(
|
||||||
wxDouble xo, wxDouble yo,
|
wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
{
|
{
|
||||||
m_brushResourceHolder = new wxD2DRadialGradientBrushResourceHolder(xo, yo, xc, yc, radius, stops);
|
m_brushResourceHolder = new wxD2DRadialGradientBrushResourceHolder(
|
||||||
|
startX, startY, endX, endY, radius, stops, matrix);
|
||||||
}
|
}
|
||||||
|
|
||||||
wxD2DBrushData* wxGetD2DBrushData(const wxGraphicsBrush& brush)
|
wxD2DBrushData* wxGetD2DBrushData(const wxGraphicsBrush& brush)
|
||||||
@@ -2665,9 +2712,34 @@ wxD2DPenData::wxD2DPenData(
|
|||||||
strokeBrush.SetStyle(wxBRUSHSTYLE_SOLID);
|
strokeBrush.SetStyle(wxBRUSHSTYLE_SOLID);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_stippleBrush = new wxD2DBrushData(renderer, strokeBrush);
|
switch ( m_penInfo.GetGradientType() )
|
||||||
|
{
|
||||||
|
case wxGRADIENT_NONE:
|
||||||
|
m_stippleBrush = new wxD2DBrushData(renderer, strokeBrush);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case wxGRADIENT_LINEAR:
|
||||||
|
m_stippleBrush = new wxD2DBrushData(renderer);
|
||||||
|
m_stippleBrush->CreateLinearGradientBrush(
|
||||||
|
m_penInfo.GetX1(), m_penInfo.GetY1(),
|
||||||
|
m_penInfo.GetX2(), m_penInfo.GetY2(),
|
||||||
|
m_penInfo.GetStops(),
|
||||||
|
m_penInfo.GetMatrix());
|
||||||
|
break;
|
||||||
|
|
||||||
|
case wxGRADIENT_RADIAL:
|
||||||
|
m_stippleBrush = new wxD2DBrushData(renderer);
|
||||||
|
m_stippleBrush->CreateRadialGradientBrush(
|
||||||
|
m_penInfo.GetStartX(), m_penInfo.GetStartY(),
|
||||||
|
m_penInfo.GetEndX(), m_penInfo.GetEndY(),
|
||||||
|
m_penInfo.GetRadius(),
|
||||||
|
m_penInfo.GetStops(),
|
||||||
|
m_penInfo.GetMatrix());
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void wxD2DPenData::CreateStrokeStyle(ID2D1Factory* const direct2dfactory)
|
void wxD2DPenData::CreateStrokeStyle(ID2D1Factory* const direct2dfactory)
|
||||||
{
|
{
|
||||||
D2D1_CAP_STYLE capStyle = wxD2DConvertPenCap(m_penInfo.GetCap());
|
D2D1_CAP_STYLE capStyle = wxD2DConvertPenCap(m_penInfo.GetCap());
|
||||||
@@ -4558,13 +4630,15 @@ public :
|
|||||||
wxGraphicsBrush CreateLinearGradientBrush(
|
wxGraphicsBrush CreateLinearGradientBrush(
|
||||||
wxDouble x1, wxDouble y1,
|
wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops) wxOVERRIDE;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) wxOVERRIDE;
|
||||||
|
|
||||||
wxGraphicsBrush CreateRadialGradientBrush(
|
wxGraphicsBrush CreateRadialGradientBrush(
|
||||||
wxDouble xo, wxDouble yo,
|
wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops) wxOVERRIDE;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) wxOVERRIDE;
|
||||||
|
|
||||||
// create a native bitmap representation
|
// create a native bitmap representation
|
||||||
wxGraphicsBitmap CreateBitmap(const wxBitmap& bitmap) wxOVERRIDE;
|
wxGraphicsBitmap CreateBitmap(const wxBitmap& bitmap) wxOVERRIDE;
|
||||||
@@ -4749,10 +4823,11 @@ wxGraphicsBrush wxD2DRenderer::CreateBrush(const wxBrush& brush)
|
|||||||
wxGraphicsBrush wxD2DRenderer::CreateLinearGradientBrush(
|
wxGraphicsBrush wxD2DRenderer::CreateLinearGradientBrush(
|
||||||
wxDouble x1, wxDouble y1,
|
wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
{
|
{
|
||||||
wxD2DBrushData* brushData = new wxD2DBrushData(this);
|
wxD2DBrushData* brushData = new wxD2DBrushData(this);
|
||||||
brushData->CreateLinearGradientBrush(x1, y1, x2, y2, stops);
|
brushData->CreateLinearGradientBrush(x1, y1, x2, y2, stops, matrix);
|
||||||
|
|
||||||
wxGraphicsBrush brush;
|
wxGraphicsBrush brush;
|
||||||
brush.SetRefData(brushData);
|
brush.SetRefData(brushData);
|
||||||
@@ -4761,13 +4836,14 @@ wxGraphicsBrush wxD2DRenderer::CreateLinearGradientBrush(
|
|||||||
}
|
}
|
||||||
|
|
||||||
wxGraphicsBrush wxD2DRenderer::CreateRadialGradientBrush(
|
wxGraphicsBrush wxD2DRenderer::CreateRadialGradientBrush(
|
||||||
wxDouble xo, wxDouble yo,
|
wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix)
|
||||||
{
|
{
|
||||||
wxD2DBrushData* brushData = new wxD2DBrushData(this);
|
wxD2DBrushData* brushData = new wxD2DBrushData(this);
|
||||||
brushData->CreateRadialGradientBrush(xo, yo, xc, yc, radius, stops);
|
brushData->CreateRadialGradientBrush(startX, startY, endX, endY, radius, stops, matrix);
|
||||||
|
|
||||||
wxGraphicsBrush brush;
|
wxGraphicsBrush brush;
|
||||||
brush.SetRefData(brushData);
|
brush.SetRefData(brushData);
|
||||||
|
File diff suppressed because it is too large
Load Diff
@@ -91,12 +91,12 @@ public:
|
|||||||
m_brush = QBrush(gradient);
|
m_brush = QBrush(gradient);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
void CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops)
|
||||||
{
|
{
|
||||||
QRadialGradient gradient(QPointF(xc, yc), radius, QPointF(xo, yo));
|
QRadialGradient gradient(QPointF(endX, endY), radius, QPointF(startX, startY));
|
||||||
SetStops(gradient, stops);
|
SetStops(gradient, stops);
|
||||||
m_brush = QBrush(gradient);
|
m_brush = QBrush(gradient);
|
||||||
}
|
}
|
||||||
@@ -1137,13 +1137,15 @@ public:
|
|||||||
virtual wxGraphicsBrush
|
virtual wxGraphicsBrush
|
||||||
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
CreateLinearGradientBrush(wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops) wxOVERRIDE;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) wxOVERRIDE;
|
||||||
|
|
||||||
virtual wxGraphicsBrush
|
virtual wxGraphicsBrush
|
||||||
CreateRadialGradientBrush(wxDouble xo, wxDouble yo,
|
CreateRadialGradientBrush(wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc,
|
wxDouble endX, wxDouble endY,
|
||||||
wxDouble radius,
|
wxDouble radius,
|
||||||
const wxGraphicsGradientStops& stops) wxOVERRIDE;
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& matrix = wxNullGraphicsMatrix) wxOVERRIDE;
|
||||||
|
|
||||||
// sets the font
|
// sets the font
|
||||||
virtual wxGraphicsFont CreateFont(const wxFont& font,
|
virtual wxGraphicsFont CreateFont(const wxFont& font,
|
||||||
@@ -1274,7 +1276,8 @@ wxGraphicsBrush wxQtGraphicsRenderer::CreateBrush(const wxBrush& brush)
|
|||||||
wxGraphicsBrush wxQtGraphicsRenderer::CreateLinearGradientBrush(
|
wxGraphicsBrush wxQtGraphicsRenderer::CreateLinearGradientBrush(
|
||||||
wxDouble x1, wxDouble y1,
|
wxDouble x1, wxDouble y1,
|
||||||
wxDouble x2, wxDouble y2,
|
wxDouble x2, wxDouble y2,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& WXUNUSED(matrix))
|
||||||
{
|
{
|
||||||
wxGraphicsBrush p;
|
wxGraphicsBrush p;
|
||||||
wxQtBrushData* d = new wxQtBrushData(this);
|
wxQtBrushData* d = new wxQtBrushData(this);
|
||||||
@@ -1284,13 +1287,14 @@ wxGraphicsBrush wxQtGraphicsRenderer::CreateLinearGradientBrush(
|
|||||||
}
|
}
|
||||||
|
|
||||||
wxGraphicsBrush wxQtGraphicsRenderer::CreateRadialGradientBrush(
|
wxGraphicsBrush wxQtGraphicsRenderer::CreateRadialGradientBrush(
|
||||||
wxDouble xo, wxDouble yo,
|
wxDouble startX, wxDouble startY,
|
||||||
wxDouble xc, wxDouble yc, wxDouble r,
|
wxDouble endX, wxDouble endY, wxDouble r,
|
||||||
const wxGraphicsGradientStops& stops)
|
const wxGraphicsGradientStops& stops,
|
||||||
|
const wxGraphicsMatrix& WXUNUSED(matrix))
|
||||||
{
|
{
|
||||||
wxGraphicsBrush p;
|
wxGraphicsBrush p;
|
||||||
wxQtBrushData* d = new wxQtBrushData(this);
|
wxQtBrushData* d = new wxQtBrushData(this);
|
||||||
d->CreateRadialGradientBrush(xo, yo, xc, yc, r, stops);
|
d->CreateRadialGradientBrush(startX, startY, endX, endY, r, stops);
|
||||||
p.SetRefData(d);
|
p.SetRefData(d);
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user