2015-02-06 20:51:10 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2015 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SkSVGCanvas_DEFINED
|
|
|
|
#define SkSVGCanvas_DEFINED
|
|
|
|
|
|
|
|
#include "SkCanvas.h"
|
|
|
|
|
2017-09-19 20:12:25 +00:00
|
|
|
class SkWStream;
|
2015-02-06 20:51:10 +00:00
|
|
|
|
|
|
|
class SK_API SkSVGCanvas {
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Returns a new canvas that will generate SVG commands from its draw calls, and send
|
2019-02-14 18:42:15 +00:00
|
|
|
* them to the provided stream. Ownership of the stream is not transfered, and it must
|
|
|
|
* remain valid for the lifetime of the returned canvas.
|
2015-02-06 20:51:10 +00:00
|
|
|
*
|
|
|
|
* The canvas may buffer some drawing calls, so the output is not guaranteed to be valid
|
|
|
|
* or complete until the canvas instance is deleted.
|
|
|
|
*
|
|
|
|
* The 'bounds' parameter defines an initial SVG viewport (viewBox attribute on the root
|
|
|
|
* SVG element).
|
|
|
|
*/
|
2017-09-19 20:12:25 +00:00
|
|
|
static std::unique_ptr<SkCanvas> Make(const SkRect& bounds, SkWStream*);
|
2015-02-06 20:51:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|