1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
|
/*
* 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 {
public:
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);
};
#endif
|