diff options
author | initial.commit <initial.commit@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-07-27 00:09:42 +0000 |
---|---|---|
committer | initial.commit <initial.commit@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-07-27 00:09:42 +0000 |
commit | ae2c20f398933a9e86c387dcc465ec0f71065ffc (patch) | |
tree | de668b1411e2ee0b4e49b6d8f8b68183134ac990 /skia/include/SkUnitMappers.h | |
parent | 09911bf300f1a419907a9412154760efd0b7abc3 (diff) | |
download | chromium_src-ae2c20f398933a9e86c387dcc465ec0f71065ffc.zip chromium_src-ae2c20f398933a9e86c387dcc465ec0f71065ffc.tar.gz chromium_src-ae2c20f398933a9e86c387dcc465ec0f71065ffc.tar.bz2 |
Add skia to the repository.
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@16 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'skia/include/SkUnitMappers.h')
-rw-r--r-- | skia/include/SkUnitMappers.h | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/skia/include/SkUnitMappers.h b/skia/include/SkUnitMappers.h new file mode 100644 index 0000000..a1331bb --- /dev/null +++ b/skia/include/SkUnitMappers.h @@ -0,0 +1,49 @@ +#ifndef SkUnitMappers_DEFINED +#define SkUnitMappers_DEFINED + +#include "SkUnitMapper.h" + +/** This discretizes the range [0...1) into N discret values. +*/ +class SkDiscreteMapper : public SkUnitMapper { +public: + SkDiscreteMapper(int segments); + // override from SkUnitMapper + virtual uint16_t mapUnit16(uint16_t x); + +protected: + SkDiscreteMapper(SkFlattenableReadBuffer& ); + // overrides from SkFlattenable + virtual void flatten(SkFlattenableWriteBuffer& ); + virtual Factory getFactory(); +private: + int fSegments; + SkFract fScale; // computed from fSegments + + static SkFlattenable* Create(SkFlattenableReadBuffer& buffer); + + typedef SkUnitMapper INHERITED; +}; + +/** This returns cos(x), to simulate lighting a sphere, where 0 maps to the + center of the sphere, and 1 maps to the edge. +*/ +class SkCosineMapper : public SkUnitMapper { +public: + SkCosineMapper() {} + // override from SkUnitMapper + virtual uint16_t mapUnit16(uint16_t x); + +protected: + SkCosineMapper(SkFlattenableReadBuffer&); + // overrides from SkFlattenable + virtual Factory getFactory(); + +private: + static SkFlattenable* Create(SkFlattenableReadBuffer&); + + typedef SkUnitMapper INHERITED; +}; + +#endif + |