1 /* 2 * Copyright 2008 The Android Open Source Project 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 9 #ifndef SkMallocPixelRef_DEFINED 10 #define SkMallocPixelRef_DEFINED 11 12 #include "SkPixelRef.h" 13 14 /** We explicitly use the same allocator for our pixels that SkMask does, 15 so that we can freely assign memory allocated by one class to the other. 16 */ 17 class SK_API SkMallocPixelRef : public SkPixelRef { 18 public: 19 /** 20 * Return a new SkMallocPixelRef with the provided pixel storage, rowBytes, 21 * and optional colortable. The caller is responsible for managing the 22 * lifetime of the pixel storage buffer, as this pixelref will not try 23 * to delete it. 24 * 25 * The pixelref will ref() the colortable (if not NULL). 26 * 27 * Returns NULL on failure. 28 */ 29 static SkMallocPixelRef* NewDirect(const SkImageInfo&, void* addr, 30 size_t rowBytes, SkColorTable*); 31 32 /** 33 * Return a new SkMallocPixelRef, automatically allocating storage for the 34 * pixels. If rowBytes are 0, an optimal value will be chosen automatically. 35 * If rowBytes is > 0, then it will be respected, or NULL will be returned 36 * if rowBytes is invalid for the specified info. 37 * 38 * This pixelref will ref() the specified colortable (if not NULL). 39 * 40 * Returns NULL on failure. 41 */ 42 static SkMallocPixelRef* NewAllocate(const SkImageInfo& info, 43 size_t rowBytes, SkColorTable*); 44 45 /** 46 * Identical to NewAllocate, except all pixel bytes are zeroed. 47 */ 48 static SkMallocPixelRef* NewZeroed(const SkImageInfo& info, 49 size_t rowBytes, SkColorTable*); 50 51 /** 52 * Return a new SkMallocPixelRef with the provided pixel storage, 53 * rowBytes, and optional colortable. On destruction, ReleaseProc 54 * will be called. 55 * 56 * This pixelref will ref() the specified colortable (if not NULL). 57 * 58 * If ReleaseProc is NULL, the pixels will never be released. This 59 * can be useful if the pixels were stack allocated. However, such an 60 * SkMallocPixelRef must not live beyond its pixels (e.g. by copying 61 * an SkBitmap pointing to it, or drawing to an SkPicture). 62 * 63 * Returns NULL on failure. 64 */ 65 typedef void (*ReleaseProc)(void* addr, void* context); 66 static SkMallocPixelRef* NewWithProc(const SkImageInfo& info, 67 size_t rowBytes, SkColorTable*, 68 void* addr, ReleaseProc proc, 69 void* context); 70 71 /** 72 * Return a new SkMallocPixelRef that will use the provided 73 * SkData, rowBytes, and optional colortable as pixel storage. 74 * The SkData will be ref()ed and on destruction of the PielRef, 75 * the SkData will be unref()ed. 76 * 77 * This pixelref will ref() the specified colortable (if not NULL). 78 * 79 * Returns NULL on failure. 80 */ 81 static SkMallocPixelRef* NewWithData(const SkImageInfo& info, 82 size_t rowBytes, 83 SkColorTable* ctable, 84 SkData* data); 85 getAddr()86 void* getAddr() const { return fStorage; } 87 88 class PRFactory : public SkPixelRefFactory { 89 public: 90 SkPixelRef* create(const SkImageInfo&, size_t rowBytes, SkColorTable*) override; 91 }; 92 93 class ZeroedPRFactory : public SkPixelRefFactory { 94 public: 95 SkPixelRef* create(const SkImageInfo&, size_t rowBytes, SkColorTable*) override; 96 }; 97 98 protected: 99 // The ownPixels version of this constructor is deprecated. 100 SkMallocPixelRef(const SkImageInfo&, void* addr, size_t rb, SkColorTable*, 101 bool ownPixels); 102 ~SkMallocPixelRef() override; 103 104 bool onNewLockPixels(LockRec*) override; 105 void onUnlockPixels() override; 106 size_t getAllocatedSizeInBytes() const override; 107 108 private: 109 // Uses alloc to implement NewAllocate or NewZeroed. 110 static SkMallocPixelRef* NewUsing(void*(*alloc)(size_t), 111 const SkImageInfo&, 112 size_t rowBytes, 113 SkColorTable*); 114 115 void* fStorage; 116 SkColorTable* fCTable; 117 size_t fRB; 118 ReleaseProc fReleaseProc; 119 void* fReleaseProcContext; 120 121 SkMallocPixelRef(const SkImageInfo&, void* addr, size_t rb, SkColorTable*, 122 ReleaseProc proc, void* context); 123 124 typedef SkPixelRef INHERITED; 125 }; 126 127 128 #endif 129