|
Packit Service |
e3b512 |
/* Copyright (C) 2005 The cairomm Development Team
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* This library is free software; you can redistribute it and/or
|
|
Packit Service |
e3b512 |
* modify it under the terms of the GNU Library General Public
|
|
Packit Service |
e3b512 |
* License as published by the Free Software Foundation; either
|
|
Packit Service |
e3b512 |
* version 2 of the License, or (at your option) any later version.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* This library is distributed in the hope that it will be useful,
|
|
Packit Service |
e3b512 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit Service |
e3b512 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit Service |
e3b512 |
* Library General Public License for more details.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* You should have received a copy of the GNU Library General Public
|
|
Packit Service |
e3b512 |
* License along with this library; if not, write to the Free Software
|
|
Packit Service |
e3b512 |
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
Packit Service |
e3b512 |
* 02110-1301, USA.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
#ifndef __CAIROMM_PATTERN_H
|
|
Packit Service |
e3b512 |
#define __CAIROMM_PATTERN_H
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
#include <cairomm/surface.h>
|
|
Packit Service |
e3b512 |
#include <cairomm/enums.h>
|
|
Packit Service |
e3b512 |
#include <cairo.h>
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
namespace Cairo
|
|
Packit Service |
e3b512 |
{
|
|
Packit Service |
e3b512 |
struct ColorStop
|
|
Packit Service |
e3b512 |
{
|
|
Packit Service |
e3b512 |
double offset;
|
|
Packit Service |
e3b512 |
double red, green, blue, alpha;
|
|
Packit Service |
e3b512 |
};
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
class Matrix;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Cairo::Pattern is the paint with which cairo draws. The primary use of
|
|
Packit Service |
e3b512 |
* patterns is as the source for all cairo drawing operations, although they
|
|
Packit Service |
e3b512 |
* can also be used as masks, that is, as the brush too.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* This is a reference-counted object that should be used via Cairo::RefPtr.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
class Pattern
|
|
Packit Service |
e3b512 |
{
|
|
Packit Service |
e3b512 |
protected:
|
|
Packit Service |
e3b512 |
//Use derived constructors.
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
//TODO?: Pattern(cairo_pattern_t *target);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
public:
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/** Create a C++ wrapper for the C instance. This C++ instance should then be given to a RefPtr.
|
|
Packit Service |
e3b512 |
* @param cobject The C instance.
|
|
Packit Service |
e3b512 |
* @param has_reference Whether we already have a reference. Otherwise, the constructor will take an extra reference.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
explicit Pattern(cairo_pattern_t* cobject, bool has_reference = false);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
Pattern(const Pattern&) = delete;
|
|
Packit Service |
e3b512 |
Pattern& operator=(const Pattern&) = delete;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
virtual ~Pattern();
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Sets the pattern's transformation matrix to @matrix. This matrix is a
|
|
Packit Service |
e3b512 |
* transformation from user space to pattern space.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* When a pattern is first created it always has the identity matrix for its
|
|
Packit Service |
e3b512 |
* transformation matrix, which means that pattern space is initially
|
|
Packit Service |
e3b512 |
* identical to user space.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* Important: Please note that the direction of this transformation matrix is
|
|
Packit Service |
e3b512 |
* from user space to pattern space. This means that if you imagine the flow
|
|
Packit Service |
e3b512 |
* from a pattern to user space (and on to device space), then coordinates in
|
|
Packit Service |
e3b512 |
* that flow will be transformed by the inverse of the pattern matrix.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* For example, if you want to make a pattern appear twice as large as it
|
|
Packit Service |
e3b512 |
* does by default the correct code to use is:
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @code
|
|
Packit Service |
e3b512 |
* pattern->set_matrix(scaling_matrix(0.5, 0.5));
|
|
Packit Service |
e3b512 |
* @endcode
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* Meanwhile, using values of 2.0 rather than 0.5 in the code above
|
|
Packit Service |
e3b512 |
* would cause the pattern to appear at half of its default size.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* Also, please note the discussion of the user-space locking semantics of
|
|
Packit Service |
e3b512 |
* set_source().
|
|
Packit Service |
e3b512 |
**/
|
|
Packit Service |
e3b512 |
void set_matrix(const Matrix& matrix);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Returns the pattern's transformation matrix
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
void get_matrix(Matrix& matrix) const;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Returns the pattern's transformation matrix
|
|
Packit Service |
e3b512 |
* @since 1.8
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
Matrix get_matrix() const;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/* To keep 1.6.x ABI */
|
|
Packit Service |
e3b512 |
void set_matrix(const cairo_matrix_t& matrix);
|
|
Packit Service |
e3b512 |
void get_matrix(cairo_matrix_t& matrix) const;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Returns the type of the pattern
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @since 1.2
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
PatternType get_type() const;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Sets the mode to be used for drawing outside the area of a pattern. See
|
|
Packit Service |
e3b512 |
* Cairo::Extend for details on the semantics of each extend strategy.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* The default extend mode is Cairo::EXTEND_NONE for surface patterns and
|
|
Packit Service |
e3b512 |
* Cairo::EXTEND_PAD for gradient patterns.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @param Cairo::Extend describing how the area outsize of the pattern will
|
|
Packit Service |
e3b512 |
* be drawn
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @since 1.12
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
void set_extend(Extend extend);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Gets the current extend mode See Cairo::Extend for details on the
|
|
Packit Service |
e3b512 |
* semantics of each extend strategy.
|
|
Packit Service |
e3b512 |
* @since 1.12
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
Extend get_extend() const;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
typedef cairo_pattern_t cobject;
|
|
Packit Service |
e3b512 |
inline cobject* cobj() { return m_cobject; }
|
|
Packit Service |
e3b512 |
inline const cobject* cobj() const { return m_cobject; }
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
#ifndef DOXYGEN_IGNORE_THIS
|
|
Packit Service |
e3b512 |
///For use only by the cairomm implementation.
|
|
Packit Service |
e3b512 |
inline ErrorStatus get_status() const
|
|
Packit Service |
e3b512 |
{ return cairo_pattern_status(const_cast<cairo_pattern_t*>(cobj())); }
|
|
Packit Service |
e3b512 |
#endif //DOXYGEN_IGNORE_THIS
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
void reference() const;
|
|
Packit Service |
e3b512 |
void unreference() const;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
protected:
|
|
Packit Service |
e3b512 |
//Used by derived types only.
|
|
Packit Service |
e3b512 |
Pattern();
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
cobject* m_cobject;
|
|
Packit Service |
e3b512 |
};
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
class SolidPattern : public Pattern
|
|
Packit Service |
e3b512 |
{
|
|
Packit Service |
e3b512 |
protected:
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
public:
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/** Create a C++ wrapper for the C instance.
|
|
Packit Service |
e3b512 |
* @param cobject The C instance.
|
|
Packit Service |
e3b512 |
* @param has_reference Whether we already have a reference. Otherwise, the constructor will take an extra reference.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
explicit SolidPattern(cairo_pattern_t* cobject, bool has_reference = false);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Gets the solid color for a solid color pattern.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @param red return value for red component of color
|
|
Packit Service |
e3b512 |
* @param green return value for green component of color
|
|
Packit Service |
e3b512 |
* @param blue return value for blue component of color
|
|
Packit Service |
e3b512 |
* @param alpha return value for alpha component of color
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @since 1.4
|
|
Packit Service |
e3b512 |
**/
|
|
Packit Service |
e3b512 |
void get_rgba(double& red, double& green,
|
|
Packit Service |
e3b512 |
double& blue, double& alpha) const;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Creates a new Cairo::Pattern corresponding to an opaque color. The color
|
|
Packit Service |
e3b512 |
* components are floating point numbers in the range 0 to 1. If the values
|
|
Packit Service |
e3b512 |
* passed in are outside that range, they will be clamped.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @param red red component of the color
|
|
Packit Service |
e3b512 |
* @param green green component of the color
|
|
Packit Service |
e3b512 |
* @param blue blue component of the color
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
static RefPtr<SolidPattern> create_rgb(double red, double green, double blue);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Creates a new Cairo::Pattern corresponding to a translucent color. The color
|
|
Packit Service |
e3b512 |
* components are floating point numbers in the range 0 to 1. If the values
|
|
Packit Service |
e3b512 |
* passed in are outside that range, they will be clamped.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @param red red component of the color
|
|
Packit Service |
e3b512 |
* @param green green component of the color
|
|
Packit Service |
e3b512 |
* @param blue blue component of the color
|
|
Packit Service |
e3b512 |
* @param alpha alpha component of the color
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
static RefPtr<SolidPattern> create_rgba(double red, double green,
|
|
Packit Service |
e3b512 |
double blue, double alpha);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
//TODO?: SolidPattern(cairo_pattern_t *target);
|
|
Packit Service |
e3b512 |
virtual ~SolidPattern();
|
|
Packit Service |
e3b512 |
};
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
class SurfacePattern : public Pattern
|
|
Packit Service |
e3b512 |
{
|
|
Packit Service |
e3b512 |
protected:
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
explicit SurfacePattern(const RefPtr<Surface>& surface);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
//TODO?: SurfacePattern(cairo_pattern_t *target);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
public:
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/** Create a C++ wrapper for the C instance. This C++ instance should then be given to a RefPtr.
|
|
Packit Service |
e3b512 |
* @param cobject The C instance.
|
|
Packit Service |
e3b512 |
* @param has_reference Whether we already have a reference. Otherwise, the constructor will take an extra reference.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
explicit SurfacePattern(cairo_pattern_t* cobject, bool has_reference = false);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/// @{
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Gets the surface associated with this pattern
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @since 1.4
|
|
Packit Service |
e3b512 |
**/
|
|
Packit Service |
e3b512 |
RefPtr<const Surface> get_surface () const;
|
|
Packit Service |
e3b512 |
RefPtr<Surface> get_surface ();
|
|
Packit Service |
e3b512 |
/// @}
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
virtual ~SurfacePattern();
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Create a new Cairo::Pattern for the given surface.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
static RefPtr<SurfacePattern> create(const RefPtr<Surface>& surface);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
#ifndef CAIROMM_DISABLE_DEPRECATED
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* @deprecated Use Pattern::set_extend() instead.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
void set_extend(Extend extend);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
*@deprecated Use Pattern::set_extend() instead.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
Extend get_extend() const;
|
|
Packit Service |
e3b512 |
#endif //CAIROMM_DISABLE_DEPRECATED
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Sets the filter to be used for resizing when using this pattern.
|
|
Packit Service |
e3b512 |
* See Cairo::Filter for details on each filter.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* Note that you might want to control filtering even when you do not have an
|
|
Packit Service |
e3b512 |
* explicit Cairo::Pattern object, (for example when using
|
|
Packit Service |
e3b512 |
* Cairo::Context::set_source_surface()). In these cases, it is convenient to
|
|
Packit Service |
e3b512 |
* use Cairo::Context::get_source() to get access to the pattern that cairo
|
|
Packit Service |
e3b512 |
* creates implicitly.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @param filter Cairo::Filter describing the filter to use for resizing the
|
|
Packit Service |
e3b512 |
* pattern
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
void set_filter(Filter filter);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Gets the current filter for a pattern. See Cairo::Filter for details on
|
|
Packit Service |
e3b512 |
* each filter.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
Filter get_filter() const;
|
|
Packit Service |
e3b512 |
};
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
class Gradient : public Pattern
|
|
Packit Service |
e3b512 |
{
|
|
Packit Service |
e3b512 |
protected:
|
|
Packit Service |
e3b512 |
//Use derived constructors.
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
//TODO?: Gradient(cairo_pattern_t *target);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
public:
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/** Create a C++ wrapper for the C instance. This C++ instance should then be given to a RefPtr.
|
|
Packit Service |
e3b512 |
* @param cobject The C instance.
|
|
Packit Service |
e3b512 |
* @param has_reference Whether we already have a reference. Otherwise, the constructor will take an extra reference.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
explicit Gradient(cairo_pattern_t* cobject, bool has_reference = false);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
virtual ~Gradient();
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Adds an opaque color stop to a gradient pattern. The offset
|
|
Packit Service |
e3b512 |
* specifies the location along the gradient's control vector. For
|
|
Packit Service |
e3b512 |
* example, a linear gradient's control vector is from (x0,y0) to
|
|
Packit Service |
e3b512 |
* (x1,y1) while a radial gradient's control vector is from any point
|
|
Packit Service |
e3b512 |
* on the start circle to the corresponding point on the end circle.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* The color is specified in the same way as in Context::set_source_rgb().
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* If two (or more) stops are specified with identical offset values,
|
|
Packit Service |
e3b512 |
* they will be sorted according to the order in which the stops are
|
|
Packit Service |
e3b512 |
* added, (stops added earlier will compare less than stops added
|
|
Packit Service |
e3b512 |
* later). This can be useful for reliably making sharp color
|
|
Packit Service |
e3b512 |
* transitions instead of the typical blend.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @param offset an offset in the range [0.0 .. 1.0]
|
|
Packit Service |
e3b512 |
* @param red red component of color
|
|
Packit Service |
e3b512 |
* @param green green component of color
|
|
Packit Service |
e3b512 |
* @param blue blue component of color
|
|
Packit Service |
e3b512 |
**/
|
|
Packit Service |
e3b512 |
void add_color_stop_rgb(double offset, double red, double green, double blue);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Adds a translucent color stop to a gradient pattern. The offset
|
|
Packit Service |
e3b512 |
* specifies the location along the gradient's control vector. For
|
|
Packit Service |
e3b512 |
* example, a linear gradient's control vector is from (x0,y0) to
|
|
Packit Service |
e3b512 |
* (x1,y1) while a radial gradient's control vector is from any point
|
|
Packit Service |
e3b512 |
* on the start circle to the corresponding point on the end circle.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* The color is specified in the same way as in Context::set_source_rgba().
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* If two (or more) stops are specified with identical offset values,
|
|
Packit Service |
e3b512 |
* they will be sorted according to the order in which the stops are
|
|
Packit Service |
e3b512 |
* added, (stops added earlier will compare less than stops added
|
|
Packit Service |
e3b512 |
* later). This can be useful for reliably making sharp color
|
|
Packit Service |
e3b512 |
* transitions instead of the typical blend.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @param offset an offset in the range [0.0 .. 1.0]
|
|
Packit Service |
e3b512 |
* @param red red component of color
|
|
Packit Service |
e3b512 |
* @param green green component of color
|
|
Packit Service |
e3b512 |
* @param blue blue component of color
|
|
Packit Service |
e3b512 |
* @param alpha alpha component of color
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
void add_color_stop_rgba(double offset, double red, double green, double blue, double alpha);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Gets the color stops and offsets for this Gradient
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @since 1.4
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
std::vector<ColorStop> get_color_stops() const;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
protected:
|
|
Packit Service |
e3b512 |
Gradient();
|
|
Packit Service |
e3b512 |
};
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
class LinearGradient : public Gradient
|
|
Packit Service |
e3b512 |
{
|
|
Packit Service |
e3b512 |
protected:
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
LinearGradient(double x0, double y0, double x1, double y1);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
public:
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/** Create a C++ wrapper for the C instance. This C++ instance should then be given to a RefPtr.
|
|
Packit Service |
e3b512 |
* @param cobject The C instance.
|
|
Packit Service |
e3b512 |
* @param has_reference Whether we already have a reference. Otherwise, the constructor will take an extra reference.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
explicit LinearGradient(cairo_pattern_t* cobject, bool has_reference = false);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* @param x0 return value for the x coordinate of the first point
|
|
Packit Service |
e3b512 |
* @param y0 return value for the y coordinate of the first point
|
|
Packit Service |
e3b512 |
* @param x1 return value for the x coordinate of the second point
|
|
Packit Service |
e3b512 |
* @param y1 return value for the y coordinate of the second point
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* Gets the gradient endpoints for a linear gradient.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @since 1.4
|
|
Packit Service |
e3b512 |
**/
|
|
Packit Service |
e3b512 |
void get_linear_points(double &x0, double &y0,
|
|
Packit Service |
e3b512 |
double &x1, double &y1) const;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
//TODO?: LinearGradient(cairo_pattern_t *target);
|
|
Packit Service |
e3b512 |
virtual ~LinearGradient();
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Create a new linear gradient Cairo::Pattern along the line defined by (x0,
|
|
Packit Service |
e3b512 |
* y0) and (x1, y1). Before using the gradient pattern, a number of color
|
|
Packit Service |
e3b512 |
* stops should be defined using Cairo::Gradient::add_color_stop_rgb() or
|
|
Packit Service |
e3b512 |
* Cairo::Gradient::add_color_stop_rgba().
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* Note: The coordinates here are in pattern space. For a new pattern,
|
|
Packit Service |
e3b512 |
* pattern space is identical to user space, but the relationship between the
|
|
Packit Service |
e3b512 |
* spaces can be changed with Cairo::Pattern::set_matrix().
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @param x0 x coordinate of the start point
|
|
Packit Service |
e3b512 |
* @param y0 y coordinate of the start point
|
|
Packit Service |
e3b512 |
* @param x1 x coordinate of the end point
|
|
Packit Service |
e3b512 |
* @param y1 y coordinate of the end point
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
static RefPtr<LinearGradient> create(double x0, double y0, double x1, double y1);
|
|
Packit Service |
e3b512 |
};
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
class RadialGradient : public Gradient
|
|
Packit Service |
e3b512 |
{
|
|
Packit Service |
e3b512 |
protected:
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
RadialGradient(double cx0, double cy0, double radius0, double cx1, double cy1, double radius1);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
public:
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/** Create a C++ wrapper for the C instance. This C++ instance should then be given to a RefPtr.
|
|
Packit Service |
e3b512 |
* @param cobject The C instance.
|
|
Packit Service |
e3b512 |
* @param has_reference Whether we already have a reference. Otherwise, the constructor will take an extra reference.
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
explicit RadialGradient(cairo_pattern_t* cobject, bool has_reference = false);
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Gets the gradient endpoint circles for a radial gradient, each
|
|
Packit Service |
e3b512 |
* specified as a center coordinate and a radius.
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @param x0 return value for the x coordinate of the center of the first (inner) circle
|
|
Packit Service |
e3b512 |
* @param y0 return value for the y coordinate of the center of the first (inner) circle
|
|
Packit Service |
e3b512 |
* @param r0 return value for the radius of the first (inner) circle
|
|
Packit Service |
e3b512 |
* @param x1 return value for the x coordinate of the center of the second (outer) circle
|
|
Packit Service |
e3b512 |
* @param y1 return value for the y coordinate of the center of the second (outer) circle
|
|
Packit Service |
e3b512 |
* @param r1 return value for the radius of the second (outer) circle
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @since 1.4
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
void get_radial_circles(double& x0, double& y0, double& r0,
|
|
Packit Service |
e3b512 |
double& x1, double& y1, double& r1) const;
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
//TODO?: RadialGradient(cairo_pattern_t *target);
|
|
Packit Service |
e3b512 |
virtual ~RadialGradient();
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
/**
|
|
Packit Service |
e3b512 |
* Creates a new radial gradient #cairo_pattern_t between the two circles
|
|
Packit Service |
e3b512 |
* defined by (cx0, cy0, radius0) and (cx1, cy1, radius1). Before using the
|
|
Packit Service |
e3b512 |
* gradient pattern, a number of color stops should be defined using
|
|
Packit Service |
e3b512 |
* Cairo::Gradient::add_color_stop_rgb() or
|
|
Packit Service |
e3b512 |
* Cairo::Gradient::add_color_stop_rgba().
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @note The coordinates here are in pattern space. For a new pattern,
|
|
Packit Service |
e3b512 |
* pattern space is identical to user space, but the relationship between the
|
|
Packit Service |
e3b512 |
* spaces can be changed with Cairo::Pattern::set_matrix().
|
|
Packit Service |
e3b512 |
*
|
|
Packit Service |
e3b512 |
* @param cx0 x coordinate for the center of the start circle
|
|
Packit Service |
e3b512 |
* @param cy0 y coordinate for the center of the start circle
|
|
Packit Service |
e3b512 |
* @param radius0 radius of the start circle
|
|
Packit Service |
e3b512 |
* @param cx1 x coordinate for the center of the end circle
|
|
Packit Service |
e3b512 |
* @param cy1 y coordinate for the center of the end circle
|
|
Packit Service |
e3b512 |
* @param radius1 radius of the end circle
|
|
Packit Service |
e3b512 |
*/
|
|
Packit Service |
e3b512 |
static RefPtr<RadialGradient> create(double cx0, double cy0, double radius0, double cx1, double cy1, double radius1);
|
|
Packit Service |
e3b512 |
};
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
} // namespace Cairo
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
#endif //__CAIROMM_PATTERN_H
|
|
Packit Service |
e3b512 |
|
|
Packit Service |
e3b512 |
// vim: ts=2 sw=2 et
|