Reland "Revert "Move localmatrix routines to shaderbase, no need to be public.""
This reverts commit12b4902e50
. Reason for revert: hmmm, where is my guard? Original change's description: > Revert "Revert "Move localmatrix routines to shaderbase, no need to be public."" > > Need to guard this for google3 > > This reverts commitf88a0e1c91
. > > Change-Id: Ia169610898c6276ae5af8a869ecc9672f6f4f285 > Reviewed-on: https://skia-review.googlesource.com/c/skia/+/206264 > Reviewed-by: Mike Reed <reed@google.com> > Commit-Queue: Mike Reed <reed@google.com> > Auto-Submit: Mike Reed <reed@google.com> TBR=reed@google.com Change-Id: Ibfb21fa248efbafe4ce3909ec3a1af5cffb221de No-Presubmit: true No-Tree-Checks: true No-Try: true Reviewed-on: https://skia-review.googlesource.com/c/skia/+/206398 Reviewed-by: Mike Reed <reed@google.com> Commit-Queue: Mike Reed <reed@google.com>
This commit is contained in:
parent
602df41025
commit
7c18eb9dc5
@ -70,6 +70,14 @@ public:
|
||||
static constexpr int kTileModeCount = kLast_TileMode + 1;
|
||||
#endif
|
||||
|
||||
/**
|
||||
* Returns the local matrix.
|
||||
*
|
||||
* FIXME: This can be incorrect for a Shader with its own local matrix
|
||||
* that is also wrapped via CreateLocalMatrixShader.
|
||||
*/
|
||||
const SkMatrix& getLocalMatrix() const;
|
||||
|
||||
/**
|
||||
* Returns true if the shader is guaranteed to produce only opaque
|
||||
* colors, subject to the SkPaint using the shader to apply an opaque
|
||||
@ -253,6 +261,13 @@ public:
|
||||
const SkMatrix* localMatrix, const SkRect* tile);
|
||||
#endif
|
||||
|
||||
/** DEPRECATED. skbug.com/8941
|
||||
* If this shader can be represented by another shader + a localMatrix, return that shader and
|
||||
* the localMatrix. If not, return nullptr and ignore the localMatrix parameter.
|
||||
*/
|
||||
// TODO: clean up clients, move to SkShaderBase.
|
||||
virtual sk_sp<SkShader> makeAsALocalMatrixShader(SkMatrix* localMatrix) const;
|
||||
|
||||
private:
|
||||
SkShader() = default;
|
||||
friend class SkShaderBase;
|
||||
|
@ -167,7 +167,7 @@ SkNormalSource::Provider* SkNormalMapSourceImpl::asProvider(const SkShaderBase::
|
||||
|
||||
bool SkNormalMapSourceImpl::computeNormTotalInverse(const SkShaderBase::ContextRec& rec,
|
||||
SkMatrix* normTotalInverse) const {
|
||||
SkMatrix total = SkMatrix::Concat(*rec.fMatrix, as_SB(fMapShader)->getLocalMatrix());
|
||||
SkMatrix total = SkMatrix::Concat(*rec.fMatrix, fMapShader->getLocalMatrix());
|
||||
if (rec.fLocalMatrix) {
|
||||
total.preConcat(*rec.fLocalMatrix);
|
||||
}
|
||||
|
@ -269,7 +269,7 @@ static SkPDFIndirectReference make_fallback_shader(SkPDFDocument* doc,
|
||||
{SkTileMode::kClamp, SkTileMode::kClamp},
|
||||
paintColor};
|
||||
|
||||
key.fShaderTransform = as_SB(shader)->getLocalMatrix();
|
||||
key.fShaderTransform = shader->getLocalMatrix();
|
||||
|
||||
// surfaceBBox is in device space. While that's exactly what we
|
||||
// want for sizing our bitmap, we need to map it into
|
||||
|
@ -12,7 +12,6 @@
|
||||
#include "SkPaint.h"
|
||||
#include "SkPath.h"
|
||||
#include "SkShader.h"
|
||||
#include "SkShaderBase.h"
|
||||
#include "SkStream.h"
|
||||
#include "SkUtils.h"
|
||||
|
||||
@ -114,10 +113,10 @@ inline void WriteUTF16beHex(SkDynamicMemoryWStream* wStream, SkUnichar utf32) {
|
||||
|
||||
inline SkMatrix GetShaderLocalMatrix(const SkShader* shader) {
|
||||
SkMatrix localMatrix;
|
||||
if (sk_sp<SkShader> s = as_SB(shader)->makeAsALocalMatrixShader(&localMatrix)) {
|
||||
return SkMatrix::Concat(as_SB(s)->getLocalMatrix(), localMatrix);
|
||||
if (sk_sp<SkShader> s = shader->makeAsALocalMatrixShader(&localMatrix)) {
|
||||
return SkMatrix::Concat(s->getLocalMatrix(), localMatrix);
|
||||
}
|
||||
return as_SB(shader)->getLocalMatrix();
|
||||
return shader->getLocalMatrix();
|
||||
}
|
||||
bool InverseTransformBBox(const SkMatrix& matrix, SkRect* bbox);
|
||||
void PopulateTilingPatternDict(SkPDFDict* pattern,
|
||||
|
@ -114,6 +114,10 @@ bool SkShaderBase::ContextRec::isLegacyCompatible(SkColorSpace* shaderColorSpace
|
||||
return !SkColorSpaceXformSteps::Required(shaderColorSpace, fDstColorSpace);
|
||||
}
|
||||
|
||||
const SkMatrix& SkShader::getLocalMatrix() const {
|
||||
return as_SB(this)->getLocalMatrix();
|
||||
}
|
||||
|
||||
SkImage* SkShader::isAImage(SkMatrix* localMatrix, SkTileMode xy[2]) const {
|
||||
return as_SB(this)->onIsAImage(localMatrix, xy);
|
||||
}
|
||||
@ -128,7 +132,7 @@ std::unique_ptr<GrFragmentProcessor> SkShaderBase::asFragmentProcessor(const GrF
|
||||
}
|
||||
#endif
|
||||
|
||||
sk_sp<SkShader> SkShaderBase::makeAsALocalMatrixShader(SkMatrix*) const {
|
||||
sk_sp<SkShader> SkShader::makeAsALocalMatrixShader(SkMatrix*) const {
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
|
@ -178,12 +178,6 @@ public:
|
||||
}
|
||||
static void RegisterFlattenables();
|
||||
|
||||
/** DEPRECATED. skbug.com/8941
|
||||
* If this shader can be represented by another shader + a localMatrix, return that shader and
|
||||
* the localMatrix. If not, return nullptr and ignore the localMatrix parameter.
|
||||
*/
|
||||
virtual sk_sp<SkShader> makeAsALocalMatrixShader(SkMatrix* localMatrix) const;
|
||||
|
||||
protected:
|
||||
SkShaderBase(const SkMatrix* localMatrix = nullptr);
|
||||
|
||||
|
@ -24,7 +24,6 @@
|
||||
#include "SkParsePath.h"
|
||||
#include "SkPngCodec.h"
|
||||
#include "SkShader.h"
|
||||
#include "SkShaderBase.h"
|
||||
#include "SkStream.h"
|
||||
#include "SkTHash.h"
|
||||
#include "SkTo.h"
|
||||
@ -548,8 +547,8 @@ SkString SkSVGDevice::AutoElement::addLinearGradientDef(const SkShader::Gradient
|
||||
gradient.addAttribute("x2", info.fPoint[1].x());
|
||||
gradient.addAttribute("y2", info.fPoint[1].y());
|
||||
|
||||
if (!as_SB(shader)->getLocalMatrix().isIdentity()) {
|
||||
this->addAttribute("gradientTransform", svg_transform(as_SB(shader)->getLocalMatrix()));
|
||||
if (!shader->getLocalMatrix().isIdentity()) {
|
||||
this->addAttribute("gradientTransform", svg_transform(shader->getLocalMatrix()));
|
||||
}
|
||||
|
||||
SkASSERT(info.fColorCount >= 2);
|
||||
|
@ -40,7 +40,6 @@
|
||||
#include "SkRasterClip.h"
|
||||
#include "SkSFNTHeader.h"
|
||||
#include "SkShader.h"
|
||||
#include "SkShaderBase.h"
|
||||
#include "SkSize.h"
|
||||
#include "SkStream.h"
|
||||
#include "SkStrikeCache.h"
|
||||
@ -1017,7 +1016,7 @@ HRESULT SkXPSDevice::createXpsBrush(const SkPaint& skPaint,
|
||||
return S_OK;
|
||||
}
|
||||
|
||||
SkMatrix localMatrix = as_SB(shader)->getLocalMatrix();
|
||||
SkMatrix localMatrix = shader->getLocalMatrix();
|
||||
if (parentTransform) {
|
||||
localMatrix.preConcat(*parentTransform);
|
||||
}
|
||||
@ -1057,7 +1056,7 @@ HRESULT SkXPSDevice::createXpsBrush(const SkPaint& skPaint,
|
||||
SkImage* image = shader->isAImage(&outMatrix, xy);
|
||||
if (image && image->asLegacyBitmap(&outTexture)) {
|
||||
//TODO: outMatrix??
|
||||
SkMatrix localMatrix = as_SB(shader)->getLocalMatrix();
|
||||
SkMatrix localMatrix = shader->getLocalMatrix();
|
||||
if (parentTransform) {
|
||||
localMatrix.postConcat(*parentTransform);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user