| Index: gm/skbug1719.cpp
|
| diff --git a/gm/skbug1719.cpp b/gm/skbug1719.cpp
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..01bb844a872383e3e5393be3416fbac980d1398d
|
| --- /dev/null
|
| +++ b/gm/skbug1719.cpp
|
| @@ -0,0 +1,102 @@
|
| +/*
|
| + * Copyright 2013 Google Inc.
|
| + *
|
| + * Use of this source code is governed by a BSD-style license that can be
|
| + * found in the LICENSE file.
|
| + */
|
| +
|
| +#include "gm.h"
|
| +#include "SkColorFilter.h"
|
| +#include "SkBlurMaskFilter.h"
|
| +
|
| +namespace skiagm {
|
| +
|
| +/**
|
| + * This test exercises bug 1719. An anti-aliased blurred path is rendered through a soft clip. On
|
| + * the GPU a scratch texture was used to hold the original path mask as well as the blurred path
|
| + * result. The same texture is then incorrectly used to generate the soft clip mask for the draw.
|
| + * Thus the same texture is used for both the blur mask and soft mask in a single draw.
|
| + *
|
| + * The correct image should look like a thin stroked round rect.
|
| + */
|
| +class SkBug1719GM : public GM {
|
| +public:
|
| + SkBug1719GM() {}
|
| +
|
| +protected:
|
| + virtual SkString onShortName() SK_OVERRIDE {
|
| + return SkString("skbug1719");
|
| + }
|
| +
|
| + virtual SkISize onISize() SK_OVERRIDE {
|
| + return make_isize(300, 100);
|
| + }
|
| +
|
| + virtual void onDrawBackground(SkCanvas* canvas) SK_OVERRIDE {
|
| + SkPaint bgPaint;
|
| + bgPaint.setColor(0xFF303030);
|
| + canvas->drawPaint(bgPaint);
|
| + }
|
| +
|
| + virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
|
| + canvas->translate(SkIntToScalar(-800), SkIntToScalar(-650));
|
| +
|
| + // The data is lifted from an SKP that exhibited the bug.
|
| +
|
| + // This is a round rect.
|
| + SkPath clipPath;
|
| + clipPath.moveTo(832.f, 654.f);
|
| + clipPath.lineTo(1034.f, 654.f);
|
| + clipPath.cubicTo(1038.4183f, 654.f, 1042.f, 657.58173f, 1042.f, 662.f);
|
| + clipPath.lineTo(1042.f, 724.f);
|
| + clipPath.cubicTo(1042.f, 728.41827f, 1038.4183f, 732.f, 1034.f, 732.f);
|
| + clipPath.lineTo(832.f, 732.f);
|
| + clipPath.cubicTo(827.58173f, 732.f, 824.f, 728.41827f, 824.f, 724.f);
|
| + clipPath.lineTo(824.f, 662.f);
|
| + clipPath.cubicTo(824.f, 657.58173f, 827.58173f, 654.f, 832.f, 654.f);
|
| + clipPath.close();
|
| +
|
| + // This is a round rect nested inside a rect.
|
| + SkPath drawPath;
|
| + drawPath.moveTo(823.f, 653.f);
|
| + drawPath.lineTo(1043.f, 653.f);
|
| + drawPath.lineTo(1043.f, 733.f);
|
| + drawPath.lineTo(823.f, 733.f);
|
| + drawPath.lineTo(823.f, 653.f);
|
| + drawPath.close();
|
| + drawPath.moveTo(832.f, 654.f);
|
| + drawPath.lineTo(1034.f, 654.f);
|
| + drawPath.cubicTo(1038.4183f, 654.f, 1042.f, 657.58173f, 1042.f, 662.f);
|
| + drawPath.lineTo(1042.f, 724.f);
|
| + drawPath.cubicTo(1042.f, 728.41827f, 1038.4183f, 732.f, 1034.f, 732.f);
|
| + drawPath.lineTo(832.f, 732.f);
|
| + drawPath.cubicTo(827.58173f, 732.f, 824.f, 728.41827f, 824.f, 724.f);
|
| + drawPath.lineTo(824.f, 662.f);
|
| + drawPath.cubicTo(824.f, 657.58173f, 827.58173f, 654.f, 832.f, 654.f);
|
| + drawPath.close();
|
| + drawPath.setFillType(SkPath::kEvenOdd_FillType);
|
| +
|
| + SkPaint paint;
|
| + paint.setAntiAlias(true);
|
| + paint.setColor(0xFF000000);
|
| + paint.setMaskFilter(
|
| + SkBlurMaskFilter::Create(SkBlurMaskFilter::kNormal_BlurStyle,
|
| + 0.78867501f,
|
| + SkBlurMaskFilter::kHighQuality_BlurFlag))->unref();
|
| + paint.setColorFilter(
|
| + SkColorFilter::CreateModeFilter(0xBFFFFFFF, SkXfermode::kSrcIn_Mode))->unref();
|
| +
|
| + canvas->clipPath(clipPath, SkRegion::kIntersect_Op, true);
|
| + canvas->drawPath(drawPath, paint);
|
| + }
|
| +
|
| +private:
|
| +
|
| + typedef GM INHERITED;
|
| +};
|
| +
|
| +//////////////////////////////////////////////////////////////////////////////
|
| +
|
| +DEF_GM(return new SkBug1719GM;)
|
| +
|
| +}
|
|
|