X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Fgradient.h;fp=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Fgradient.h;h=bc4c1e820972dc4f9baa35e1e603bde1be141da6;hb=cf1a6e2a6f015914a56e5f539da2e14146ce4c20;hp=25a9dbfa84e86800ba1c30b578f0c93e003aaa4c;hpb=11c0abb278300f2c4439b538b300433078a19a78;p=synfig.git diff --git a/synfig-core/trunk/src/synfig/gradient.h b/synfig-core/trunk/src/synfig/gradient.h index 25a9dbf..bc4c1e8 100644 --- a/synfig-core/trunk/src/synfig/gradient.h +++ b/synfig-core/trunk/src/synfig/gradient.h @@ -60,12 +60,17 @@ struct GradientCPoint : public UniqueID /*! \class Gradient ** \brief Color Gradient Class */ -class Gradient : public std::vector +using namespace std; +class Gradient { public: typedef GradientCPoint CPoint; + typedef vector::const_iterator const_iterator; + typedef vector::iterator iterator; + typedef vector::const_reverse_iterator const_reverse_iterator; + typedef vector::reverse_iterator reverse_iterator; private: - + vector cpoints; public: Gradient() { } @@ -81,6 +86,20 @@ public: //! You should call this function after changing stuff. void sort(); + void push_back(const GradientCPoint cpoint) { cpoints.push_back(cpoint); } + iterator erase(iterator iter) { return cpoints.erase(iter); } + bool empty()const { return cpoints.empty(); } + size_t size()const { return cpoints.size(); } + + iterator begin() { return cpoints.begin(); } + iterator end() { return cpoints.end(); } + reverse_iterator rbegin() { return cpoints.rbegin(); } + reverse_iterator rend() { return cpoints.rend(); } + const_iterator begin()const { return cpoints.begin(); } + const_iterator end()const { return cpoints.end(); } + const_reverse_iterator rbegin()const { return cpoints.rbegin(); } + const_reverse_iterator rend()const { return cpoints.rend(); } + Color operator()(const Real &x, float supersample=0)const; //! Returns the iterator of the CPoint closest to \a x