ec80d901b9
will flesh out more over time. Bug: skia: Change-Id: If5eaf0a7c404b9209b93871eb3ac3d74da8c65dd Reviewed-on: https://skia-review.googlesource.com/c/191003 Reviewed-by: Florin Malita <fmalita@chromium.org> Commit-Queue: Mike Reed <reed@google.com>
49 lines
1.1 KiB
C++
49 lines
1.1 KiB
C++
/*
|
|
* Copyright 2017 Google Inc.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
#ifndef SkSGDraw_DEFINED
|
|
#define SkSGDraw_DEFINED
|
|
|
|
#include "SkSGGeometryNode.h"
|
|
#include "SkSGPaintNode.h"
|
|
#include "SkSGRenderNode.h"
|
|
|
|
namespace sksg {
|
|
|
|
/**
|
|
* Concrete rendering node.
|
|
*
|
|
* Wraps and draws a [geometry, paint] tuple.
|
|
*
|
|
* Think Skia SkCanvas::drawFoo(foo, paint) calls.
|
|
*/
|
|
class Draw : public RenderNode {
|
|
public:
|
|
static sk_sp<Draw> Make(sk_sp<GeometryNode> geo, sk_sp<PaintNode> paint) {
|
|
return (geo && paint) ? sk_sp<Draw>(new Draw(std::move(geo), std::move(paint))) : nullptr;
|
|
}
|
|
|
|
protected:
|
|
Draw(sk_sp<GeometryNode>, sk_sp<PaintNode> paint);
|
|
~Draw() override;
|
|
|
|
void onRender(SkCanvas*, const RenderContext*) const override;
|
|
const RenderNode* onNodeAt(const SkPoint&) const override;
|
|
|
|
SkRect onRevalidate(InvalidationController*, const SkMatrix&) override;
|
|
|
|
private:
|
|
sk_sp<GeometryNode> fGeometry;
|
|
sk_sp<PaintNode> fPaint;
|
|
|
|
typedef RenderNode INHERITED;
|
|
};
|
|
|
|
} // namespace sksg
|
|
|
|
#endif // SkSGDraw_DEFINED
|