blob: 6b21e32602c0f3d08cba733699ff2e00370a3ef5 [file] [log] [blame] [edit]
/*
* Copyright 2018 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef GrFPArgs_DEFINED
#define GrFPArgs_DEFINED
#include "include/core/SkFilterQuality.h"
#include "include/core/SkMatrix.h"
class GrColorInfo;
class GrRecordingContext;
class SkMatrixProvider;
struct GrFPArgs {
GrFPArgs(GrRecordingContext* context,
const SkMatrixProvider& matrixProvider,
SkFilterQuality filterQuality,
const GrColorInfo* dstColorInfo)
: fContext(context)
, fMatrixProvider(matrixProvider)
, fFilterQuality(filterQuality)
, fDstColorInfo(dstColorInfo) {
SkASSERT(fContext);
}
class WithPreLocalMatrix;
GrFPArgs withNewMatrixProvider(const SkMatrixProvider& provider) const {
GrFPArgs newArgs(fContext, provider, fFilterQuality, fDstColorInfo);
newArgs.fInputColorIsOpaque = fInputColorIsOpaque;
newArgs.fPreLocalMatrix = fPreLocalMatrix;
return newArgs;
}
GrRecordingContext* fContext;
const SkMatrixProvider& fMatrixProvider;
const SkMatrix* fPreLocalMatrix = nullptr;
// Make this SkAlphaType?
bool fInputColorIsOpaque = false;
SkFilterQuality fFilterQuality;
const GrColorInfo* fDstColorInfo;
};
class GrFPArgs::WithPreLocalMatrix final : public GrFPArgs {
public:
WithPreLocalMatrix(const GrFPArgs& args, const SkMatrix& lm) : INHERITED(args) {
if (!lm.isIdentity()) {
if (fPreLocalMatrix) {
fStorage.setConcat(lm, *fPreLocalMatrix);
fPreLocalMatrix = fStorage.isIdentity() ? nullptr : &fStorage;
} else {
fPreLocalMatrix = &lm;
}
}
}
private:
WithPreLocalMatrix(const WithPreLocalMatrix&) = delete;
WithPreLocalMatrix& operator=(const WithPreLocalMatrix&) = delete;
SkMatrix fStorage;
using INHERITED = GrFPArgs;
};
#endif