blob: e0abff8f68388324128cbe15bfebfc4d49540bc2 [file] [log] [blame]
epoger@google.comec3ed6a2011-07-28 14:26:00 +00001
vandebo@chromium.orgda912d62011-03-08 18:31:02 +00002/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00003 * Copyright 2011 Google Inc.
vandebo@chromium.orgda912d62011-03-08 18:31:02 +00004 *
epoger@google.comec3ed6a2011-07-28 14:26:00 +00005 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
vandebo@chromium.orgda912d62011-03-08 18:31:02 +00007 */
8
epoger@google.comec3ed6a2011-07-28 14:26:00 +00009
vandebo@chromium.orgda912d62011-03-08 18:31:02 +000010#ifndef SkPDFShader_DEFINED
11#define SkPDFShader_DEFINED
12
13#include "SkPDFStream.h"
14#include "SkPDFTypes.h"
15#include "SkMatrix.h"
16#include "SkRefCnt.h"
17#include "SkShader.h"
18
19class SkObjRef;
20class SkPDFCatalog;
21
22/** \class SkPDFShader
23
24 In PDF parlance, this is a pattern, used in place of a color when the
25 pattern color space is selected.
26*/
27
vandebo@chromium.org421d6442011-07-20 17:39:01 +000028class SkPDFShader {
vandebo@chromium.orgda912d62011-03-08 18:31:02 +000029public:
vandebo@chromium.orgda912d62011-03-08 18:31:02 +000030 /** Get the PDF shader for the passed SkShader. If the SkShader is
31 * invalid in some way, returns NULL. The reference count of
32 * the object is incremented and it is the caller's responsibility to
33 * unreference it when done. This is needed to accommodate the weak
34 * reference pattern used when the returned object is new and has no
35 * other references.
fmalitac3796c72015-01-13 08:06:11 -080036 * @param shader The SkShader to emulate.
37 * @param matrix The current transform. (PDF shaders are absolutely
38 * positioned, relative to where the page is drawn.)
39 * @param surfceBBox The bounding box of the drawing surface (with matrix
40 * already applied).
41 * @param rasterScale Additional scale to be applied for early rasterization.
vandebo@chromium.orgda912d62011-03-08 18:31:02 +000042 */
vandebo@chromium.org421d6442011-07-20 17:39:01 +000043 static SkPDFObject* GetPDFShader(const SkShader& shader,
vandebo@chromium.orgda912d62011-03-08 18:31:02 +000044 const SkMatrix& matrix,
fmalitac3796c72015-01-13 08:06:11 -080045 const SkIRect& surfaceBBox,
46 SkScalar rasterScale);
vandebo@chromium.orgda912d62011-03-08 18:31:02 +000047
vandebo@chromium.org421d6442011-07-20 17:39:01 +000048 class State;
halcanaryfb62b3d2015-01-21 09:59:14 -080049 bool equals(const SkPDFShader::State&) const;
vandebo@chromium.orgda912d62011-03-08 18:31:02 +000050
halcanaryfb62b3d2015-01-21 09:59:14 -080051protected:
52 SkAutoTDelete<const State> fShaderState;
commit-bot@chromium.org93a2e212013-07-23 23:16:03 +000053
54 // This is an internal method.
55 // CanonicalShadersMutex() should already be acquired.
56 // This also takes ownership of shaderState.
57 static SkPDFObject* GetPDFShaderByState(State* shaderState);
halcanaryfb62b3d2015-01-21 09:59:14 -080058 static SkPDFObject* AddToCanonIfValid(SkPDFShader*);
59 static void RemoveFromCanonIfValid(SkPDFShader*);
vandebo@chromium.orgda912d62011-03-08 18:31:02 +000060
halcanaryfb62b3d2015-01-21 09:59:14 -080061 SkPDFShader(State*);
62 virtual ~SkPDFShader();
vandebo@chromium.org386dfc02012-04-17 22:31:52 +000063
64 virtual bool isValid() = 0;
halcanaryfb62b3d2015-01-21 09:59:14 -080065 virtual SkPDFObject* toPDFObject() = 0;
vandebo@chromium.orgda912d62011-03-08 18:31:02 +000066};
67
68#endif