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 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
|
/*
* arrow_atyle.cc -- ePiX's arrowhead parameters
*
* This file is part of ePiX, a C++ library for creating high-quality
* figures in LaTeX
*
* Version 1.1.15
* Last Change: September 08, 2007
*/
/*
* Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007
* Andrew D. Hwang <ahwang -at- holycross -dot- edu>
* Department of Mathematics and Computer Science
* College of the Holy Cross
* Worcester, MA, 01610-2395, USA
*/
/*
* ePiX is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* ePiX is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* License for more details.
*
* You should have received a copy of the GNU General Public License
* along with ePiX; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
/*
* The class in this file implements backend for user-level global
* functions defined in state.h. This header is not part of epix.h.
*/
#include <cmath>
#include "constants.h"
#include "functions.h" // for snip_to
#include "arrow_style.h"
namespace ePiX {
arrowhead_state::arrowhead_state()
: m_width(0.5*AVG_AWIDTH), m_ratio(AVG_ARATIO),
m_inset(AVG_INSET), m_fill(false) { }
// set
arrowhead_state& arrowhead_state::width(double w)
{
m_width = fabs(0.5*snip_to(w, MIN_AWIDTH, MAX_AWIDTH));
return *this;
}
arrowhead_state& arrowhead_state::ratio(double r)
{
m_ratio = fabs(snip_to(r, MIN_ARATIO, MAX_ARATIO));
return *this;
}
arrowhead_state& arrowhead_state::inset(double arg)
{
m_inset = snip_to(arg, MIN_INSET, MAX_INSET);
return *this;
}
arrowhead_state& arrowhead_state::fill(bool fill)
{
m_fill = fill;
return *this;
}
// get
double arrowhead_state::width() const
{
return m_width;
}
double arrowhead_state::ratio() const
{
return m_ratio;
}
double arrowhead_state::inset() const
{
return m_inset;
}
bool arrowhead_state::fill() const
{
return m_fill;
}
arrowhead_state& the_arrowhead_style()
{
static arrowhead_state* the_arrowhead_state(new arrowhead_state());
return *the_arrowhead_state;
}
} // end of namespace
|