blob: d4c38ea01773a7701095113084b47dbaa69ea2fc [file] [log] [blame]
* 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 "include/core/SkTypes.h"
#include <cstdint>
#include <memory>
class SkCanvas;
class SkWStream;
struct SkRect;
class SK_API SkSVGCanvas {
enum {
kConvertTextToPaths_Flag = 0x01, // emit text as <path>s
kNoPrettyXML_Flag = 0x02, // suppress newlines and tabs in output
kRelativePathEncoding_Flag = 0x04, // use relative commands for path encoding
* Returns a new canvas that will generate SVG commands from its draw calls, and send
* them to the provided stream. Ownership of the stream is not transfered, and it must
* remain valid for the lifetime of the returned canvas.
* 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).
static std::unique_ptr<SkCanvas> Make(const SkRect& bounds, SkWStream*, uint32_t flags = 0);