1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2016 Google Inc. 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard Worker #ifndef SkSVGDOM_DEFINED 9*c8dee2aaSAndroid Build Coastguard Worker #define SkSVGDOM_DEFINED 10*c8dee2aaSAndroid Build Coastguard Worker 11*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkFontMgr.h" 12*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkRefCnt.h" 13*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkSize.h" 14*c8dee2aaSAndroid Build Coastguard Worker #include "include/private/base/SkAPI.h" 15*c8dee2aaSAndroid Build Coastguard Worker #include "modules/skresources/include/SkResources.h" 16*c8dee2aaSAndroid Build Coastguard Worker #include "modules/skshaper/include/SkShaper_factory.h" 17*c8dee2aaSAndroid Build Coastguard Worker #include "modules/svg/include/SkSVGIDMapper.h" 18*c8dee2aaSAndroid Build Coastguard Worker #include "modules/svg/include/SkSVGSVG.h" 19*c8dee2aaSAndroid Build Coastguard Worker 20*c8dee2aaSAndroid Build Coastguard Worker class SkCanvas; 21*c8dee2aaSAndroid Build Coastguard Worker class SkSVGNode; 22*c8dee2aaSAndroid Build Coastguard Worker class SkStream; 23*c8dee2aaSAndroid Build Coastguard Worker struct SkSVGPresentationContext; 24*c8dee2aaSAndroid Build Coastguard Worker 25*c8dee2aaSAndroid Build Coastguard Worker class SK_API SkSVGDOM : public SkRefCnt { 26*c8dee2aaSAndroid Build Coastguard Worker public: 27*c8dee2aaSAndroid Build Coastguard Worker class Builder final { 28*c8dee2aaSAndroid Build Coastguard Worker public: 29*c8dee2aaSAndroid Build Coastguard Worker /** 30*c8dee2aaSAndroid Build Coastguard Worker * Specify a font manager for loading fonts (e.g. from the system) to render <text> 31*c8dee2aaSAndroid Build Coastguard Worker * SVG nodes. 32*c8dee2aaSAndroid Build Coastguard Worker * If this is not set, but a font is required as part of rendering, the text will 33*c8dee2aaSAndroid Build Coastguard Worker * not be displayed. 34*c8dee2aaSAndroid Build Coastguard Worker */ 35*c8dee2aaSAndroid Build Coastguard Worker Builder& setFontManager(sk_sp<SkFontMgr>); 36*c8dee2aaSAndroid Build Coastguard Worker 37*c8dee2aaSAndroid Build Coastguard Worker /** 38*c8dee2aaSAndroid Build Coastguard Worker * Specify a resource provider for loading images etc. 39*c8dee2aaSAndroid Build Coastguard Worker */ 40*c8dee2aaSAndroid Build Coastguard Worker Builder& setResourceProvider(sk_sp<skresources::ResourceProvider>); 41*c8dee2aaSAndroid Build Coastguard Worker 42*c8dee2aaSAndroid Build Coastguard Worker /** 43*c8dee2aaSAndroid Build Coastguard Worker * Specify the callbacks for dealing with shaping text. See also 44*c8dee2aaSAndroid Build Coastguard Worker * modules/skshaper/utils/FactoryHelpers.h 45*c8dee2aaSAndroid Build Coastguard Worker */ 46*c8dee2aaSAndroid Build Coastguard Worker Builder& setTextShapingFactory(sk_sp<SkShapers::Factory>); 47*c8dee2aaSAndroid Build Coastguard Worker 48*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkSVGDOM> make(SkStream&) const; 49*c8dee2aaSAndroid Build Coastguard Worker 50*c8dee2aaSAndroid Build Coastguard Worker private: 51*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkFontMgr> fFontMgr; 52*c8dee2aaSAndroid Build Coastguard Worker sk_sp<skresources::ResourceProvider> fResourceProvider; 53*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkShapers::Factory> fTextShapingFactory; 54*c8dee2aaSAndroid Build Coastguard Worker }; 55*c8dee2aaSAndroid Build Coastguard Worker MakeFromStream(SkStream & str)56*c8dee2aaSAndroid Build Coastguard Worker static sk_sp<SkSVGDOM> MakeFromStream(SkStream& str) { 57*c8dee2aaSAndroid Build Coastguard Worker return Builder().make(str); 58*c8dee2aaSAndroid Build Coastguard Worker } 59*c8dee2aaSAndroid Build Coastguard Worker 60*c8dee2aaSAndroid Build Coastguard Worker /** 61*c8dee2aaSAndroid Build Coastguard Worker * Returns the root (outermost) SVG element. 62*c8dee2aaSAndroid Build Coastguard Worker */ getRoot()63*c8dee2aaSAndroid Build Coastguard Worker SkSVGSVG* getRoot() const { return fRoot.get(); } 64*c8dee2aaSAndroid Build Coastguard Worker 65*c8dee2aaSAndroid Build Coastguard Worker /** 66*c8dee2aaSAndroid Build Coastguard Worker * Specify a "container size" for the SVG dom. 67*c8dee2aaSAndroid Build Coastguard Worker * 68*c8dee2aaSAndroid Build Coastguard Worker * This is used to resolve the initial viewport when the root SVG width/height are specified 69*c8dee2aaSAndroid Build Coastguard Worker * in relative units. 70*c8dee2aaSAndroid Build Coastguard Worker * 71*c8dee2aaSAndroid Build Coastguard Worker * If the root dimensions are in absolute units, then the container size has no effect since 72*c8dee2aaSAndroid Build Coastguard Worker * the initial viewport is fixed. 73*c8dee2aaSAndroid Build Coastguard Worker */ 74*c8dee2aaSAndroid Build Coastguard Worker void setContainerSize(const SkSize&); 75*c8dee2aaSAndroid Build Coastguard Worker 76*c8dee2aaSAndroid Build Coastguard Worker /** 77*c8dee2aaSAndroid Build Coastguard Worker * DEPRECATED: use getRoot()->intrinsicSize() to query the root element intrinsic size. 78*c8dee2aaSAndroid Build Coastguard Worker * 79*c8dee2aaSAndroid Build Coastguard Worker * Returns the SVG dom container size. 80*c8dee2aaSAndroid Build Coastguard Worker * 81*c8dee2aaSAndroid Build Coastguard Worker * If the client specified a container size via setContainerSize(), then the same size is 82*c8dee2aaSAndroid Build Coastguard Worker * returned. 83*c8dee2aaSAndroid Build Coastguard Worker * 84*c8dee2aaSAndroid Build Coastguard Worker * When unspecified by clients, this returns the intrinsic size of the root element, as defined 85*c8dee2aaSAndroid Build Coastguard Worker * by its width/height attributes. If either width or height is specified in relative units 86*c8dee2aaSAndroid Build Coastguard Worker * (e.g. "100%"), then the corresponding intrinsic size dimension is zero. 87*c8dee2aaSAndroid Build Coastguard Worker */ 88*c8dee2aaSAndroid Build Coastguard Worker const SkSize& containerSize() const; 89*c8dee2aaSAndroid Build Coastguard Worker 90*c8dee2aaSAndroid Build Coastguard Worker // Returns the node with the given id, or nullptr if not found. 91*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkSVGNode>* findNodeById(const char* id); 92*c8dee2aaSAndroid Build Coastguard Worker 93*c8dee2aaSAndroid Build Coastguard Worker void render(SkCanvas*) const; 94*c8dee2aaSAndroid Build Coastguard Worker 95*c8dee2aaSAndroid Build Coastguard Worker /** Render the node with the given id as if it were the only child of the root. */ 96*c8dee2aaSAndroid Build Coastguard Worker void renderNode(SkCanvas*, SkSVGPresentationContext&, const char* id) const; 97*c8dee2aaSAndroid Build Coastguard Worker 98*c8dee2aaSAndroid Build Coastguard Worker private: 99*c8dee2aaSAndroid Build Coastguard Worker SkSVGDOM(sk_sp<SkSVGSVG>, 100*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkFontMgr>, 101*c8dee2aaSAndroid Build Coastguard Worker sk_sp<skresources::ResourceProvider>, 102*c8dee2aaSAndroid Build Coastguard Worker SkSVGIDMapper&&, 103*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkShapers::Factory>); 104*c8dee2aaSAndroid Build Coastguard Worker 105*c8dee2aaSAndroid Build Coastguard Worker const sk_sp<SkSVGSVG> fRoot; 106*c8dee2aaSAndroid Build Coastguard Worker const sk_sp<SkFontMgr> fFontMgr; 107*c8dee2aaSAndroid Build Coastguard Worker const sk_sp<SkShapers::Factory> fTextShapingFactory; 108*c8dee2aaSAndroid Build Coastguard Worker const sk_sp<skresources::ResourceProvider> fResourceProvider; 109*c8dee2aaSAndroid Build Coastguard Worker const SkSVGIDMapper fIDMapper; 110*c8dee2aaSAndroid Build Coastguard Worker SkSize fContainerSize; 111*c8dee2aaSAndroid Build Coastguard Worker }; 112*c8dee2aaSAndroid Build Coastguard Worker 113*c8dee2aaSAndroid Build Coastguard Worker #endif // SkSVGDOM_DEFINED 114