// This may look like C code, but it is really -*- C++ -*- // // Copyright Bob Friesenhahn, 1999, 2000, 2001, 2002, 2003 // Copyright Dirk Lemstra 2014-2017 // // Implementation of Drawable (Graphic objects) // #define MAGICKCORE_IMPLEMENTATION 1 #define MAGICK_PLUSPLUS_IMPLEMENTATION 1 #define MAGICK_DRAWABLE_IMPLEMENTATION #include "Magick++/Include.h" #include <math.h> #include <string> #include "Magick++/Drawable.h" #include "Magick++/Image.h" using namespace std; MagickPPExport int Magick::operator == (const Magick::Coordinate& left_, const Magick::Coordinate& right_) { return((left_.x() == right_.x()) && (left_.y() == right_.y())); } MagickPPExport int Magick::operator != (const Magick::Coordinate& left_, const Magick::Coordinate& right_) { return(!(left_ == right_)); } MagickPPExport int Magick::operator > (const Magick::Coordinate& left_, const Magick::Coordinate& right_) { return (!(left_ < right_) && (left_ != right_)); } MagickPPExport int Magick::operator < (const Magick::Coordinate& left_, const Magick::Coordinate& right_) { // Based on distance from origin return((sqrt(left_.x()*left_.x() + left_.y()*left_.y())) < (sqrt(right_.x()*right_.x() + right_.y()*right_.y()))); } MagickPPExport int Magick::operator >= (const Magick::Coordinate& left_, const Magick::Coordinate& right_) { return((left_ > right_) || (left_ == right_)); } MagickPPExport int Magick::operator <= (const Magick::Coordinate& left_, const Magick::Coordinate& right_) { return((left_ < right_) || (left_ == right_)); } /* DrawableBase */ Magick::DrawableBase::DrawableBase() { } Magick::DrawableBase::~DrawableBase(void) { } void Magick::DrawableBase::operator()(MagickCore::DrawingWand * context_) const { (void) context_; } Magick::DrawableBase* Magick::DrawableBase::copy() const { return new DrawableBase(*this); } /* Drawable */ Magick::Drawable::Drawable(void) : dp((Magick::DrawableBase *) NULL) { } Magick::Drawable::Drawable(const Magick::DrawableBase& original_) : dp(original_.copy()) { } Magick::Drawable::~Drawable(void) { delete dp; dp=(Magick::DrawableBase *) NULL; } Magick::Drawable::Drawable(const Magick::Drawable& original_) : dp((original_.dp != (Magick::DrawableBase *) NULL ? original_.dp->copy() : (Magick::DrawableBase *) NULL)) { } Magick::Drawable& Magick::Drawable::operator= ( const Magick::Drawable& original_) { DrawableBase *temp_dp; if (this != &original_) { temp_dp=(original_.dp != (Magick::DrawableBase *) NULL ? original_.dp->copy() : (Magick::DrawableBase *) NULL); delete dp; dp=temp_dp; } return(*this); } void Magick::Drawable::operator()(MagickCore::DrawingWand * context_) const { if (dp != (Magick::DrawableBase *) NULL) dp->operator()(context_); } /*virtual*/ Magick::VPathBase::~VPathBase ( void ) { } // Constructor Magick::VPath::VPath ( void ) : dp(0) { } // Construct from VPathBase Magick::VPath::VPath ( const Magick::VPathBase& original_ ) : dp(original_.copy()) { } // Destructor /* virtual */ Magick::VPath::~VPath ( void ) { delete dp; dp = 0; } // Copy constructor Magick::VPath::VPath ( const Magick::VPath& original_ ) : dp(original_.dp? original_.dp->copy(): 0) { } // Assignment operator Magick::VPath& Magick::VPath::operator= (const Magick::VPath& original_ ) { if (this != &original_) { VPathBase* temp_dp = (original_.dp ? original_.dp->copy() : 0); delete dp; dp = temp_dp; } return *this; } // Operator to invoke contained object void Magick::VPath::operator()( MagickCore::DrawingWand * context_ ) const { if(dp) dp->operator()( context_ ); } // // Drawable Objects // // Affine (scaling, rotation, and translation) Magick::DrawableAffine::DrawableAffine( double sx_, double sy_, double rx_, double ry_, double tx_, double ty_ ) { _affine.sx = sx_; _affine.rx = rx_; _affine.ry = ry_; _affine.sy = sy_; _affine.tx = tx_; _affine.ty = ty_; } Magick::DrawableAffine::DrawableAffine( void ) { GetAffineMatrix(&_affine); } Magick::DrawableAffine::~DrawableAffine( void ) { } void Magick::DrawableAffine::operator()( MagickCore::DrawingWand * context_ ) const { DrawAffine( context_, &_affine ); } Magick::DrawableBase* Magick::DrawableAffine::copy() const { return new DrawableAffine(*this); } Magick::DrawableAlpha::~DrawableAlpha(void) { } void Magick::DrawableAlpha::operator()(MagickCore::DrawingWand * context_) const { DrawAlpha(context_,_x,_y,_paintMethod); } Magick::DrawableBase* Magick::DrawableAlpha::copy() const { return new DrawableAlpha(*this); } // Arc Magick::DrawableArc::~DrawableArc( void ) { } void Magick::DrawableArc::operator()( MagickCore::DrawingWand * context_ ) const { DrawArc( context_, _startX, _startY, _endX, _endY, _startDegrees, _endDegrees ); } Magick::DrawableBase* Magick::DrawableArc::copy() const { return new DrawableArc(*this); } // // Bezier curve // // Construct from coordinates (Coordinate list must contain at least three members) Magick::DrawableBezier::DrawableBezier ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } // Copy constructor Magick::DrawableBezier::DrawableBezier( const Magick::DrawableBezier& original_ ) : DrawableBase (original_), _coordinates(original_._coordinates) { } // Destructor Magick::DrawableBezier::~DrawableBezier( void ) { } void Magick::DrawableBezier::operator()( MagickCore::DrawingWand * context_ ) const { size_t num_coords = (size_t) _coordinates.size(); PointInfo *coordinates = new PointInfo[num_coords]; PointInfo *q = coordinates; CoordinateList::const_iterator p = _coordinates.begin(); while( p != _coordinates.end() ) { q->x = p->x(); q->y = p->y(); q++; p++; } DrawBezier( context_, num_coords, coordinates ); delete [] coordinates; } Magick::DrawableBase* Magick::DrawableBezier::copy() const { return new DrawableBezier(*this); } /* DrawableBorderColor */ Magick::DrawableBorderColor::DrawableBorderColor(const Magick::Color &color_) : _color(color_) { } Magick::DrawableBorderColor::DrawableBorderColor (const Magick::DrawableBorderColor &original_) : DrawableBase(original_), _color(original_._color) { } Magick::DrawableBorderColor::~DrawableBorderColor(void) { } void Magick::DrawableBorderColor::operator()( MagickCore::DrawingWand *context_) const { PixelInfo color; PixelWand *pixel_wand; color=static_cast<PixelInfo>(_color); pixel_wand=NewPixelWand(); PixelSetPixelColor(pixel_wand,&color); DrawSetBorderColor(context_,pixel_wand); pixel_wand=DestroyPixelWand(pixel_wand); } void Magick::DrawableBorderColor::color(const Color &color_) { _color=color_; } Magick::Color Magick::DrawableBorderColor::color(void) const { return(_color); } Magick::DrawableBase* Magick::DrawableBorderColor::copy() const { return(new DrawableBorderColor(*this)); } /* DrawableClipRule */ Magick::DrawableClipRule::DrawableClipRule(const FillRule fillRule_) { _fillRule=fillRule_; } Magick::DrawableClipRule::~DrawableClipRule(void) { } void Magick::DrawableClipRule::operator()( MagickCore::DrawingWand * context_) const { DrawSetClipRule(context_,_fillRule); } void Magick::DrawableClipRule::fillRule(const FillRule fillRule_) { _fillRule=fillRule_; } Magick::FillRule Magick::DrawableClipRule::fillRule(void) const { return(_fillRule); } Magick::DrawableBase* Magick::DrawableClipRule::copy() const { return(new DrawableClipRule(*this)); } /* DrawableClipUnits */ Magick::DrawableClipUnits::DrawableClipUnits(const ClipPathUnits units_) { _units = units_; } Magick::DrawableClipUnits::~DrawableClipUnits(void) { } void Magick::DrawableClipUnits::operator()( MagickCore::DrawingWand * context_) const { DrawSetClipUnits(context_, _units); } void Magick::DrawableClipUnits::units(const ClipPathUnits units_) { _units = units_; } Magick::ClipPathUnits Magick::DrawableClipUnits::units(void) const { return(_units); } Magick::DrawableBase* Magick::DrawableClipUnits::copy() const { return(new DrawableClipUnits(*this)); } // //Clip Path // // Pop (terminate) Clip path definition Magick::DrawablePopClipPath::~DrawablePopClipPath ( void ) { } void Magick::DrawablePopClipPath::operator() ( MagickCore::DrawingWand * context_ ) const { DrawPopClipPath( context_ ); DrawPopDefs(context_); } Magick::DrawableBase* Magick::DrawablePopClipPath::copy() const { return new DrawablePopClipPath(*this); } // Push clip path definition Magick::DrawablePushClipPath::DrawablePushClipPath( const std::string &id_) : _id(id_.c_str()) //multithread safe const char* { } Magick::DrawablePushClipPath::DrawablePushClipPath ( const Magick::DrawablePushClipPath& original_ ) //multithread safe const char* : DrawableBase (original_), _id(original_._id.c_str()) { } Magick::DrawablePushClipPath::~DrawablePushClipPath( void ) { } void Magick::DrawablePushClipPath::operator() ( MagickCore::DrawingWand * context_ ) const { DrawPushDefs(context_); DrawPushClipPath( context_, _id.c_str()); } Magick::DrawableBase* Magick::DrawablePushClipPath::copy() const { return new DrawablePushClipPath(*this); } // // ClipPath // Magick::DrawableClipPath::DrawableClipPath( const std::string &id_ ) :_id(id_.c_str()) { } Magick::DrawableClipPath::DrawableClipPath ( const Magick::DrawableClipPath& original_ ) : DrawableBase (original_), _id(original_._id.c_str()) { } Magick::DrawableClipPath::~DrawableClipPath( void ) { } void Magick::DrawableClipPath::operator()( MagickCore::DrawingWand * context_ ) const { (void) DrawSetClipPath( context_, _id.c_str()); } Magick::DrawableBase* Magick::DrawableClipPath::copy() const { return new DrawableClipPath(*this); } // Circle Magick::DrawableCircle::~DrawableCircle ( void ) { } void Magick::DrawableCircle::operator()( MagickCore::DrawingWand * context_ ) const { DrawCircle( context_, _originX, _originY, _perimX, _perimY ); } Magick::DrawableBase* Magick::DrawableCircle::copy() const { return new DrawableCircle(*this); } // Colorize at point using PaintMethod Magick::DrawableColor::~DrawableColor( void ) { } void Magick::DrawableColor::operator()( MagickCore::DrawingWand * context_ ) const { DrawColor( context_, _x, _y, _paintMethod ); } Magick::DrawableBase* Magick::DrawableColor::copy() const { return new DrawableColor(*this); } // Draw image at point Magick::DrawableCompositeImage::DrawableCompositeImage ( double x_, double y_, double width_, double height_, const std::string &filename_, Magick::CompositeOperator composition_ ) : _composition(composition_), _x(x_), _y(y_), _width(width_), _height(height_), _image(new Image(filename_)) { } Magick::DrawableCompositeImage::DrawableCompositeImage ( double x_, double y_, double width_, double height_, const Magick::Image &image_, Magick::CompositeOperator composition_ ) : _composition(composition_), _x(x_), _y(y_), _width(width_), _height(height_), _image(new Image(image_)) { } Magick::DrawableCompositeImage::DrawableCompositeImage ( double x_, double y_, double width_, double height_, const std::string &filename_ ) :_composition(CopyCompositeOp), _x(x_), _y(y_), _width(width_), _height(height_), _image(new Image(filename_)) { } Magick::DrawableCompositeImage::DrawableCompositeImage ( double x_, double y_, double width_, double height_, const Magick::Image &image_ ) :_composition(CopyCompositeOp), _x(x_), _y(y_), _width(width_), _height(height_), _image(new Image(image_)) { } Magick::DrawableCompositeImage::DrawableCompositeImage ( double x_, double y_, const std::string &filename_ ) : _composition(CopyCompositeOp), _x(x_), _y(y_), _width(0), _height(0), _image(new Image(filename_)) { _width=_image->columns(); _height=_image->rows(); } Magick::DrawableCompositeImage::DrawableCompositeImage ( double x_, double y_, const Magick::Image &image_ ) : _composition(CopyCompositeOp), _x(x_), _y(y_), _width(0), _height(0), _image(new Image(image_)) { _width=_image->columns(); _height=_image->rows(); } // Copy constructor Magick::DrawableCompositeImage::DrawableCompositeImage ( const Magick::DrawableCompositeImage& original_ ) : Magick::DrawableBase(original_), _composition(original_._composition), _x(original_._x), _y(original_._y), _width(original_._width), _height(original_._height), _image(new Image(*original_._image)) { } Magick::DrawableCompositeImage::~DrawableCompositeImage( void ) { delete _image; } // Assignment operator Magick::DrawableCompositeImage& Magick::DrawableCompositeImage::operator= (const Magick::DrawableCompositeImage& original_ ) { // If not being set to ourself if ( this != &original_ ) { _composition = original_._composition; _x = original_._x; _y = original_._y; _width = original_._width; _height = original_._height; Image* temp_image = new Image(*original_._image); delete _image; _image = temp_image; } return *this; } void Magick::DrawableCompositeImage::filename( const std::string &filename_ ) { Image* temp_image = new Image(filename_); delete _image; _image = temp_image; } std::string Magick::DrawableCompositeImage::filename( void ) const { return _image->fileName(); } void Magick::DrawableCompositeImage::image( const Magick::Image &image_ ) { Image* temp_image = new Image(image_); delete _image; _image = temp_image; } Magick::Image Magick::DrawableCompositeImage::image( void ) const { return *_image; } // Specify image format used to output Base64 inlined image data. void Magick::DrawableCompositeImage::magick( std::string magick_ ) { _image->magick( magick_ ); } std::string Magick::DrawableCompositeImage::magick( void ) { return _image->magick(); } void Magick::DrawableCompositeImage::operator() ( MagickCore::DrawingWand * context_ ) const { MagickWand *magick_wand; magick_wand=NewMagickWandFromImage(_image->constImage()); (void) DrawComposite( context_, _composition, _x, _y, _width, _height, magick_wand ); magick_wand=DestroyMagickWand(magick_wand); } Magick::DrawableBase* Magick::DrawableCompositeImage::copy() const { return new DrawableCompositeImage(*this); } Magick::DrawableDensity::DrawableDensity(const Point &density_) : _density(density_) { } Magick::DrawableDensity::DrawableDensity(const std::string &density_) : _density(density_) { } Magick::DrawableDensity::~DrawableDensity(void) { } void Magick::DrawableDensity::operator()( MagickCore::DrawingWand *context_) const { DrawSetDensity(context_,_density.c_str()); } Magick::DrawableBase* Magick::DrawableDensity::copy() const { return(new DrawableDensity(*this)); } // Ellipse Magick::DrawableEllipse::~DrawableEllipse( void ) { } void Magick::DrawableEllipse::operator() ( MagickCore::DrawingWand * context_ ) const { DrawEllipse( context_, _originX, _originY, _radiusX, _radiusY, _arcStart, _arcEnd ); } Magick::DrawableBase* Magick::DrawableEllipse::copy() const { return new DrawableEllipse(*this); } // Specify drawing fill color Magick::DrawableFillColor::DrawableFillColor( const Magick::Color &color_ ) : _color(color_) { } Magick::DrawableFillColor::DrawableFillColor ( const Magick::DrawableFillColor& original_ ) : DrawableBase (original_), _color(original_._color) { } Magick::DrawableFillColor::~DrawableFillColor( void ) { } void Magick::DrawableFillColor::operator() ( MagickCore::DrawingWand * context_ ) const { PixelInfo color = static_cast<PixelInfo>(_color); PixelWand *pixel_wand=NewPixelWand(); PixelSetPixelColor(pixel_wand,&color); DrawSetFillColor(context_,pixel_wand); pixel_wand=DestroyPixelWand(pixel_wand); } Magick::DrawableBase* Magick::DrawableFillColor::copy() const { return new DrawableFillColor(*this); } /* DrawableFillPatternUrl */ Magick::DrawableFillPatternUrl::DrawableFillPatternUrl(const std::string &url_) : _url(url_) { } Magick::DrawableFillPatternUrl::DrawableFillPatternUrl( const Magick::DrawableFillPatternUrl& original_) : DrawableBase(original_), _url(original_._url) { } Magick::DrawableFillPatternUrl::~DrawableFillPatternUrl(void) { } void Magick::DrawableFillPatternUrl::operator()( MagickCore::DrawingWand * context_) const { DrawSetFillPatternURL(context_, _url.c_str()); } void Magick::DrawableFillPatternUrl::url(const std::string &url_) { _url = url_; } std::string Magick::DrawableFillPatternUrl::url(void) const { return(_url); } Magick::DrawableBase* Magick::DrawableFillPatternUrl::copy() const { return(new DrawableFillPatternUrl(*this)); } // Specify drawing fill fule Magick::DrawableFillRule::~DrawableFillRule ( void ) { } void Magick::DrawableFillRule::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetFillRule( context_, _fillRule ); } Magick::DrawableBase* Magick::DrawableFillRule::copy() const { return new DrawableFillRule(*this); } Magick::DrawableFillOpacity::~DrawableFillOpacity(void) { } void Magick::DrawableFillOpacity::operator() (MagickCore::DrawingWand *context_) const { DrawSetFillOpacity(context_,_opacity); } Magick::DrawableBase* Magick::DrawableFillOpacity::copy() const { return new DrawableFillOpacity(*this); } // Specify text font Magick::DrawableFont::DrawableFont ( const std::string &font_ ) : _font(font_), _family(), _style(Magick::AnyStyle), _weight(400), _stretch(Magick::NormalStretch) { } Magick::DrawableFont::DrawableFont ( const std::string &family_, Magick::StyleType style_, const unsigned int weight_, Magick::StretchType stretch_ ) : _font(), _family(family_), _style(style_), _weight(weight_), _stretch(stretch_) { } Magick::DrawableFont::DrawableFont ( const Magick::DrawableFont& original_ ) : DrawableBase (original_), _font(original_._font), _family(original_._family), _style(original_._style), _weight(original_._weight), _stretch(original_._stretch) { } Magick::DrawableFont::~DrawableFont ( void ) { } void Magick::DrawableFont::operator()( MagickCore::DrawingWand * context_ ) const { // font if(_font.length()) { (void) DrawSetFont( context_, _font.c_str() ); } if(_family.length()) { // font-family (void) DrawSetFontFamily( context_, _family.c_str() ); // font-style DrawSetFontStyle( context_, _style ); // font-weight DrawSetFontWeight( context_, _weight ); // font-stretch DrawSetFontStretch( context_, _stretch ); } } Magick::DrawableBase* Magick::DrawableFont::copy() const { return new DrawableFont(*this); } // Specify text positioning gravity Magick::DrawableGravity::~DrawableGravity ( void ) { } void Magick::DrawableGravity::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetGravity( context_, _gravity ); } Magick::DrawableBase* Magick::DrawableGravity::copy() const { return new DrawableGravity(*this); } // Line Magick::DrawableLine::~DrawableLine ( void ) { } void Magick::DrawableLine::operator()( MagickCore::DrawingWand * context_ ) const { DrawLine( context_, _startX, _startY, _endX, _endY ); } Magick::DrawableBase* Magick::DrawableLine::copy() const { return new DrawableLine(*this); } // Drawable Path Magick::DrawablePath::DrawablePath ( const VPathList &path_ ) : _path(path_) { } Magick::DrawablePath::DrawablePath ( const Magick::DrawablePath& original_ ) : DrawableBase (original_), _path(original_._path) { } Magick::DrawablePath::~DrawablePath ( void ) { } void Magick::DrawablePath::operator()( MagickCore::DrawingWand * context_ ) const { DrawPathStart( context_ ); for( VPathList::const_iterator p = _path.begin(); p != _path.end(); p++ ) p->operator()( context_ ); // FIXME, how to quit loop on error? DrawPathFinish( context_ ); } Magick::DrawableBase* Magick::DrawablePath::copy() const { return new DrawablePath(*this); } // Point Magick::DrawablePoint::~DrawablePoint ( void ) { } void Magick::DrawablePoint::operator()( MagickCore::DrawingWand * context_ ) const { DrawPoint( context_, _x, _y ); } Magick::DrawableBase* Magick::DrawablePoint::copy() const { return new DrawablePoint(*this); } // Text pointsize Magick::DrawablePointSize::~DrawablePointSize ( void ) { } void Magick::DrawablePointSize::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetFontSize( context_, _pointSize ); } Magick::DrawableBase* Magick::DrawablePointSize::copy() const { return new DrawablePointSize(*this); } // Polygon (Coordinate list must contain at least three members) Magick::DrawablePolygon::DrawablePolygon ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } Magick::DrawablePolygon::DrawablePolygon ( const Magick::DrawablePolygon& original_ ) : DrawableBase (original_), _coordinates(original_._coordinates) { } Magick::DrawablePolygon::~DrawablePolygon ( void ) { } void Magick::DrawablePolygon::operator() ( MagickCore::DrawingWand * context_ ) const { size_t num_coords = (size_t) _coordinates.size(); PointInfo *coordinates = new PointInfo[num_coords]; PointInfo *q = coordinates; CoordinateList::const_iterator p = _coordinates.begin(); while( p != _coordinates.end() ) { q->x = p->x(); q->y = p->y(); q++; p++; } DrawPolygon( context_, num_coords, coordinates ); delete [] coordinates; } Magick::DrawableBase* Magick::DrawablePolygon::copy() const { return new DrawablePolygon(*this); } // Polyline (Coordinate list must contain at least three members) Magick::DrawablePolyline::DrawablePolyline ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } Magick::DrawablePolyline::DrawablePolyline ( const Magick::DrawablePolyline& original_ ) : DrawableBase (original_), _coordinates(original_._coordinates) { } Magick::DrawablePolyline::~DrawablePolyline ( void ) { } void Magick::DrawablePolyline::operator() ( MagickCore::DrawingWand * context_ ) const { size_t num_coords = (size_t) _coordinates.size(); PointInfo *coordinates = new PointInfo[num_coords]; PointInfo *q = coordinates; CoordinateList::const_iterator p = _coordinates.begin(); while( p != _coordinates.end() ) { q->x = p->x(); q->y = p->y(); q++; p++; } DrawPolyline( context_, num_coords, coordinates ); delete [] coordinates; } Magick::DrawableBase* Magick::DrawablePolyline::copy() const { return new DrawablePolyline(*this); } // Pop Graphic Context Magick::DrawablePopGraphicContext::~DrawablePopGraphicContext ( void ) { } void Magick::DrawablePopGraphicContext::operator() ( MagickCore::DrawingWand * context_ ) const { PopDrawingWand( context_ ); } Magick::DrawableBase* Magick::DrawablePopGraphicContext::copy() const { return new DrawablePopGraphicContext(*this); } // Push Graphic Context Magick::DrawablePushGraphicContext::~DrawablePushGraphicContext ( void ) { } void Magick::DrawablePushGraphicContext::operator() ( MagickCore::DrawingWand * context_ ) const { PushDrawingWand( context_ ); } Magick::DrawableBase* Magick::DrawablePushGraphicContext::copy() const { return new DrawablePushGraphicContext(*this); } // Pop (terminate) Pattern definition Magick::DrawablePopPattern::~DrawablePopPattern ( void ) { } void Magick::DrawablePopPattern::operator() ( MagickCore::DrawingWand * context_ ) const { (void) DrawPopPattern( context_ ); } Magick::DrawableBase* Magick::DrawablePopPattern::copy() const { return new DrawablePopPattern(*this); } // Push Pattern definition Magick::DrawablePushPattern::DrawablePushPattern ( const std::string &id_, ssize_t x_, ssize_t y_, size_t width_, size_t height_ ) : _id(id_), _x(x_), _y(y_), _width(width_), _height(height_) { } Magick::DrawablePushPattern::DrawablePushPattern ( const Magick::DrawablePushPattern& original_ ) : DrawableBase (original_), _id(original_._id), _x(original_._x), _y(original_._y), _width(original_._width), _height(original_._height) { } Magick::DrawablePushPattern::~DrawablePushPattern ( void ) { } void Magick::DrawablePushPattern::operator() ( MagickCore::DrawingWand * context_ ) const { (void) DrawPushPattern( context_, _id.c_str(), _x, _y, _width, _height ); } Magick::DrawableBase* Magick::DrawablePushPattern::copy() const { return new DrawablePushPattern(*this); } // Rectangle Magick::DrawableRectangle::~DrawableRectangle ( void ) { } void Magick::DrawableRectangle::operator() ( MagickCore::DrawingWand * context_ ) const { DrawRectangle( context_, _upperLeftX, _upperLeftY, _lowerRightX, _lowerRightY ); } Magick::DrawableBase* Magick::DrawableRectangle::copy() const { return new DrawableRectangle(*this); } // Apply Rotation Magick::DrawableRotation::~DrawableRotation ( void ) { } void Magick::DrawableRotation::operator() ( MagickCore::DrawingWand * context_ ) const { DrawRotate( context_, _angle ); } Magick::DrawableBase* Magick::DrawableRotation::copy() const { return new DrawableRotation(*this); } // Round Rectangle Magick::DrawableRoundRectangle::~DrawableRoundRectangle ( void ) { } void Magick::DrawableRoundRectangle::operator() ( MagickCore::DrawingWand * context_ ) const { DrawRoundRectangle(context_,_upperLeftX,_upperLeftY,_lowerRightX, _lowerRightY,_cornerWidth, _cornerHeight); } Magick::DrawableBase* Magick::DrawableRoundRectangle::copy() const { return new DrawableRoundRectangle(*this); } // Apply Scaling Magick::DrawableScaling::~DrawableScaling ( void ) { } void Magick::DrawableScaling::operator() ( MagickCore::DrawingWand * context_ ) const { DrawScale( context_, _x, _y ); } Magick::DrawableBase* Magick::DrawableScaling::copy() const { return new DrawableScaling(*this); } // Apply Skew in the X direction Magick::DrawableSkewX::~DrawableSkewX ( void ) { } void Magick::DrawableSkewX::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSkewX( context_, _angle ); } Magick::DrawableBase* Magick::DrawableSkewX::copy() const { return new DrawableSkewX(*this); } // Apply Skew in the Y direction Magick::DrawableSkewY::~DrawableSkewY ( void ) { } void Magick::DrawableSkewY::operator()( MagickCore::DrawingWand * context_ ) const { DrawSkewY( context_, _angle ); } Magick::DrawableBase* Magick::DrawableSkewY::copy() const { return new DrawableSkewY(*this); } /* DrawableStrokeDashArray */ Magick::DrawableStrokeDashArray::DrawableStrokeDashArray(const double* dasharray_) : _size(0), _dasharray(0) { dasharray(dasharray_); } Magick::DrawableStrokeDashArray::DrawableStrokeDashArray( const Magick::DrawableStrokeDashArray& original_) : DrawableBase (original_), _size(original_._size), _dasharray(new double[_size+1]) { // Copy elements { for (size_t i=0; i < _size; i++) _dasharray[i]=original_._dasharray[i]; _dasharray[_size]=0.0; } } Magick::DrawableStrokeDashArray::~DrawableStrokeDashArray(void) { delete [] _dasharray; _size=0; _dasharray=(double *) NULL; } Magick::DrawableStrokeDashArray& Magick::DrawableStrokeDashArray::operator=( const Magick::DrawableStrokeDashArray &original_) { if (this != &original_) { delete [] _dasharray; _size=original_._size; _dasharray = new double[_size+1]; // Copy elements { for (size_t i=0; i < _size; i++) _dasharray[i]=original_._dasharray[i]; _dasharray[_size]=0.0; } } return(*this); } void Magick::DrawableStrokeDashArray::operator()( MagickCore::DrawingWand *context_) const { (void) DrawSetStrokeDashArray(context_,(const unsigned long) _size, _dasharray); } Magick::DrawableBase *Magick::DrawableStrokeDashArray::copy() const { return(new DrawableStrokeDashArray(*this)); } void Magick::DrawableStrokeDashArray::dasharray(const double* dasharray_) { size_t n; delete [] _dasharray; _size=0; _dasharray=0; if (dasharray_ != (const double *) NULL) { const double *p; // Count elements in dash array n=0; { p = dasharray_; while(*p++ != 0.0) n++; } _size=n; // Allocate elements _dasharray=new double[_size+1]; // Copy elements { for (size_t i=0; i < _size; i++) _dasharray[i]=dasharray_[i]; _dasharray[_size]=0.0; } } } const double* Magick::DrawableStrokeDashArray::dasharray(void) const { return(_dasharray); } /* DrawableStrokeDashOffset */ Magick::DrawableStrokeDashOffset::~DrawableStrokeDashOffset(void) { } void Magick::DrawableStrokeDashOffset::operator() ( MagickCore::DrawingWand * context_) const { DrawSetStrokeDashOffset(context_,_offset); } Magick::DrawableBase* Magick::DrawableStrokeDashOffset::copy() const { return(new DrawableStrokeDashOffset(*this)); } void Magick::DrawableStrokeDashOffset::offset(const double offset_) { _offset=offset_; } double Magick::DrawableStrokeDashOffset::offset(void) const { return(_offset); } // Stroke linecap Magick::DrawableStrokeLineCap::~DrawableStrokeLineCap ( void ) { } void Magick::DrawableStrokeLineCap::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetStrokeLineCap( context_, _linecap ); } Magick::DrawableBase* Magick::DrawableStrokeLineCap::copy() const { return new DrawableStrokeLineCap(*this); } // Stroke linejoin Magick::DrawableStrokeLineJoin::~DrawableStrokeLineJoin ( void ) { } void Magick::DrawableStrokeLineJoin::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetStrokeLineJoin( context_, _linejoin ); } Magick::DrawableBase* Magick::DrawableStrokeLineJoin::copy() const { return new DrawableStrokeLineJoin(*this); } // Stroke miterlimit Magick::DrawableMiterLimit::~DrawableMiterLimit ( void ) { } void Magick::DrawableMiterLimit::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetStrokeMiterLimit( context_, _miterlimit ); } Magick::DrawableBase* Magick::DrawableMiterLimit::copy() const { return new DrawableMiterLimit(*this); } /* DrawableStrokePatternUrl */ Magick::DrawableStrokePatternUrl::DrawableStrokePatternUrl( const std::string &url_) : _url(url_) { } Magick::DrawableStrokePatternUrl::DrawableStrokePatternUrl( const Magick::DrawableStrokePatternUrl& original_) : DrawableBase(original_), _url(original_._url) { } Magick::DrawableStrokePatternUrl::~DrawableStrokePatternUrl(void) { } void Magick::DrawableStrokePatternUrl::operator()( MagickCore::DrawingWand * context_) const { DrawSetStrokePatternURL(context_, _url.c_str()); } void Magick::DrawableStrokePatternUrl::url(const std::string &url_) { _url = url_; } std::string Magick::DrawableStrokePatternUrl::url(void) const { return(_url); } Magick::DrawableBase* Magick::DrawableStrokePatternUrl::copy() const { return(new DrawableStrokePatternUrl(*this)); } // Stroke antialias Magick::DrawableStrokeAntialias::~DrawableStrokeAntialias ( void ) { } void Magick::DrawableStrokeAntialias::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetStrokeAntialias( context_, static_cast<MagickBooleanType> (_flag ? MagickTrue : MagickFalse) ); } Magick::DrawableBase* Magick::DrawableStrokeAntialias::copy() const { return new DrawableStrokeAntialias(*this); } // Stroke color Magick::DrawableStrokeColor::DrawableStrokeColor ( const Magick::Color &color_ ) : _color(color_) { } Magick::DrawableStrokeColor::DrawableStrokeColor ( const Magick::DrawableStrokeColor& original_ ) : DrawableBase (original_), _color(original_._color) { } Magick::DrawableStrokeColor::~DrawableStrokeColor ( void ) { } void Magick::DrawableStrokeColor::operator() ( MagickCore::DrawingWand * context_ ) const { PixelInfo color = static_cast<PixelInfo>(_color); PixelWand *pixel_wand=NewPixelWand(); PixelSetPixelColor(pixel_wand,&color); DrawSetStrokeColor(context_,pixel_wand); pixel_wand=DestroyPixelWand(pixel_wand); } Magick::DrawableBase* Magick::DrawableStrokeColor::copy() const { return new DrawableStrokeColor(*this); } Magick::DrawableStrokeOpacity::~DrawableStrokeOpacity(void) { } void Magick::DrawableStrokeOpacity::operator() (MagickCore::DrawingWand * context_) const { DrawSetStrokeOpacity(context_,_opacity); } Magick::DrawableBase* Magick::DrawableStrokeOpacity::copy() const { return new DrawableStrokeOpacity(*this); } // Stroke width Magick::DrawableStrokeWidth::~DrawableStrokeWidth ( void ) { } void Magick::DrawableStrokeWidth::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetStrokeWidth( context_, _width ); } Magick::DrawableBase* Magick::DrawableStrokeWidth::copy() const { return new DrawableStrokeWidth(*this); } // Draw text at point Magick::DrawableText::DrawableText ( const double x_, const double y_, const std::string &text_ ) : _x(x_), _y(y_), _text(text_), _encoding() { } Magick::DrawableText::DrawableText ( const double x_, const double y_, const std::string &text_, const std::string &encoding_) : _x(x_), _y(y_), _text(text_), _encoding(encoding_) { } Magick::DrawableText::DrawableText( const Magick::DrawableText& original_ ) : DrawableBase (original_), _x(original_._x), _y(original_._y), _text(original_._text), _encoding(original_._encoding) { } Magick::DrawableText::~DrawableText ( void ) { } void Magick::DrawableText::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetTextEncoding( context_, _encoding.c_str() ); DrawAnnotation( context_, _x, _y, reinterpret_cast<const unsigned char*>(_text.c_str()) ); } Magick::DrawableBase* Magick::DrawableText::copy() const { return new DrawableText(*this); } /* DrawableTextAlignment */ Magick::DrawableTextAlignment::DrawableTextAlignment( Magick::AlignType alignment_) : _alignment(alignment_) { } Magick::DrawableTextAlignment::DrawableTextAlignment (const Magick::DrawableTextAlignment &original_) : DrawableBase(original_), _alignment(original_._alignment) { } Magick::DrawableTextAlignment::~DrawableTextAlignment(void) { } void Magick::DrawableTextAlignment::operator()( MagickCore::DrawingWand * context_) const { DrawSetTextAlignment(context_, _alignment); } void Magick::DrawableTextAlignment::alignment(AlignType alignment_) { _alignment=alignment_; } Magick::AlignType Magick::DrawableTextAlignment::alignment(void) const { return(_alignment); } Magick::DrawableBase* Magick::DrawableTextAlignment::copy() const { return new DrawableTextAlignment(*this); } // Text antialias Magick::DrawableTextAntialias::DrawableTextAntialias ( bool flag_ ) : _flag(flag_) { } Magick::DrawableTextAntialias::DrawableTextAntialias( const Magick::DrawableTextAntialias &original_ ) : DrawableBase (original_), _flag(original_._flag) { } Magick::DrawableTextAntialias::~DrawableTextAntialias ( void ) { } void Magick::DrawableTextAntialias::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetTextAntialias( context_, static_cast<MagickBooleanType> (_flag ? MagickTrue : MagickFalse) ); } Magick::DrawableBase* Magick::DrawableTextAntialias::copy() const { return new DrawableTextAntialias(*this); } // Decoration (text decoration) Magick::DrawableTextDecoration::DrawableTextDecoration ( Magick::DecorationType decoration_ ) : _decoration(decoration_) { } Magick::DrawableTextDecoration::DrawableTextDecoration ( const Magick::DrawableTextDecoration &original_ ) : DrawableBase (original_), _decoration(original_._decoration) { } Magick::DrawableTextDecoration::~DrawableTextDecoration( void ) { } void Magick::DrawableTextDecoration::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetTextDecoration( context_, _decoration ); } Magick::DrawableBase* Magick::DrawableTextDecoration::copy() const { return new DrawableTextDecoration(*this); } // DrawableTextDirection Magick::DrawableTextDirection::DrawableTextDirection( DirectionType direction_) : _direction(direction_) { } Magick::DrawableTextDirection::~DrawableTextDirection(void) { } void Magick::DrawableTextDirection::operator()( MagickCore::DrawingWand *context_) const { DrawSetTextDirection(context_,_direction); } void Magick::DrawableTextDirection::direction(DirectionType direction_) { _direction=direction_; } Magick::DirectionType Magick::DrawableTextDirection::direction(void) const { return(_direction); } Magick::DrawableBase *Magick::DrawableTextDirection::copy() const { return new DrawableTextDirection(*this); } // DrawableTextInterlineSpacing Magick::DrawableTextInterlineSpacing::DrawableTextInterlineSpacing( double spacing_) : _spacing(spacing_) { } Magick::DrawableTextInterlineSpacing::~DrawableTextInterlineSpacing(void) { } void Magick::DrawableTextInterlineSpacing::operator()( MagickCore::DrawingWand *context_) const { DrawSetTextInterlineSpacing(context_,_spacing); } void Magick::DrawableTextInterlineSpacing::spacing(double spacing_) { _spacing=spacing_; } double Magick::DrawableTextInterlineSpacing::spacing(void) const { return(_spacing); } Magick::DrawableBase *Magick::DrawableTextInterlineSpacing::copy() const { return new DrawableTextInterlineSpacing(*this); } // DrawableTextInterwordSpacing Magick::DrawableTextInterwordSpacing::DrawableTextInterwordSpacing( double spacing_) : _spacing(spacing_) { } Magick::DrawableTextInterwordSpacing::~DrawableTextInterwordSpacing(void) { } void Magick::DrawableTextInterwordSpacing::operator()( MagickCore::DrawingWand *context_) const { DrawSetTextInterwordSpacing(context_,_spacing); } void Magick::DrawableTextInterwordSpacing::spacing(double spacing_) { _spacing=spacing_; } double Magick::DrawableTextInterwordSpacing::spacing(void) const { return(_spacing); } Magick::DrawableBase *Magick::DrawableTextInterwordSpacing::copy() const { return new DrawableTextInterwordSpacing(*this); } // DrawableTextKerning Magick::DrawableTextKerning::DrawableTextKerning( double kerning_) : _kerning(kerning_) { } Magick::DrawableTextKerning::~DrawableTextKerning(void) { } void Magick::DrawableTextKerning::operator()( MagickCore::DrawingWand *context_) const { DrawSetTextKerning(context_,_kerning); } void Magick::DrawableTextKerning::kerning(double kerning_) { _kerning=kerning_; } double Magick::DrawableTextKerning::kerning(void) const { return(_kerning); } Magick::DrawableBase *Magick::DrawableTextKerning::copy() const { return new DrawableTextKerning(*this); } // Set text undercolor Magick::DrawableTextUnderColor::DrawableTextUnderColor ( const Magick::Color &color_ ) : _color(color_) { } Magick::DrawableTextUnderColor::DrawableTextUnderColor ( const Magick::DrawableTextUnderColor& original_ ) : DrawableBase (original_), _color(original_._color) { } Magick::DrawableTextUnderColor::~DrawableTextUnderColor ( void ) { } void Magick::DrawableTextUnderColor::operator() ( MagickCore::DrawingWand * context_ ) const { PixelInfo color = static_cast<PixelInfo>(_color); PixelWand *pixel_wand=NewPixelWand(); PixelSetPixelColor(pixel_wand,&color); DrawSetTextUnderColor(context_,pixel_wand); pixel_wand=DestroyPixelWand(pixel_wand); } Magick::DrawableBase* Magick::DrawableTextUnderColor::copy() const { return new DrawableTextUnderColor(*this); } // Apply Translation Magick::DrawableTranslation::~DrawableTranslation ( void ) { } void Magick::DrawableTranslation::operator() ( MagickCore::DrawingWand * context_ ) const { DrawTranslate( context_, _x, _y ); } Magick::DrawableBase* Magick::DrawableTranslation::copy() const { return new DrawableTranslation(*this); } // Set the size of the viewbox Magick::DrawableViewbox::~DrawableViewbox ( void ) { } void Magick::DrawableViewbox::operator() ( MagickCore::DrawingWand * context_ ) const { DrawSetViewbox( context_, _x1, _y1, _x2, _y2 ); } Magick::DrawableBase* Magick::DrawableViewbox::copy() const { return new DrawableViewbox(*this); } // // Path Classes // // // PathArcArgs // MagickPPExport int Magick::operator == ( const Magick::PathArcArgs& /*left_*/, const Magick::PathArcArgs& /*right_*/ ) { return ( 1 ); } MagickPPExport int Magick::operator != ( const Magick::PathArcArgs& /*left_*/, const Magick::PathArcArgs& /*right_*/ ) { return ( 0 ); } MagickPPExport int Magick::operator > ( const Magick::PathArcArgs& /*left_*/, const Magick::PathArcArgs& /*right_*/ ) { return ( 0 ); } MagickPPExport int Magick::operator < ( const Magick::PathArcArgs& /*left_*/, const Magick::PathArcArgs& /*right_*/ ) { return ( false ); } MagickPPExport int Magick::operator >= ( const Magick::PathArcArgs& left_, const Magick::PathArcArgs& right_ ) { return ( ( left_ > right_ ) || ( left_ == right_ ) ); } MagickPPExport int Magick::operator <= ( const Magick::PathArcArgs& left_, const Magick::PathArcArgs& right_ ) { return ( ( left_ < right_ ) || ( left_ == right_ ) ); } // Default constructor Magick::PathArcArgs::PathArcArgs( void ) : _radiusX(0), _radiusY(0), _xAxisRotation(0), _largeArcFlag(false), _sweepFlag(false), _x(0), _y(0) { } // Normal constructor Magick::PathArcArgs::PathArcArgs( double radiusX_, double radiusY_, double xAxisRotation_, bool largeArcFlag_, bool sweepFlag_, double x_, double y_ ) : _radiusX(radiusX_), _radiusY(radiusY_), _xAxisRotation(xAxisRotation_), _largeArcFlag(largeArcFlag_), _sweepFlag(sweepFlag_), _x(x_), _y(y_) { } // Copy constructor Magick::PathArcArgs::PathArcArgs( const Magick::PathArcArgs &original_ ) : _radiusX(original_._radiusX), _radiusY(original_._radiusY), _xAxisRotation(original_._xAxisRotation), _largeArcFlag(original_._largeArcFlag), _sweepFlag(original_._sweepFlag), _x(original_._x), _y(original_._y) { } // Destructor Magick::PathArcArgs::~PathArcArgs ( void ) { } // Path Arc Magick::PathArcAbs::PathArcAbs ( const Magick::PathArcArgs &coordinates_ ) : _coordinates(1,coordinates_) { } Magick::PathArcAbs::PathArcAbs ( const PathArcArgsList &coordinates_ ) : _coordinates(coordinates_) { } Magick::PathArcAbs::PathArcAbs ( const Magick::PathArcAbs& original_ ) : VPathBase (original_), _coordinates(original_._coordinates) { } Magick::PathArcAbs::~PathArcAbs ( void ) { } void Magick::PathArcAbs::operator()( MagickCore::DrawingWand * context_ ) const { for( PathArcArgsList::const_iterator p = _coordinates.begin(); p != _coordinates.end(); p++ ) { DrawPathEllipticArcAbsolute( context_, p->radiusX(), p->radiusY(), p->xAxisRotation(), (MagickBooleanType) p->largeArcFlag(), (MagickBooleanType) p->sweepFlag(), p->x(), p->y() ); } } Magick::VPathBase* Magick::PathArcAbs::copy() const { return new PathArcAbs(*this); } Magick::PathArcRel::PathArcRel ( const Magick::PathArcArgs &coordinates_ ) : _coordinates(1,coordinates_) { } Magick::PathArcRel::PathArcRel ( const PathArcArgsList &coordinates_ ) : _coordinates(coordinates_) { } Magick::PathArcRel::PathArcRel ( const Magick::PathArcRel& original_ ) : VPathBase (original_), _coordinates(original_._coordinates) { } Magick::PathArcRel::~PathArcRel ( void ) { } void Magick::PathArcRel::operator()( MagickCore::DrawingWand * context_ ) const { for( PathArcArgsList::const_iterator p = _coordinates.begin(); p != _coordinates.end(); p++ ) { DrawPathEllipticArcRelative( context_, p->radiusX(), p->radiusY(), p->xAxisRotation(), (MagickBooleanType) p->largeArcFlag(), (MagickBooleanType) p->sweepFlag(), p->x(), p->y() ); } } Magick::VPathBase* Magick::PathArcRel::copy() const { return new PathArcRel(*this); } // // Path Closepath // Magick::PathClosePath::~PathClosePath ( void ) { } void Magick::PathClosePath::operator()( MagickCore::DrawingWand * context_ ) const { DrawPathClose( context_ ); } Magick::VPathBase* Magick::PathClosePath::copy() const { return new PathClosePath(*this); } // // Path Curveto (Cubic Bezier) // MagickPPExport int Magick::operator == ( const Magick::PathCurvetoArgs& /*left_*/, const Magick::PathCurvetoArgs& /*right_*/ ) { return ( 1 ); } MagickPPExport int Magick::operator != ( const Magick::PathCurvetoArgs& /*left_*/, const Magick::PathCurvetoArgs& /*right_*/ ) { return ( 0 ); } MagickPPExport int Magick::operator > ( const Magick::PathCurvetoArgs& /*left_*/, const Magick::PathCurvetoArgs& /*right_*/ ) { return ( 0 ); } MagickPPExport int Magick::operator < ( const Magick::PathCurvetoArgs& /*left_*/, const Magick::PathCurvetoArgs& /*right_*/ ) { return ( false ); } MagickPPExport int Magick::operator >= ( const Magick::PathCurvetoArgs& left_, const Magick::PathCurvetoArgs& right_ ) { return ( ( left_ > right_ ) || ( left_ == right_ ) ); } MagickPPExport int Magick::operator <= ( const Magick::PathCurvetoArgs& left_, const Magick::PathCurvetoArgs& right_ ) { return ( ( left_ < right_ ) || ( left_ == right_ ) ); } // Default constructor Magick::PathCurvetoArgs::PathCurvetoArgs( void ) : _x1(0), _y1(0), _x2(0), _y2(0), _x(0), _y(0) { } // Normal constructor Magick::PathCurvetoArgs::PathCurvetoArgs( double x1_, double y1_, double x2_, double y2_, double x_, double y_ ) : _x1(x1_), _y1(y1_), _x2(x2_), _y2(y2_), _x(x_), _y(y_) { } // Copy constructor Magick::PathCurvetoArgs::PathCurvetoArgs( const PathCurvetoArgs &original_ ) : _x1(original_._x1), _y1(original_._y1), _x2(original_._x2), _y2(original_._y2), _x(original_._x), _y(original_._y) { } // Destructor Magick::PathCurvetoArgs::~PathCurvetoArgs ( void ) { } Magick::PathCurvetoAbs::PathCurvetoAbs ( const Magick::PathCurvetoArgs &args_ ) : _args(1,args_) { } Magick::PathCurvetoAbs::PathCurvetoAbs ( const PathCurveToArgsList &args_ ) : _args(args_) { } Magick::PathCurvetoAbs::PathCurvetoAbs ( const Magick::PathCurvetoAbs& original_ ) : VPathBase (original_), _args(original_._args) { } Magick::PathCurvetoAbs::~PathCurvetoAbs ( void ) { } void Magick::PathCurvetoAbs::operator() ( MagickCore::DrawingWand * context_ ) const { for( PathCurveToArgsList::const_iterator p = _args.begin(); p != _args.end(); p++ ) { DrawPathCurveToAbsolute( context_, p->x1(), p->y1(), p->x2(), p->y2(), p->x(), p->y() ); } } Magick::VPathBase* Magick::PathCurvetoAbs::copy() const { return new PathCurvetoAbs(*this); } Magick::PathCurvetoRel::PathCurvetoRel ( const Magick::PathCurvetoArgs &args_ ) : _args(1,args_) { } Magick::PathCurvetoRel::PathCurvetoRel ( const PathCurveToArgsList &args_ ) : _args(args_) { } Magick::PathCurvetoRel::PathCurvetoRel ( const Magick::PathCurvetoRel& original_ ) : VPathBase (original_), _args(original_._args) { } Magick::PathCurvetoRel::~PathCurvetoRel ( void ) { } void Magick::PathCurvetoRel::operator() ( MagickCore::DrawingWand * context_ ) const { for( PathCurveToArgsList::const_iterator p = _args.begin(); p != _args.end(); p++ ) { DrawPathCurveToRelative( context_, p->x1(), p->y1(), p->x2(), p->y2(), p->x(), p->y() ); } } Magick::VPathBase* Magick::PathCurvetoRel::copy() const { return new PathCurvetoRel(*this); } Magick::PathSmoothCurvetoAbs::PathSmoothCurvetoAbs ( const Magick::Coordinate &coordinates_ ) : _coordinates(1,coordinates_) { } Magick::PathSmoothCurvetoAbs::PathSmoothCurvetoAbs ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } Magick::PathSmoothCurvetoAbs::PathSmoothCurvetoAbs ( const Magick::PathSmoothCurvetoAbs& original_ ) : VPathBase (original_), _coordinates(original_._coordinates) { } Magick::PathSmoothCurvetoAbs::~PathSmoothCurvetoAbs ( void ) { } void Magick::PathSmoothCurvetoAbs::operator() ( MagickCore::DrawingWand * context_ ) const { for( CoordinateList::const_iterator p = _coordinates.begin(); p != _coordinates.end(); p++ ) { double x2 = p->x(); double y2 = p->y(); p++; if (p == _coordinates.end() ) break; DrawPathCurveToSmoothAbsolute( context_, x2, y2, p->x(), p->y() ); } } Magick::VPathBase* Magick::PathSmoothCurvetoAbs::copy() const { return new PathSmoothCurvetoAbs(*this); } Magick::PathSmoothCurvetoRel::PathSmoothCurvetoRel ( const Magick::Coordinate &coordinates_ ) : _coordinates(1,coordinates_) { } Magick::PathSmoothCurvetoRel::PathSmoothCurvetoRel ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } Magick::PathSmoothCurvetoRel::PathSmoothCurvetoRel ( const Magick::PathSmoothCurvetoRel& original_ ) : VPathBase (original_), _coordinates(original_._coordinates) { } Magick::PathSmoothCurvetoRel::~PathSmoothCurvetoRel ( void ) { } void Magick::PathSmoothCurvetoRel::operator() ( MagickCore::DrawingWand * context_ ) const { for( CoordinateList::const_iterator p = _coordinates.begin(); p != _coordinates.end(); p++ ) { double x2 = p->x(); double y2 = p->y(); p++; if (p == _coordinates.end() ) break; DrawPathCurveToSmoothRelative( context_, x2, y2, p->x(), p->y() ); } } Magick::VPathBase* Magick::PathSmoothCurvetoRel::copy() const { return new PathSmoothCurvetoRel(*this); } // // Quadratic Curveto (Quadratic Bezier) // MagickPPExport int Magick::operator == ( const Magick::PathQuadraticCurvetoArgs& /*left_*/, const Magick::PathQuadraticCurvetoArgs& /*right_*/ ) { return ( 1 ); } MagickPPExport int Magick::operator != ( const Magick::PathQuadraticCurvetoArgs& /*left_*/, const Magick::PathQuadraticCurvetoArgs& /*right_*/ ) { return ( 0 ); } MagickPPExport int Magick::operator > ( const Magick::PathQuadraticCurvetoArgs& /*left_*/, const Magick::PathQuadraticCurvetoArgs& /*right_*/ ) { return ( 0 ); } MagickPPExport int Magick::operator < ( const Magick::PathQuadraticCurvetoArgs& /*left_*/, const Magick::PathQuadraticCurvetoArgs& /*right_*/ ) { return ( 0 ); } MagickPPExport int Magick::operator >= ( const Magick::PathQuadraticCurvetoArgs& left_, const Magick::PathQuadraticCurvetoArgs& right_ ) { return ( ( left_ > right_ ) || ( left_ == right_ ) ); } MagickPPExport int Magick::operator <= ( const Magick::PathQuadraticCurvetoArgs& left_, const Magick::PathQuadraticCurvetoArgs& right_ ) { return ( ( left_ < right_ ) || ( left_ == right_ ) ); } // Default Constructor Magick::PathQuadraticCurvetoArgs::PathQuadraticCurvetoArgs( void ) : _x1(0), _y1(0), _x(0), _y(0) { } // Normal Constructor Magick::PathQuadraticCurvetoArgs::PathQuadraticCurvetoArgs( double x1_, double y1_, double x_, double y_ ) : _x1(x1_), _y1(y1_), _x(x_), _y(y_) { } // Copy Constructor Magick::PathQuadraticCurvetoArgs::PathQuadraticCurvetoArgs( const PathQuadraticCurvetoArgs &original_ ) : _x1(original_._x1), _y1(original_._y1), _x(original_._x), _y(original_._y) { } // Destructor Magick::PathQuadraticCurvetoArgs::~PathQuadraticCurvetoArgs ( void ) { } Magick::PathQuadraticCurvetoAbs::PathQuadraticCurvetoAbs ( const Magick::PathQuadraticCurvetoArgs &args_ ) : _args(1,args_) { } Magick::PathQuadraticCurvetoAbs::PathQuadraticCurvetoAbs ( const PathQuadraticCurvetoArgsList &args_ ) : _args(args_) { } Magick::PathQuadraticCurvetoAbs::PathQuadraticCurvetoAbs ( const Magick::PathQuadraticCurvetoAbs& original_ ) : VPathBase (original_), _args(original_._args) { } Magick::PathQuadraticCurvetoAbs::~PathQuadraticCurvetoAbs ( void ) { } void Magick::PathQuadraticCurvetoAbs::operator() ( MagickCore::DrawingWand * context_ ) const { for( PathQuadraticCurvetoArgsList::const_iterator p = _args.begin(); p != _args.end(); p++ ) { DrawPathCurveToQuadraticBezierAbsolute( context_, p->x1(), p->y1(), p->x(), p->y() ); } } Magick::VPathBase* Magick::PathQuadraticCurvetoAbs::copy() const { return new PathQuadraticCurvetoAbs(*this); } Magick::PathQuadraticCurvetoRel::PathQuadraticCurvetoRel ( const Magick::PathQuadraticCurvetoArgs &args_ ) : _args(1,args_) { } Magick::PathQuadraticCurvetoRel::PathQuadraticCurvetoRel ( const PathQuadraticCurvetoArgsList &args_ ) : _args(args_) { } Magick::PathQuadraticCurvetoRel::PathQuadraticCurvetoRel ( const Magick::PathQuadraticCurvetoRel& original_ ) : VPathBase (original_), _args(original_._args) { } Magick::PathQuadraticCurvetoRel::~PathQuadraticCurvetoRel ( void ) { } void Magick::PathQuadraticCurvetoRel::operator() ( MagickCore::DrawingWand * context_ ) const { for( PathQuadraticCurvetoArgsList::const_iterator p = _args.begin(); p != _args.end(); p++ ) { DrawPathCurveToQuadraticBezierRelative( context_, p->x1(), p->y1(), p->x(), p->y() ); } } Magick::VPathBase* Magick::PathQuadraticCurvetoRel::copy() const { return new PathQuadraticCurvetoRel(*this); } Magick::PathSmoothQuadraticCurvetoAbs::PathSmoothQuadraticCurvetoAbs ( const Magick::Coordinate &coordinate_ ) : _coordinates(1,coordinate_) { } Magick::PathSmoothQuadraticCurvetoAbs::PathSmoothQuadraticCurvetoAbs ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } Magick::PathSmoothQuadraticCurvetoAbs::PathSmoothQuadraticCurvetoAbs ( const Magick::PathSmoothQuadraticCurvetoAbs& original_ ) : VPathBase (original_), _coordinates(original_._coordinates) { } Magick::PathSmoothQuadraticCurvetoAbs::~PathSmoothQuadraticCurvetoAbs ( void ) { } void Magick::PathSmoothQuadraticCurvetoAbs::operator() ( MagickCore::DrawingWand * context_ ) const { for( CoordinateList::const_iterator p = _coordinates.begin(); p != _coordinates.end(); p++ ) { DrawPathCurveToQuadraticBezierSmoothAbsolute( context_, p->x(), p->y() ); } } Magick::VPathBase* Magick::PathSmoothQuadraticCurvetoAbs::copy() const { return new PathSmoothQuadraticCurvetoAbs(*this); } Magick::PathSmoothQuadraticCurvetoRel::PathSmoothQuadraticCurvetoRel ( const Magick::Coordinate &coordinate_ ) : _coordinates(1,coordinate_) { } Magick::PathSmoothQuadraticCurvetoRel::PathSmoothQuadraticCurvetoRel ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } Magick::PathSmoothQuadraticCurvetoRel::PathSmoothQuadraticCurvetoRel ( const PathSmoothQuadraticCurvetoRel& original_ ) : VPathBase (original_), _coordinates(original_._coordinates) { } Magick::PathSmoothQuadraticCurvetoRel::~PathSmoothQuadraticCurvetoRel ( void ) { } void Magick::PathSmoothQuadraticCurvetoRel::operator() ( MagickCore::DrawingWand * context_ ) const { for( CoordinateList::const_iterator p = _coordinates.begin(); p != _coordinates.end(); p++ ) { DrawPathCurveToQuadraticBezierSmoothRelative( context_, p->x(), p->y() ); } } Magick::VPathBase* Magick::PathSmoothQuadraticCurvetoRel::copy() const { return new PathSmoothQuadraticCurvetoRel(*this); } // // Path Lineto // Magick::PathLinetoAbs::PathLinetoAbs ( const Magick::Coordinate& coordinate_ ) : _coordinates(1,coordinate_) { } Magick::PathLinetoAbs::PathLinetoAbs ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } Magick::PathLinetoAbs::PathLinetoAbs ( const Magick::PathLinetoAbs& original_ ) : VPathBase (original_), _coordinates(original_._coordinates) { } Magick::PathLinetoAbs::~PathLinetoAbs ( void ) { } void Magick::PathLinetoAbs::operator()( MagickCore::DrawingWand * context_ ) const { for( CoordinateList::const_iterator p = _coordinates.begin(); p != _coordinates.end(); p++ ) { DrawPathLineToAbsolute( context_, p->x(), p->y() ); } } Magick::VPathBase* Magick::PathLinetoAbs::copy() const { return new PathLinetoAbs(*this); } Magick::PathLinetoRel::PathLinetoRel ( const Magick::Coordinate& coordinate_ ) : _coordinates(1,coordinate_) { } Magick::PathLinetoRel::PathLinetoRel ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } Magick::PathLinetoRel::PathLinetoRel ( const Magick::PathLinetoRel& original_ ) : VPathBase (original_), _coordinates(original_._coordinates) { } Magick::PathLinetoRel::~PathLinetoRel ( void ) { } void Magick::PathLinetoRel::operator()( MagickCore::DrawingWand * context_ ) const { for( CoordinateList::const_iterator p = _coordinates.begin(); p != _coordinates.end(); p++ ) { DrawPathLineToRelative( context_, p->x(), p->y() ); } } Magick::VPathBase* Magick::PathLinetoRel::copy() const { return new PathLinetoRel(*this); } // // Path Horizontal Lineto // Magick::PathLinetoHorizontalAbs::~PathLinetoHorizontalAbs ( void ) { } void Magick::PathLinetoHorizontalAbs::operator() ( MagickCore::DrawingWand * context_ ) const { DrawPathLineToHorizontalAbsolute( context_, _x ); } Magick::VPathBase* Magick::PathLinetoHorizontalAbs::copy() const { return new PathLinetoHorizontalAbs(*this); } Magick::PathLinetoHorizontalRel::~PathLinetoHorizontalRel ( void ) { } void Magick::PathLinetoHorizontalRel::operator() ( MagickCore::DrawingWand * context_ ) const { DrawPathLineToHorizontalRelative( context_, _x ); } Magick::VPathBase* Magick::PathLinetoHorizontalRel::copy() const { return new PathLinetoHorizontalRel(*this); } // // Path Vertical Lineto // Magick::PathLinetoVerticalAbs::~PathLinetoVerticalAbs ( void ) { } void Magick::PathLinetoVerticalAbs::operator() ( MagickCore::DrawingWand * context_ ) const { DrawPathLineToVerticalAbsolute( context_, _y ); } Magick::VPathBase* Magick::PathLinetoVerticalAbs::copy() const { return new PathLinetoVerticalAbs(*this); } Magick::PathLinetoVerticalRel::~PathLinetoVerticalRel ( void ) { } void Magick::PathLinetoVerticalRel::operator() ( MagickCore::DrawingWand * context_ ) const { DrawPathLineToVerticalRelative( context_, _y ); } Magick::VPathBase* Magick::PathLinetoVerticalRel::copy() const { return new PathLinetoVerticalRel(*this); } // // Path Moveto // Magick::PathMovetoAbs::PathMovetoAbs ( const Magick::Coordinate &coordinate_ ) : _coordinates(1,coordinate_) { } Magick::PathMovetoAbs::PathMovetoAbs ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } Magick::PathMovetoAbs::PathMovetoAbs ( const Magick::PathMovetoAbs& original_ ) : VPathBase (original_), _coordinates(original_._coordinates) { } Magick::PathMovetoAbs::~PathMovetoAbs ( void ) { } void Magick::PathMovetoAbs::operator()( MagickCore::DrawingWand * context_ ) const { for( CoordinateList::const_iterator p = _coordinates.begin(); p != _coordinates.end(); p++ ) { DrawPathMoveToAbsolute( context_, p->x(), p->y() ); } } Magick::VPathBase* Magick::PathMovetoAbs::copy() const { return new PathMovetoAbs(*this); } Magick::PathMovetoRel::PathMovetoRel ( const Magick::Coordinate &coordinate_ ) : _coordinates(1,coordinate_) { } Magick::PathMovetoRel::PathMovetoRel ( const CoordinateList &coordinates_ ) : _coordinates(coordinates_) { } Magick::PathMovetoRel::PathMovetoRel ( const Magick::PathMovetoRel& original_ ) : VPathBase (original_), _coordinates(original_._coordinates) { } Magick::PathMovetoRel::~PathMovetoRel ( void ) { } void Magick::PathMovetoRel::operator()( MagickCore::DrawingWand * context_ ) const { for( CoordinateList::const_iterator p = _coordinates.begin(); p != _coordinates.end(); p++ ) { DrawPathMoveToRelative( context_, p->x(), p->y() ); } } Magick::VPathBase* Magick::PathMovetoRel::copy() const { return new PathMovetoRel(*this); } #if defined(EXPLICIT_TEMPLATE_INSTANTIATION) // template class std::vector<Magick::Coordinate>; // template class std::vector<const Magick::Drawable>; // template class std::vector<const Magick::PathArcArgs>; // template class std::vector<const Magick::PathCurvetoArgs>; // template class std::vector<const Magick::PathQuadraticCurvetoArgs>; // template class std::vector<const Magick::VPath>; #endif