e964c18b98
Change-Id: I705180db106ec4515aaec5f347199b98b21976fa Reviewed-on: https://skia-review.googlesource.com/c/186081 Auto-Submit: Hal Canary <halcanary@google.com> Reviewed-by: Herb Derby <herb@google.com> Commit-Queue: Hal Canary <halcanary@google.com>
83 lines
2.0 KiB
C++
83 lines
2.0 KiB
C++
/*
|
|
* Copyright 2011 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 "SkRandom.h"
|
|
|
|
namespace skiagm {
|
|
|
|
#define W 400
|
|
#define H 400
|
|
#define N 100
|
|
|
|
constexpr SkScalar SW = SkIntToScalar(W);
|
|
constexpr SkScalar SH = SkIntToScalar(H);
|
|
|
|
class StrokeRectsGM : public GM {
|
|
public:
|
|
StrokeRectsGM() {}
|
|
|
|
protected:
|
|
|
|
SkString onShortName() override {
|
|
return SkString("strokerects");
|
|
}
|
|
|
|
SkISize onISize() override {
|
|
return SkISize::Make(W*2, H*2);
|
|
}
|
|
|
|
static void rnd_rect(SkRect* r, SkRandom& rand) {
|
|
SkScalar x = rand.nextUScalar1() * W;
|
|
SkScalar y = rand.nextUScalar1() * H;
|
|
SkScalar w = rand.nextUScalar1() * (W >> 2);
|
|
SkScalar h = rand.nextUScalar1() * (H >> 2);
|
|
SkScalar hoffset = rand.nextSScalar1();
|
|
SkScalar woffset = rand.nextSScalar1();
|
|
|
|
r->set(x, y, x + w, y + h);
|
|
r->offset(-w/2 + woffset, -h/2 + hoffset);
|
|
}
|
|
|
|
void onDraw(SkCanvas* canvas) override {
|
|
SkPaint paint;
|
|
paint.setStyle(SkPaint::kStroke_Style);
|
|
|
|
for (int y = 0; y < 2; y++) {
|
|
paint.setAntiAlias(!!y);
|
|
for (int x = 0; x < 2; x++) {
|
|
paint.setStrokeWidth(x * SkIntToScalar(3));
|
|
|
|
SkAutoCanvasRestore acr(canvas, true);
|
|
canvas->translate(SW * x, SH * y);
|
|
canvas->clipRect(SkRect::MakeLTRB(
|
|
SkIntToScalar(2), SkIntToScalar(2)
|
|
, SW - SkIntToScalar(2), SH - SkIntToScalar(2)
|
|
));
|
|
|
|
SkRandom rand;
|
|
for (int i = 0; i < N; i++) {
|
|
SkRect r;
|
|
rnd_rect(&r, rand);
|
|
canvas->drawRect(r, paint);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
private:
|
|
typedef GM INHERITED;
|
|
};
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
DEF_GM( return new StrokeRectsGM; )
|
|
|
|
}
|