diff options
Diffstat (limited to 'include')
-rw-r--r-- | include/core/SkShader.h | 13 | ||||
-rw-r--r-- | include/gpu/GrSamplerState.h | 29 |
2 files changed, 24 insertions, 18 deletions
diff --git a/include/core/SkShader.h b/include/core/SkShader.h index a0a1b056d4..8eb695cd14 100644 --- a/include/core/SkShader.h +++ b/include/core/SkShader.h @@ -306,13 +306,14 @@ public: virtual GradientType asAGradient(GradientInfo* info) const; /** - * If the shader subclass has a GrCustomStage implementation, this installs - * a custom stage on the sampler. A GrContext pointer is required since custom - * stages may need to create textures. The sampler parameter is necessary to set a - * texture matrix. It will eventually be removed and this function will operate as a - * GrCustomStage factory. + * If the shader subclass has a GrCustomStage implementation, this returns + * a new custom stage (the caller assumes ownership, and will need to + * unref it). A GrContext pointer is required since custom stages may + * need to create textures. The sampler parameter is necessary to set + * up matrix/tile modes/etc, and will eventually be removed. */ - virtual bool asNewCustomStage(GrContext* context, GrSamplerState* sampler) const; + virtual GrCustomStage* asNewCustomStage(GrContext* context, + GrSamplerState* sampler) const; ////////////////////////////////////////////////////////////////////////// // Factory methods for stock shaders diff --git a/include/gpu/GrSamplerState.h b/include/gpu/GrSamplerState.h index da52e95277..385dba7bdd 100644 --- a/include/gpu/GrSamplerState.h +++ b/include/gpu/GrSamplerState.h @@ -19,7 +19,14 @@ class GrSamplerState { public: + static const bool kBilerpDefault = false; + static const SkShader::TileMode kTileModeDefault = SkShader::kClamp_TileMode; + + /** + * Default sampler state is set to clamp, use normal sampling mode, be + * unfiltered, and use identity matrix. + */ GrSamplerState() : fCustomStage (NULL) { memset(this, 0, sizeof(GrSamplerState)); @@ -56,6 +63,12 @@ public: const GrMatrix& getMatrix() const { return fMatrix; } /** + * Access the sampler's matrix. See SampleMode for explanation of + * relationship between the matrix and sample mode. + */ + GrMatrix* matrix() { return &fMatrix; } + + /** * Multiplies the current sampler matrix a matrix * * After this call M' = M*m where M is the old matrix, m is the parameter @@ -67,10 +80,10 @@ public: */ void preConcatMatrix(const GrMatrix& matrix) { fMatrix.preConcat(matrix); } - /** - * Do not call this function. It will be removed soon. - */ - void setMatrixDeprecated(const GrMatrix& matrix) { fMatrix = matrix; } + void reset(const GrMatrix& matrix) { + fMatrix = matrix; + GrSafeSetNull(fCustomStage); + } void reset() { fMatrix.reset(); @@ -79,16 +92,8 @@ public: GrCustomStage* setCustomStage(GrCustomStage* stage) { GrSafeAssign(fCustomStage, stage); - fMatrix.reset(); return stage; } - - GrCustomStage* setCustomStage(GrCustomStage* stage, const GrMatrix& matrix) { - GrSafeAssign(fCustomStage, stage); - fMatrix = matrix; - return stage; - } - const GrCustomStage* getCustomStage() const { return fCustomStage; } private: |