/*
* Copyright 2015 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef GrTestMeshDrawOp_DEFINED
#define GrTestMeshDrawOp_DEFINED
#include "GrGeometryProcessor.h"
#include "GrOpFlushState.h"
#include "ops/GrMeshDrawOp.h"
/*
* A simple solid color GrMeshDrawOp for testing purposes which doesn't ever combine. Subclassing
* this in tests saves having to fill out some boiler plate methods.
*/
class GrTestMeshDrawOp : public GrMeshDrawOp {
public:
const char* name() const override = 0;
protected:
GrTestMeshDrawOp(uint32_t classID, const SkRect& bounds, GrColor color)
: INHERITED(classID), fColor(color) {
// Choose some conservative values for aa bloat and zero area.
this->setBounds(bounds, HasAABloat::kYes, IsZeroArea::kYes);
}
GrColor color() const { return fColor; }
bool usesLocalCoords() const { return fUsesLocalCoords; }
private:
void getFragmentProcessorAnalysisInputs(GrPipelineAnalysisColor* color,
GrPipelineAnalysisCoverage* coverage) const override {
color->setToConstant(fColor);
*coverage = GrPipelineAnalysisCoverage::kSingleChannel;
}
void applyPipelineOptimizations(const GrPipelineOptimizations& optimizations) override {
optimizations.getOverrideColorIfSet(&fColor);
fUsesLocalCoords = optimizations.readsLocalCoords();
}
bool onCombineIfPossible(GrOp*, const GrCaps&) override { return false; }
GrColor fColor;
bool fUsesLocalCoords = false;
typedef GrMeshDrawOp INHERITED;
};
#endif