skia2/gm/textblobuseaftergpufree.cpp
Mike Klein ea3f014e2b sk_tool_utils -> ToolUtils, and git clang-format
sk_tool_utils doesn't really fit the naming convention
the rest of code under tools/ tends to use.

Change-Id: I45326a174101c6eb4b6149e9c742f658f2fd23b1
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/202313
Auto-Submit: Mike Klein <mtklein@google.com>
Commit-Queue: Brian Osman <brianosman@google.com>
Reviewed-by: Brian Osman <brianosman@google.com>
2019-03-20 18:05:42 +00:00

60 lines
1.6 KiB
C++

/*
* Copyright 2015 Google Inc.
*
* Use of this source code is governed by a BD-style license that can be
* found in the LICENSE file.
*/
#include "ToolUtils.h"
#include "gm.h"
#include "SkCanvas.h"
#include "SkSurface.h"
#include "SkTextBlob.h"
#include "GrContext.h"
// This tests that we correctly regenerate textblobs after freeing all gpu resources crbug/491350
namespace skiagm {
class TextBlobUseAfterGpuFree : public GpuGM {
public:
TextBlobUseAfterGpuFree() { }
protected:
SkString onShortName() override {
return SkString("textblobuseaftergpufree");
}
SkISize onISize() override {
return SkISize::Make(kWidth, kHeight);
}
void onDraw(GrContext* context, GrRenderTargetContext*, SkCanvas* canvas) override {
const char text[] = "Hamburgefons";
SkFont font(ToolUtils::create_portable_typeface(), 20);
auto blob = SkTextBlob::MakeFromText(text, strlen(text), font);
// draw textblob
SkRect rect = SkRect::MakeLTRB(0.f, 0.f, SkIntToScalar(kWidth), kHeight / 2.f);
SkPaint rectPaint;
rectPaint.setColor(0xffffffff);
canvas->drawRect(rect, rectPaint);
canvas->drawTextBlob(blob, 20, 60, SkPaint());
// This text should look fine
context->freeGpuResources();
canvas->drawTextBlob(blob, 20, 160, SkPaint());
}
private:
static constexpr int kWidth = 200;
static constexpr int kHeight = 200;
typedef GM INHERITED;
};
//////////////////////////////////////////////////////////////////////////////
DEF_GM(return new TextBlobUseAfterGpuFree;)
}