/*
* Copyright 2012 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef Gr1DKernelEffect_DEFINED
#define Gr1DKernelEffect_DEFINED
#include "GrSingleTextureEffect.h"
#include "SkMatrix.h"
/**
* Base class for 1D kernel effects. The kernel operates either in X or Y and
* has a pixel radius. The kernel is specified in the src texture's space
* and the kernel center is pinned to a texel's center. The radius specifies
* the number of texels on either side of the center texel in X or Y that are
* read. Since the center pixel is also read, the total width is one larger than
* two times the radius.
*/
class Gr1DKernelEffect : public GrSingleTextureEffect {
public:
enum Direction {
kX_Direction,
kY_Direction,
};
Gr1DKernelEffect(GrResourceProvider* resourceProvider, OptimizationFlags optFlags,
sk_sp<GrTextureProxy> proxy, Direction direction, int radius)
: INHERITED(resourceProvider, optFlags, std::move(proxy), nullptr, SkMatrix::I())
, fDirection(direction)
, fRadius(radius) {
}
~Gr1DKernelEffect() override {}
static int WidthFromRadius(int radius) { return 2 * radius + 1; }
int radius() const { return fRadius; }
int width() const { return WidthFromRadius(fRadius); }
Direction direction() const { return fDirection; }
SkString dumpInfo() const override {
SkString str;
str.appendf("Direction: %s, Radius: %d ", kX_Direction == fDirection ? "X" : "Y", fRadius);
str.append(INHERITED::dumpInfo());
return str;
}
private:
Direction fDirection;
int fRadius;
typedef GrSingleTextureEffect INHERITED;
};
#endif