blob: 19bef2103811e5d70daf70415cf6222c07c54efe [file] [log] [blame]
epoger@google.comec3ed6a2011-07-28 14:26:00 +00001
reed@google.comac10a2d2010-12-22 21:39:39 +00002/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00003 * Copyright 2010 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
reed@google.comac10a2d2010-12-22 21:39:39 +00007 */
8
reed@google.comac10a2d2010-12-22 21:39:39 +00009#ifndef SkGpuDevice_DEFINED
10#define SkGpuDevice_DEFINED
11
12#include "SkGr.h"
reed@google.comaf951c92011-06-16 19:10:39 +000013#include "SkBitmap.h"
reed89443ab2014-06-27 11:34:19 -070014#include "SkDevice.h"
commit-bot@chromium.org145d1c02014-03-16 19:46:36 +000015#include "SkPicture.h"
reed@google.comac10a2d2010-12-22 21:39:39 +000016#include "SkRegion.h"
bsalomonafe30052015-01-16 07:32:33 -080017#include "SkSurface.h"
joshualitt06dd0a82016-01-08 06:32:31 -080018#include "GrDrawContext.h"
bsalomon@google.com50398bf2011-07-26 20:45:30 +000019#include "GrContext.h"
bsalomonafbf2d62014-09-30 12:18:44 -070020#include "GrSurfacePriv.h"
reed@google.comac10a2d2010-12-22 21:39:39 +000021
robertphillips64bf7672014-08-21 13:07:35 -070022class GrAccelData;
bsalomonb1b01992015-11-18 10:56:08 -080023class GrTextureProducer;
robertphillips64bf7672014-08-21 13:07:35 -070024struct GrCachedLayer;
commit-bot@chromium.orgddf2bfb2014-01-30 16:41:23 +000025
reed@google.comac10a2d2010-12-22 21:39:39 +000026/**
reed89443ab2014-06-27 11:34:19 -070027 * Subclass of SkBaseDevice, which directs all drawing to the GrGpu owned by the
reed@google.comac10a2d2010-12-22 21:39:39 +000028 * canvas.
29 */
reed89443ab2014-06-27 11:34:19 -070030class SK_API SkGpuDevice : public SkBaseDevice {
reed@google.comac10a2d2010-12-22 21:39:39 +000031public:
bsalomon74f681d2015-06-23 14:38:48 -070032 enum InitContents {
33 kClear_InitContents,
34 kUninit_InitContents
commit-bot@chromium.orgd8a57af2014-03-19 21:19:16 +000035 };
bsalomon@google.com123ac1d2013-03-28 19:18:12 +000036
37 /**
bsalomonafe30052015-01-16 07:32:33 -080038 * Creates an SkGpuDevice from a GrRenderTarget.
bsalomon@google.com123ac1d2013-03-28 19:18:12 +000039 */
bsalomon74f681d2015-06-23 14:38:48 -070040 static SkGpuDevice* Create(GrRenderTarget* target, const SkSurfaceProps*, InitContents);
bsalomon@google.com123ac1d2013-03-28 19:18:12 +000041
bsalomon@google.com2e7b43d2011-01-18 20:57:22 +000042 /**
senorblancod0d37ca2015-04-02 04:54:56 -070043 * Creates an SkGpuDevice from a GrRenderTarget whose texture width/height is
44 * different than its actual width/height (e.g., approx-match scratch texture).
45 */
46 static SkGpuDevice* Create(GrRenderTarget* target, int width, int height,
bsalomon74f681d2015-06-23 14:38:48 -070047 const SkSurfaceProps*, InitContents);
senorblancod0d37ca2015-04-02 04:54:56 -070048
49 /**
bsalomonafe30052015-01-16 07:32:33 -080050 * New device that will create an offscreen renderTarget based on the ImageInfo and
51 * sampleCount. The Budgeted param controls whether the device's backing store counts against
halcanary96fcdcc2015-08-27 07:41:13 -070052 * the resource cache budget. On failure, returns nullptr.
commit-bot@chromium.org15a14052014-02-16 00:59:25 +000053 */
bsalomonafe30052015-01-16 07:32:33 -080054 static SkGpuDevice* Create(GrContext*, SkSurface::Budgeted, const SkImageInfo&,
bsalomon74f681d2015-06-23 14:38:48 -070055 int sampleCount, const SkSurfaceProps*, InitContents);
commit-bot@chromium.org15a14052014-02-16 00:59:25 +000056
joshualitt06dd0a82016-01-08 06:32:31 -080057 ~SkGpuDevice() override {}
reed@google.com7b201d22011-01-11 18:59:23 +000058
reedb2db8982014-11-13 12:41:02 -080059 SkGpuDevice* cloneDevice(const SkSurfaceProps& props) {
reed76033be2015-03-14 10:54:31 -070060 SkBaseDevice* dev = this->onCreateDevice(CreateInfo(this->imageInfo(), kPossible_TileUsage,
61 props.pixelGeometry()),
halcanary96fcdcc2015-08-27 07:41:13 -070062 nullptr);
reedb2db8982014-11-13 12:41:02 -080063 return static_cast<SkGpuDevice*>(dev);
64 }
65
joshualitt5f5a8d72015-02-25 14:09:45 -080066 GrContext* context() const { return fContext; }
reed@google.comac10a2d2010-12-22 21:39:39 +000067
reed8eddfb52014-12-04 07:50:14 -080068 // set all pixels to 0
69 void clearAll();
70
kkinnunenabcfab42015-02-22 22:53:44 -080071 void replaceRenderTarget(bool shouldRetainContent);
72
mtklein36352bf2015-03-25 18:17:31 -070073 GrRenderTarget* accessRenderTarget() override;
reed@google.comac10a2d2010-12-22 21:39:39 +000074
mtklein36352bf2015-03-25 18:17:31 -070075 SkImageInfo imageInfo() const override {
senorblancod0d37ca2015-04-02 04:54:56 -070076 return fLegacyBitmap.info();
robertphillips@google.com07f81a52013-09-17 12:26:23 +000077 }
reed@google.comac10a2d2010-12-22 21:39:39 +000078
mtklein36352bf2015-03-25 18:17:31 -070079 void drawPaint(const SkDraw&, const SkPaint& paint) override;
reed@google.comac10a2d2010-12-22 21:39:39 +000080 virtual void drawPoints(const SkDraw&, SkCanvas::PointMode mode, size_t count,
mtklein36352bf2015-03-25 18:17:31 -070081 const SkPoint[], const SkPaint& paint) override;
reed@google.comac10a2d2010-12-22 21:39:39 +000082 virtual void drawRect(const SkDraw&, const SkRect& r,
mtklein36352bf2015-03-25 18:17:31 -070083 const SkPaint& paint) override;
commit-bot@chromium.orgf2bfd542013-04-25 15:27:00 +000084 virtual void drawRRect(const SkDraw&, const SkRRect& r,
mtklein36352bf2015-03-25 18:17:31 -070085 const SkPaint& paint) override;
commit-bot@chromium.org0a09d712014-04-09 21:26:11 +000086 virtual void drawDRRect(const SkDraw& draw, const SkRRect& outer,
mtklein36352bf2015-03-25 18:17:31 -070087 const SkRRect& inner, const SkPaint& paint) override;
jvanverth@google.com46d3d392013-01-22 13:34:01 +000088 virtual void drawOval(const SkDraw&, const SkRect& oval,
mtklein36352bf2015-03-25 18:17:31 -070089 const SkPaint& paint) override;
reed@google.comac10a2d2010-12-22 21:39:39 +000090 virtual void drawPath(const SkDraw&, const SkPath& path,
91 const SkPaint& paint, const SkMatrix* prePathMatrix,
mtklein36352bf2015-03-25 18:17:31 -070092 bool pathIsMutable) override;
reed@google.comac10a2d2010-12-22 21:39:39 +000093 virtual void drawBitmap(const SkDraw&, const SkBitmap& bitmap,
mtklein36352bf2015-03-25 18:17:31 -070094 const SkMatrix&, const SkPaint&) override;
reed@google.com33535f32012-09-25 15:37:50 +000095 virtual void drawBitmapRect(const SkDraw&, const SkBitmap&,
96 const SkRect* srcOrNull, const SkRect& dst,
reed562fe472015-07-28 07:35:14 -070097 const SkPaint& paint, SkCanvas::SrcRectConstraint) override;
reed@google.comac10a2d2010-12-22 21:39:39 +000098 virtual void drawSprite(const SkDraw&, const SkBitmap& bitmap,
mtklein36352bf2015-03-25 18:17:31 -070099 int x, int y, const SkPaint& paint) override;
reed@google.comac10a2d2010-12-22 21:39:39 +0000100 virtual void drawText(const SkDraw&, const void* text, size_t len,
mtklein36352bf2015-03-25 18:17:31 -0700101 SkScalar x, SkScalar y, const SkPaint&) override;
reed@google.comac10a2d2010-12-22 21:39:39 +0000102 virtual void drawPosText(const SkDraw&, const void* text, size_t len,
fmalita05c4a432014-09-29 06:29:53 -0700103 const SkScalar pos[], int scalarsPerPos,
mtklein36352bf2015-03-25 18:17:31 -0700104 const SkPoint& offset, const SkPaint&) override;
joshualitt9c328182015-03-23 08:13:04 -0700105 virtual void drawTextBlob(const SkDraw&, const SkTextBlob*, SkScalar x, SkScalar y,
mtklein36352bf2015-03-25 18:17:31 -0700106 const SkPaint& paint, SkDrawFilter* drawFilter) override;
reed@google.comac10a2d2010-12-22 21:39:39 +0000107 virtual void drawVertices(const SkDraw&, SkCanvas::VertexMode, int vertexCount,
108 const SkPoint verts[], const SkPoint texs[],
109 const SkColor colors[], SkXfermode* xmode,
110 const uint16_t indices[], int indexCount,
mtklein36352bf2015-03-25 18:17:31 -0700111 const SkPaint&) override;
reedca109532015-06-25 16:25:25 -0700112 void drawAtlas(const SkDraw&, const SkImage* atlas, const SkRSXform[], const SkRect[],
113 const SkColor[], int count, SkXfermode::Mode, const SkPaint&) override;
robertphillips@google.com1f2f3382013-08-29 11:54:56 +0000114 virtual void drawDevice(const SkDraw&, SkBaseDevice*, int x, int y,
mtklein36352bf2015-03-25 18:17:31 -0700115 const SkPaint&) override;
reeda85d4d02015-05-06 12:56:48 -0700116 void drawImage(const SkDraw&, const SkImage*, SkScalar x, SkScalar y, const SkPaint&) override;
117 void drawImageRect(const SkDraw&, const SkImage*, const SkRect* src, const SkRect& dst,
reeda5517e22015-07-14 10:54:12 -0700118 const SkPaint&, SkCanvas::SrcRectConstraint) override;
reed@google.com7b201d22011-01-11 18:59:23 +0000119
joshualitt33a5fce2015-11-18 13:28:51 -0800120 void drawImageNine(const SkDraw& draw, const SkImage* image, const SkIRect& center,
121 const SkRect& dst, const SkPaint& paint) override;
122 void drawBitmapNine(const SkDraw& draw, const SkBitmap& bitmap, const SkIRect& center,
123 const SkRect& dst, const SkPaint& paint) override;
124
mtklein36352bf2015-03-25 18:17:31 -0700125 void flush() override;
reed@google.com7b201d22011-01-11 18:59:23 +0000126
mtklein36352bf2015-03-25 18:17:31 -0700127 void onAttachToCanvas(SkCanvas* canvas) override;
128 void onDetachFromCanvas() override;
robertphillips@google.com40a1ae42012-07-13 15:36:15 +0000129
mtklein36352bf2015-03-25 18:17:31 -0700130 const SkBitmap& onAccessBitmap() override;
reed41e010c2015-06-09 12:16:53 -0700131 bool onAccessPixels(SkPixmap*) override;
senorblanco@chromium.orgb7b7eb32014-03-19 18:24:04 +0000132
mtklein36352bf2015-03-25 18:17:31 -0700133 bool canHandleImageFilter(const SkImageFilter*) override;
senorblanco@chromium.org4cb543d2014-03-14 15:44:01 +0000134 virtual bool filterImage(const SkImageFilter*, const SkBitmap&,
135 const SkImageFilter::Context&,
mtklein36352bf2015-03-25 18:17:31 -0700136 SkBitmap*, SkIPoint*) override;
vandebo@chromium.org74b46192012-01-28 01:45:11 +0000137
senorblancod0d37ca2015-04-02 04:54:56 -0700138 bool filterTexture(GrContext*, GrTexture*, int width, int height, const SkImageFilter*,
robertphillips7b9e8a42014-12-11 08:20:31 -0800139 const SkImageFilter::Context&,
140 SkBitmap* result, SkIPoint* offset);
141
reed13ccbf82015-10-20 09:56:52 -0700142 static SkImageFilter::Cache* NewImageFilterCache();
143
jvanverth0671b962015-12-08 18:53:44 -0800144 // for debugging purposes only
145 void drawTexture(GrTexture*, const SkRect& dst, const SkPaint&);
146
reed@google.comac10a2d2010-12-22 21:39:39 +0000147protected:
mtklein36352bf2015-03-25 18:17:31 -0700148 bool onReadPixels(const SkImageInfo&, void*, size_t, int, int) override;
149 bool onWritePixels(const SkImageInfo&, const void*, size_t, int, int) override;
robertphillips9c240a12015-05-28 07:45:59 -0700150 bool onShouldDisableLCD(const SkPaint&) const final;
bsalomon@google.comc6980972011-11-02 19:57:21 +0000151
commit-bot@chromium.org145d1c02014-03-16 19:46:36 +0000152 /** PRIVATE / EXPERIMENTAL -- do not call */
reedd5fa1a42014-08-09 11:08:05 -0700153 virtual bool EXPERIMENTAL_drawPicture(SkCanvas* canvas, const SkPicture* picture,
mtklein36352bf2015-03-25 18:17:31 -0700154 const SkMatrix*, const SkPaint*) override;
commit-bot@chromium.org145d1c02014-03-16 19:46:36 +0000155
reed@google.comac10a2d2010-12-22 21:39:39 +0000156private:
joshualitt06dd0a82016-01-08 06:32:31 -0800157 // We want these unreffed in DrawContext, RenderTarget, GrContext order.
158 SkAutoTUnref<GrContext> fContext;
159 SkAutoTUnref<GrRenderTarget> fRenderTarget;
160 SkAutoTUnref<GrDrawContext> fDrawContext;
161
joshualitt44701df2015-02-23 14:44:57 -0800162 SkAutoTUnref<const SkClipStack> fClipStack;
163 SkIPoint fClipOrigin;
joshualitt06dd0a82016-01-08 06:32:31 -0800164 GrClip fClip;;
reed89443ab2014-06-27 11:34:19 -0700165 // remove when our clients don't rely on accessBitmap()
joshualitt44701df2015-02-23 14:44:57 -0800166 SkBitmap fLegacyBitmap;
167 bool fNeedClear;
bsalomon74f681d2015-06-23 14:38:48 -0700168 bool fOpaque;
169
170 enum Flags {
171 kNeedClear_Flag = 1 << 0, //!< Surface requires an initial clear
172 kIsOpaque_Flag = 1 << 1, //!< Hint from client that rendering to this device will be
173 // opaque even if the config supports alpha.
174 };
175 static bool CheckAlphaTypeAndGetFlags(const SkImageInfo* info, InitContents init,
176 unsigned* flags);
reed89443ab2014-06-27 11:34:19 -0700177
senorblancod0d37ca2015-04-02 04:54:56 -0700178 SkGpuDevice(GrRenderTarget*, int width, int height, const SkSurfaceProps*, unsigned flags);
bsalomon@google.com06cd7322012-03-30 18:45:35 +0000179
mtklein36352bf2015-03-25 18:17:31 -0700180 SkBaseDevice* onCreateDevice(const CreateInfo&, const SkPaint*) override;
bsalomon@google.come97f0852011-06-17 13:10:25 +0000181
mtklein36352bf2015-03-25 18:17:31 -0700182 SkSurface* newSurface(const SkImageInfo&, const SkSurfaceProps&) override;
reed@google.com76f10a32014-02-05 15:32:21 +0000183
mtklein36352bf2015-03-25 18:17:31 -0700184 SkImageFilter::Cache* getImageFilterCache() override;
reed841010f2014-09-10 07:23:32 -0700185
mtklein36352bf2015-03-25 18:17:31 -0700186 bool forceConservativeRasterClip() const override { return true; }
senorblanco55b6d8b2014-07-30 11:26:46 -0700187
joshualitt5531d512014-12-17 15:50:11 -0800188 // sets the render target and clip on context
189 void prepareDraw(const SkDraw&);
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000190
191 /**
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000192 * Helper functions called by drawBitmapCommon. By the time these are called the SkDraw's
commit-bot@chromium.org7edad872013-10-25 14:58:12 +0000193 * matrix, clip, and the device's render target has already been set on GrContext.
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000194 */
commit-bot@chromium.org7edad872013-10-25 14:58:12 +0000195
196 // The tileSize and clippedSrcRect will be valid only if true is returned.
reed85d91782015-09-10 14:33:38 -0700197 bool shouldTileImageID(uint32_t imageID, const SkIRect& imageRect,
198 const SkMatrix& viewMatrix,
199 const GrTextureParams& params,
200 const SkRect* srcRectPtr,
201 int maxTileSize,
202 int* tileSize,
203 SkIRect* clippedSubset) const;
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000204 bool shouldTileBitmap(const SkBitmap& bitmap,
joshualitt5531d512014-12-17 15:50:11 -0800205 const SkMatrix& viewMatrix,
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000206 const GrTextureParams& sampler,
bsalomon@google.comaf562b42013-10-24 17:52:07 +0000207 const SkRect* srcRectPtr,
208 int maxTileSize,
commit-bot@chromium.org7edad872013-10-25 14:58:12 +0000209 int* tileSize,
210 SkIRect* clippedSrcRect) const;
reed85d91782015-09-10 14:33:38 -0700211 // Just returns the predicate, not the out-tileSize or out-clippedSubset, as they are not
212 // needed at the moment.
213 bool shouldTileImage(const SkImage* image, const SkRect* srcRectPtr,
214 SkCanvas::SrcRectConstraint constraint, SkFilterQuality quality,
215 const SkMatrix& viewMatrix) const;
216
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000217 void internalDrawBitmap(const SkBitmap&,
joshualitt5531d512014-12-17 15:50:11 -0800218 const SkMatrix& viewMatrix,
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000219 const SkRect&,
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000220 const GrTextureParams& params,
commit-bot@chromium.orgeed779d2013-08-16 10:24:37 +0000221 const SkPaint& paint,
reeda5517e22015-07-14 10:54:12 -0700222 SkCanvas::SrcRectConstraint,
commit-bot@chromium.orga17773f2014-05-09 13:53:38 +0000223 bool bicubic,
224 bool needsTextureDomain);
bsalomonc55271f2015-11-09 11:55:57 -0800225
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000226 void drawTiledBitmap(const SkBitmap& bitmap,
joshualitt5531d512014-12-17 15:50:11 -0800227 const SkMatrix& viewMatrix,
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000228 const SkRect& srcRect,
commit-bot@chromium.org7edad872013-10-25 14:58:12 +0000229 const SkIRect& clippedSrcRect,
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000230 const GrTextureParams& params,
commit-bot@chromium.orgeed779d2013-08-16 10:24:37 +0000231 const SkPaint& paint,
reeda5517e22015-07-14 10:54:12 -0700232 SkCanvas::SrcRectConstraint,
commit-bot@chromium.orgdec61502013-12-02 22:22:35 +0000233 int tileSize,
234 bool bicubic);
bsalomon@google.com3ab43d52012-10-11 19:39:09 +0000235
bsalomonb1b01992015-11-18 10:56:08 -0800236 void drawTextureProducer(GrTextureProducer*,
bsalomonc55271f2015-11-09 11:55:57 -0800237 const SkRect* srcRect,
238 const SkRect* dstRect,
bsalomonb1b01992015-11-18 10:56:08 -0800239 SkCanvas::SrcRectConstraint,
bsalomonc55271f2015-11-09 11:55:57 -0800240 const SkMatrix& viewMatrix,
bsalomonb1b01992015-11-18 10:56:08 -0800241 const GrClip&,
242 const SkPaint&);
bsalomonc55271f2015-11-09 11:55:57 -0800243
bsalomonb1b01992015-11-18 10:56:08 -0800244 void drawTextureProducerImpl(GrTextureProducer*,
bsalomonc55271f2015-11-09 11:55:57 -0800245 const SkRect& clippedSrcRect,
246 const SkRect& clippedDstRect,
bsalomonb1b01992015-11-18 10:56:08 -0800247 SkCanvas::SrcRectConstraint,
bsalomonc55271f2015-11-09 11:55:57 -0800248 const SkMatrix& viewMatrix,
249 const SkMatrix& srcToDstMatrix,
bsalomonb1b01992015-11-18 10:56:08 -0800250 const GrClip&,
251 const SkPaint&);
bsalomonc55271f2015-11-09 11:55:57 -0800252
bsalomonf1ecd212015-12-09 17:06:02 -0800253 void drawProducerNine(const SkDraw&, GrTextureProducer*, const SkIRect& center,
254 const SkRect& dst, const SkPaint&);
bsalomon2bbd0c62015-12-09 12:50:56 -0800255
commit-bot@chromium.org628ed0b2014-05-19 14:32:49 +0000256 bool drawDashLine(const SkPoint pts[2], const SkPaint& paint);
257
kkinnunenabcfab42015-02-22 22:53:44 -0800258 static GrRenderTarget* CreateRenderTarget(GrContext*, SkSurface::Budgeted, const SkImageInfo&,
259 int sampleCount);
260
joshualittdbd35932015-04-02 09:19:04 -0700261 friend class GrAtlasTextContext;
robertphillips7b05ff12015-06-19 14:14:54 -0700262 friend class SkSurface_Gpu; // for access to surfaceProps
reed89443ab2014-06-27 11:34:19 -0700263 typedef SkBaseDevice INHERITED;
reed@google.comac10a2d2010-12-22 21:39:39 +0000264};
265
266#endif