2013-10-02 13:04:56 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2013 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef GrCoordTransform_DEFINED
|
|
|
|
#define GrCoordTransform_DEFINED
|
|
|
|
|
|
|
|
#include "SkMatrix.h"
|
|
|
|
#include "GrTexture.h"
|
|
|
|
|
2017-04-03 20:36:58 +00:00
|
|
|
class GrResourceProvider;
|
2017-01-23 20:30:35 +00:00
|
|
|
class GrTextureProxy;
|
|
|
|
|
2013-10-02 13:04:56 +00:00
|
|
|
/**
|
2016-10-03 21:15:28 +00:00
|
|
|
* A class representing a linear transformation of local coordinates. GrFragnentProcessors
|
|
|
|
* these transformations, and the GrGeometryProcessor implements the transformation.
|
2013-10-02 13:04:56 +00:00
|
|
|
*/
|
2014-04-07 19:34:38 +00:00
|
|
|
class GrCoordTransform : SkNoncopyable {
|
2013-10-02 13:04:56 +00:00
|
|
|
public:
|
2017-01-20 17:44:06 +00:00
|
|
|
GrCoordTransform()
|
|
|
|
: fTexture(nullptr)
|
2017-01-23 20:30:35 +00:00
|
|
|
, fNormalize(false)
|
2017-04-03 20:36:58 +00:00
|
|
|
, fReverseY(false) {
|
2017-01-20 17:44:06 +00:00
|
|
|
SkDEBUGCODE(fInProcessor = false);
|
|
|
|
}
|
2013-10-02 13:04:56 +00:00
|
|
|
|
|
|
|
/**
|
2017-04-03 20:36:58 +00:00
|
|
|
* Create a transformation that maps [0, 1] to a proxy's boundaries. The proxy origin also
|
|
|
|
* implies whether a y-reversal should be performed.
|
2013-10-02 13:04:56 +00:00
|
|
|
*/
|
2017-04-03 20:36:58 +00:00
|
|
|
GrCoordTransform(GrResourceProvider* resourceProvider, GrTextureProxy* proxy) {
|
2017-01-23 20:30:35 +00:00
|
|
|
SkASSERT(proxy);
|
|
|
|
SkDEBUGCODE(fInProcessor = false);
|
2017-04-03 20:36:58 +00:00
|
|
|
this->reset(resourceProvider, SkMatrix::I(), proxy);
|
2017-01-23 20:30:35 +00:00
|
|
|
}
|
|
|
|
|
2013-10-02 13:04:56 +00:00
|
|
|
/**
|
2017-04-03 20:36:58 +00:00
|
|
|
* Create a transformation from a matrix. The proxy origin also implies whether a y-reversal
|
|
|
|
* should be performed.
|
2013-10-02 13:04:56 +00:00
|
|
|
*/
|
2017-03-15 14:42:12 +00:00
|
|
|
GrCoordTransform(GrResourceProvider* resourceProvider, const SkMatrix& m,
|
2017-04-03 20:36:58 +00:00
|
|
|
GrTextureProxy* proxy) {
|
2017-01-23 20:30:35 +00:00
|
|
|
SkASSERT(proxy);
|
|
|
|
SkDEBUGCODE(fInProcessor = false);
|
2017-04-03 20:36:58 +00:00
|
|
|
this->reset(resourceProvider, m, proxy);
|
2017-01-23 20:30:35 +00:00
|
|
|
}
|
|
|
|
|
2014-12-09 17:00:49 +00:00
|
|
|
/**
|
|
|
|
* Create a transformation that applies the matrix to a coord set.
|
|
|
|
*/
|
2017-04-03 20:36:58 +00:00
|
|
|
GrCoordTransform(const SkMatrix& m) {
|
2014-12-09 17:00:49 +00:00
|
|
|
SkDEBUGCODE(fInProcessor = false);
|
2017-04-03 20:36:58 +00:00
|
|
|
this->reset(m);
|
2014-12-09 17:00:49 +00:00
|
|
|
}
|
|
|
|
|
2017-04-03 20:36:58 +00:00
|
|
|
void reset(GrResourceProvider*, const SkMatrix&, GrTextureProxy*, bool normalize = true);
|
2017-01-23 20:30:35 +00:00
|
|
|
|
2017-04-03 20:36:58 +00:00
|
|
|
void reset(const SkMatrix& m) {
|
2014-10-16 01:34:46 +00:00
|
|
|
SkASSERT(!fInProcessor);
|
2017-01-20 17:44:06 +00:00
|
|
|
fMatrix = m;
|
|
|
|
fTexture = nullptr;
|
|
|
|
fNormalize = false;
|
|
|
|
fReverseY = false;
|
2013-10-02 13:04:56 +00:00
|
|
|
}
|
|
|
|
|
2014-12-09 17:00:49 +00:00
|
|
|
GrCoordTransform& operator= (const GrCoordTransform& that) {
|
2014-10-16 01:34:46 +00:00
|
|
|
SkASSERT(!fInProcessor);
|
2014-12-09 17:00:49 +00:00
|
|
|
fMatrix = that.fMatrix;
|
2017-01-20 17:44:06 +00:00
|
|
|
fTexture = that.fTexture;
|
|
|
|
fNormalize = that.fNormalize;
|
2014-12-09 17:00:49 +00:00
|
|
|
fReverseY = that.fReverseY;
|
2013-10-04 01:20:09 +00:00
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Access the matrix for editing. Note, this must be done before adding the transform to an
|
|
|
|
* effect, since effects are immutable.
|
|
|
|
*/
|
|
|
|
SkMatrix* accessMatrix() {
|
2014-10-16 01:34:46 +00:00
|
|
|
SkASSERT(!fInProcessor);
|
2013-10-04 01:20:09 +00:00
|
|
|
return &fMatrix;
|
|
|
|
}
|
|
|
|
|
2017-01-20 17:44:06 +00:00
|
|
|
bool hasSameEffectAs(const GrCoordTransform& that) const {
|
|
|
|
if (fNormalize != that.fNormalize ||
|
|
|
|
fReverseY != that.fReverseY ||
|
|
|
|
!fMatrix.cheapEqualTo(that.fMatrix)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (fNormalize) {
|
|
|
|
SkASSERT(fTexture && that.fTexture);
|
|
|
|
return fTexture->width() == that.fTexture->width() &&
|
|
|
|
fTexture->height() == that.fTexture->height();
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
2013-10-02 13:04:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const SkMatrix& getMatrix() const { return fMatrix; }
|
2017-01-20 17:44:06 +00:00
|
|
|
const GrTexture* texture() const { return fTexture; }
|
|
|
|
bool normalize() const { return fNormalize; }
|
2013-10-02 13:04:56 +00:00
|
|
|
bool reverseY() const { return fReverseY; }
|
|
|
|
|
2017-01-17 19:20:54 +00:00
|
|
|
private:
|
2017-01-20 17:44:06 +00:00
|
|
|
// The textures' effect is to optionally normalize the final matrix, so a blind
|
|
|
|
// equality check could be misleading
|
|
|
|
bool operator==(const GrCoordTransform& that) const;
|
|
|
|
bool operator!=(const GrCoordTransform& that) const;
|
|
|
|
|
2014-12-09 17:00:49 +00:00
|
|
|
SkMatrix fMatrix;
|
2017-01-20 17:44:06 +00:00
|
|
|
const GrTexture* fTexture;
|
|
|
|
bool fNormalize;
|
2014-12-09 17:00:49 +00:00
|
|
|
bool fReverseY;
|
2013-10-02 13:04:56 +00:00
|
|
|
typedef SkNoncopyable INHERITED;
|
2013-10-04 01:20:09 +00:00
|
|
|
|
|
|
|
#ifdef SK_DEBUG
|
|
|
|
public:
|
2014-10-16 01:34:46 +00:00
|
|
|
void setInProcessor() const { fInProcessor = true; }
|
2013-10-04 01:20:09 +00:00
|
|
|
private:
|
2014-10-16 01:34:46 +00:00
|
|
|
mutable bool fInProcessor;
|
2013-10-04 01:20:09 +00:00
|
|
|
#endif
|
2013-10-02 13:04:56 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|