blob: 5efd6f0b9fccd82243023cd16bc2051f820fb84a [file] [log] [blame]
scroggo@google.com72c96722012-06-06 21:07:10 +00001/*
2 * Copyright 2012 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#include "SkBitmap.h"
scroggo@google.com58b4ead2012-08-31 16:15:22 +00009#include "SkChunkAlloc.h"
scroggo@google.com72c96722012-06-06 21:07:10 +000010#include "SkGPipe.h"
scroggo@google.com58b4ead2012-08-31 16:15:22 +000011#include "SkTDArray.h"
scroggo@google.com72c96722012-06-06 21:07:10 +000012
13class SkCanvas;
scroggo@google.comb073d922012-06-08 15:35:03 +000014class SkMatrix;
scroggo@google.com72c96722012-06-06 21:07:10 +000015
16class PipeController : public SkGPipeController {
17public:
18 PipeController(SkCanvas* target);
19 virtual ~PipeController();
20 virtual void* requestBlock(size_t minRequest, size_t* actual) SK_OVERRIDE;
21 virtual void notifyWritten(size_t bytes) SK_OVERRIDE;
22protected:
23 const void* getData() { return (const char*) fBlock + fBytesWritten; }
24 SkGPipeReader fReader;
25private:
26 void* fBlock;
27 size_t fBlockSize;
28 size_t fBytesWritten;
29 SkGPipeReader::Status fStatus;
30};
31
32////////////////////////////////////////////////////////////////////////////////
33
34class TiledPipeController : public PipeController {
35public:
scroggo@google.comb073d922012-06-08 15:35:03 +000036 TiledPipeController(const SkBitmap&, const SkMatrix* initialMatrix = NULL);
scroggo@google.com72c96722012-06-06 21:07:10 +000037 virtual ~TiledPipeController() {};
38 virtual void notifyWritten(size_t bytes) SK_OVERRIDE;
scroggo@google.com284bf502012-07-17 16:10:34 +000039 virtual int numberOfReaders() const SK_OVERRIDE { return NumberOfTiles; }
scroggo@google.com72c96722012-06-06 21:07:10 +000040private:
41 enum {
42 NumberOfTiles = 10
43 };
44 SkGPipeReader fReaders[NumberOfTiles - 1];
45 SkBitmap fBitmaps[NumberOfTiles];
46 typedef PipeController INHERITED;
47};
scroggo@google.com58b4ead2012-08-31 16:15:22 +000048
49////////////////////////////////////////////////////////////////////////////////
50
51/**
52 * Borrowed (and modified) from SkDeferredCanvas.cpp::DeferredPipeController.
scroggo@google.com8e073ba2012-08-31 16:25:46 +000053 * Allows playing back from multiple threads, but does not do the threading itself.
scroggo@google.com58b4ead2012-08-31 16:15:22 +000054 */
scroggo@google.com8e073ba2012-08-31 16:25:46 +000055class ThreadSafePipeController : public SkGPipeController {
scroggo@google.com58b4ead2012-08-31 16:15:22 +000056public:
scroggo@google.com8e073ba2012-08-31 16:25:46 +000057 ThreadSafePipeController(int numberOfReaders);
scroggo@google.com58b4ead2012-08-31 16:15:22 +000058 virtual void* requestBlock(size_t minRequest, size_t* actual) SK_OVERRIDE;
59 virtual void notifyWritten(size_t bytes) SK_OVERRIDE;
60 virtual int numberOfReaders() const SK_OVERRIDE { return fNumberOfReaders; }
61
62 /**
63 * Play the stored drawing commands to the specified canvas. If SkGPipeWriter::startRecording
64 * used the flag SkGPipeWriter::kSimultaneousReaders_Flag, this can be called from different
65 * threads simultaneously.
66 */
scroggo@google.combcdf2ec2012-09-20 14:42:33 +000067 void draw(SkCanvas*);
scroggo@google.com58b4ead2012-08-31 16:15:22 +000068private:
69 enum {
70 kMinBlockSize = 4096
71 };
72 struct PipeBlock {
73 PipeBlock(void* block, size_t bytes) { fBlock = block, fBytes = bytes; }
74 // Stream of draw commands written by the SkGPipeWriter. Allocated by fAllocator, which will
75 // handle freeing it.
76 void* fBlock;
77 // Number of bytes that were written to fBlock.
78 size_t fBytes;
79 };
80 void* fBlock;
81 size_t fBytesWritten;
82 SkChunkAlloc fAllocator;
83 SkTDArray<PipeBlock> fBlockList;
84 int fNumberOfReaders;
85};