00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 #include "qwt_scale_div.h"
00011 #include "qwt_math.h"
00012 #include "qwt_double_interval.h"
00013 
00015 QwtScaleDiv::QwtScaleDiv():
00016     d_lBound(0.0),
00017     d_hBound(0.0),
00018     d_isValid(false)
00019 {
00020 }
00021 
00028 QwtScaleDiv::QwtScaleDiv(
00029         const QwtDoubleInterval &interval, 
00030         QwtValueList ticks[NTickTypes]):
00031     d_lBound(interval.minValue()),
00032     d_hBound(interval.maxValue()),
00033     d_isValid(true)
00034 {
00035     for ( int i = 0; i < NTickTypes; i++ )
00036         d_ticks[i] = ticks[i];
00037 }
00038 
00046 QwtScaleDiv::QwtScaleDiv(
00047         double lBound, double hBound,
00048         QwtValueList ticks[NTickTypes]):
00049     d_lBound(lBound),
00050     d_hBound(hBound),
00051     d_isValid(true)
00052 {
00053     for ( int i = 0; i < NTickTypes; i++ )
00054         d_ticks[i] = ticks[i];
00055 }
00056 
00061 void QwtScaleDiv::setInterval(const QwtDoubleInterval &interval)
00062 {
00063     setInterval(interval.minValue(), interval.maxValue());
00064 }
00065 
00070 int QwtScaleDiv::operator==(const QwtScaleDiv &other) const
00071 {
00072     if ( d_lBound != other.d_lBound ||
00073         d_hBound != other.d_hBound ||
00074         d_isValid != other.d_isValid )
00075     {
00076         return false;
00077     }
00078 
00079     for ( int i = 0; i < NTickTypes; i++ )
00080     {
00081         if ( d_ticks[i] != other.d_ticks[i] )
00082             return false;
00083     }
00084 
00085     return true;
00086 }
00087 
00092 int QwtScaleDiv::operator!=(const QwtScaleDiv &s) const
00093 {
00094     return (!(*this == s));
00095 }
00096 
00098 void QwtScaleDiv::invalidate()
00099 {
00100     d_isValid = false;
00101 
00102     
00103     for ( int i = 0; i < NTickTypes; i++ )
00104         d_ticks[i].clear();
00105 
00106     d_lBound = d_hBound = 0;
00107 }
00108 
00110 bool QwtScaleDiv::isValid() const
00111 {
00112     return d_isValid;
00113 }
00114 
00115 bool QwtScaleDiv::contains(double v) const
00116 {
00117     if ( !d_isValid )
00118         return false;
00119 
00120     const double min = qwtMin(d_lBound, d_hBound);
00121     const double max = qwtMax(d_lBound, d_hBound);
00122 
00123     return v >= min && v <= max;
00124 }
00125 
00127 void QwtScaleDiv::invert()
00128 {
00129     qSwap(d_lBound, d_hBound);
00130 
00131     for ( int i = 0; i < NTickTypes; i++ )
00132     {
00133         QwtValueList& ticks = d_ticks[i];
00134 
00135         const int size = ticks.count();
00136         const int size2 = size / 2;
00137  
00138         for (int i=0; i < size2; i++)
00139             qSwap(ticks[i], ticks[size - 1 - i]);
00140     }
00141 }
00142 
00149 void QwtScaleDiv::setTicks(int type, const QwtValueList &ticks)
00150 {
00151     if ( type >= 0 || type < NTickTypes )
00152         d_ticks[type] = ticks;
00153 }
00154 
00160 const QwtValueList &QwtScaleDiv::ticks(int type) const
00161 {
00162     if ( type >= 0 || type < NTickTypes )
00163         return d_ticks[type];
00164 
00165     static QwtValueList noTicks;
00166     return noTicks;
00167 }