1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
/***************************************************************
* Name: OpenArrow.h
* Purpose: Defines open arrow for line shapes
* Author: Michal Bližňák (michal.bliznak@tiscali.cz)
* Created: 2007-07-22
* Copyright: Michal Bližňák
* License: wxWidgets license (www.wxwidgets.org)
* Notes:
**************************************************************/
#ifndef _WXSFOPENARROW_H
#define _WXSFOPENARROW_H
#include <wx/wxsf/ArrowBase.h>
/*!
* \brief Class extends the wxSFArrowBase class and encapsulates
* arrow shape consisting of single two lines leading from the end of the
* parent line shape.
*/
class WXDLLIMPEXP_SF wxSFOpenArrow : public wxSFArrowBase
{
public:
XS_DECLARE_CLONABLE_CLASS(wxSFOpenArrow);
/*! \brief Default constructor. */
wxSFOpenArrow(void);
/*!
* \brief User constructor.
* \param parent"> Pointer to the parent shape
*/
wxSFOpenArrow(wxSFShapeBase* parent);
/*!
* \brief Copy constructor.
* \param obj Reference to the source object
*/
wxSFOpenArrow(const wxSFOpenArrow& obj);
/*! \brief Destructor. */
virtual ~wxSFOpenArrow(void);
// public member data accessors
/**
* \brief Set a pen used for drawing of the arrow.
* \param pen Reference to the pen
*/
void SetArrowPen(const wxPen& pen) {m_Pen = pen;}
/**
* \brief Get current pen used for drawing of the arrow.
* \return Constant reference to current pen
*/
const wxPen& GetArrowPen() const {return m_Pen;}
// public virtual functions
/*!
* \brief Draw arrow shape at the end of a virtual line.
* \param from Start of the virtual line
* \param to End of the virtual line
* \param dc Device context for drawing
*/
virtual void Draw(const wxRealPoint& from, const wxRealPoint& to, wxDC& dc);
protected:
// protected data members
/*! \brief Arrow pen */
wxPen m_Pen;
};
#endif //_WXSFOPENARROW_H
|