2008-12-17 15:59:43 +00:00
|
|
|
/*
|
2011-07-28 14:26:00 +00:00
|
|
|
* Copyright 2008 The Android Open Source Project
|
2008-12-17 15:59:43 +00:00
|
|
|
*
|
2011-07-28 14:26:00 +00:00
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
2008-12-17 15:59:43 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SkPixelRef_DEFINED
|
|
|
|
#define SkPixelRef_DEFINED
|
|
|
|
|
2019-04-23 17:05:21 +00:00
|
|
|
#include "include/core/SkBitmap.h"
|
|
|
|
#include "include/core/SkImageInfo.h"
|
|
|
|
#include "include/core/SkPixmap.h"
|
|
|
|
#include "include/core/SkRefCnt.h"
|
|
|
|
#include "include/core/SkSize.h"
|
2020-03-02 21:59:40 +00:00
|
|
|
#include "include/private/SkIDChangeListener.h"
|
2019-04-23 17:05:21 +00:00
|
|
|
#include "include/private/SkMutex.h"
|
|
|
|
#include "include/private/SkTDArray.h"
|
2018-09-19 14:28:59 +00:00
|
|
|
|
2018-08-09 16:23:19 +00:00
|
|
|
#include <atomic>
|
2008-12-17 15:59:43 +00:00
|
|
|
|
2011-04-01 19:05:36 +00:00
|
|
|
struct SkIRect;
|
2008-12-17 15:59:43 +00:00
|
|
|
|
2021-02-10 13:58:34 +00:00
|
|
|
class GrTexture;
|
2015-08-19 19:25:40 +00:00
|
|
|
class SkDiscardableMemory;
|
2010-09-09 16:01:26 +00:00
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
/** \class SkPixelRef
|
|
|
|
|
2017-04-13 20:02:22 +00:00
|
|
|
This class is the smart container for pixel memory, and is used with SkBitmap.
|
2008-12-17 15:59:43 +00:00
|
|
|
This class can be shared/accessed between multiple threads.
|
|
|
|
*/
|
2014-07-14 16:21:31 +00:00
|
|
|
class SK_API SkPixelRef : public SkRefCnt {
|
2008-12-17 15:59:43 +00:00
|
|
|
public:
|
2017-07-18 14:53:11 +00:00
|
|
|
SkPixelRef(int width, int height, void* addr, size_t rowBytes);
|
2017-05-01 14:22:31 +00:00
|
|
|
~SkPixelRef() override;
|
|
|
|
|
2020-03-02 21:59:40 +00:00
|
|
|
SkISize dimensions() const { return {fWidth, fHeight}; }
|
2017-05-02 15:41:30 +00:00
|
|
|
int width() const { return fWidth; }
|
|
|
|
int height() const { return fHeight; }
|
2017-04-17 15:02:51 +00:00
|
|
|
void* pixels() const { return fPixels; }
|
|
|
|
size_t rowBytes() const { return fRowBytes; }
|
2014-01-08 15:42:01 +00:00
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
/** Returns a non-zero, unique value corresponding to the pixels in this
|
|
|
|
pixelref. Each time the pixels are changed (and notifyPixelsChanged is
|
|
|
|
called), a different generation ID will be returned.
|
|
|
|
*/
|
|
|
|
uint32_t getGenerationID() const;
|
2011-02-24 18:09:46 +00:00
|
|
|
|
2014-01-27 15:41:07 +00:00
|
|
|
/**
|
|
|
|
* Call this if you have changed the contents of the pixels. This will in-
|
|
|
|
* turn cause a different generation ID value to be returned from
|
|
|
|
* getGenerationID().
|
|
|
|
*/
|
2014-01-28 16:05:39 +00:00
|
|
|
void notifyPixelsChanged();
|
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
/** Returns true if this pixelref is marked as immutable, meaning that the
|
|
|
|
contents of its pixels will not change for the lifetime of the pixelref.
|
|
|
|
*/
|
2015-07-29 18:44:52 +00:00
|
|
|
bool isImmutable() const { return fMutability != kMutable; }
|
2011-02-24 18:09:46 +00:00
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
/** Marks this pixelref is immutable, meaning that the contents of its
|
|
|
|
pixels will not change for the lifetime of the pixelref. This state can
|
|
|
|
be set on a pixelref, but it cannot be cleared once it is set.
|
|
|
|
*/
|
|
|
|
void setImmutable();
|
|
|
|
|
2013-10-24 17:44:27 +00:00
|
|
|
// Register a listener that may be called the next time our generation ID changes.
|
|
|
|
//
|
|
|
|
// We'll only call the listener if we're confident that we are the only SkPixelRef with this
|
|
|
|
// generation ID. If our generation ID changes and we decide not to call the listener, we'll
|
|
|
|
// never call it: you must add a new listener for each generation ID change. We also won't call
|
|
|
|
// the listener when we're certain no one knows what our generation ID is.
|
|
|
|
//
|
|
|
|
// This can be used to invalidate caches keyed by SkPixelRef generation ID.
|
2018-09-17 21:29:39 +00:00
|
|
|
// Takes ownership of listener. Threadsafe.
|
2020-03-02 21:59:40 +00:00
|
|
|
void addGenIDChangeListener(sk_sp<SkIDChangeListener> listener);
|
2013-10-24 17:44:27 +00:00
|
|
|
|
2018-10-12 20:18:28 +00:00
|
|
|
// Call when this pixelref is part of the key to a resourcecache entry. This allows the cache
|
|
|
|
// to know automatically those entries can be purged when this pixelref is changed or deleted.
|
|
|
|
void notifyAddedToCache() {
|
|
|
|
fAddedToCache.store(true);
|
|
|
|
}
|
|
|
|
|
2017-08-28 14:34:05 +00:00
|
|
|
virtual SkDiscardableMemory* diagnostic_only_getDiscardable() const { return nullptr; }
|
2015-08-19 19:25:40 +00:00
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
protected:
|
2017-07-18 14:53:11 +00:00
|
|
|
void android_only_reset(int width, int height, size_t rowBytes);
|
2017-04-12 16:57:07 +00:00
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
private:
|
2017-05-02 15:41:30 +00:00
|
|
|
int fWidth;
|
|
|
|
int fHeight;
|
2017-05-01 14:22:31 +00:00
|
|
|
void* fPixels;
|
|
|
|
size_t fRowBytes;
|
2015-05-22 15:06:21 +00:00
|
|
|
|
2015-02-25 17:10:57 +00:00
|
|
|
// Bottom bit indicates the Gen ID is unique.
|
|
|
|
bool genIDIsUnique() const { return SkToBool(fTaggedGenID.load() & 1); }
|
2018-08-09 16:23:19 +00:00
|
|
|
mutable std::atomic<uint32_t> fTaggedGenID;
|
2015-02-25 17:10:57 +00:00
|
|
|
|
2020-03-02 21:59:40 +00:00
|
|
|
SkIDChangeListener::List fGenIDChangeListeners;
|
2012-08-22 15:00:05 +00:00
|
|
|
|
2018-10-12 20:18:28 +00:00
|
|
|
// Set true by caches when they cache content that's derived from the current pixels.
|
|
|
|
std::atomic<bool> fAddedToCache;
|
|
|
|
|
2018-04-26 12:32:37 +00:00
|
|
|
enum Mutability {
|
2015-07-29 18:44:52 +00:00
|
|
|
kMutable, // PixelRefs begin mutable.
|
|
|
|
kTemporarilyImmutable, // Considered immutable, but can revert to mutable.
|
|
|
|
kImmutable, // Once set to this state, it never leaves.
|
|
|
|
} fMutability : 8; // easily fits inside a byte
|
|
|
|
|
2013-10-24 17:44:27 +00:00
|
|
|
void needsNewGenID();
|
|
|
|
void callGenIDChangeListeners();
|
|
|
|
|
2015-07-29 18:44:52 +00:00
|
|
|
void setTemporarilyImmutable();
|
|
|
|
void restoreMutability();
|
2022-03-30 14:12:28 +00:00
|
|
|
friend class SkSurface_Raster; // For temporary immutable methods above.
|
2015-07-29 18:44:52 +00:00
|
|
|
|
2015-08-04 15:10:13 +00:00
|
|
|
void setImmutableWithID(uint32_t genID);
|
2017-04-11 16:03:44 +00:00
|
|
|
friend void SkBitmapCache_setImmutableWithID(SkPixelRef*, uint32_t);
|
2015-08-04 15:10:13 +00:00
|
|
|
|
2020-09-03 02:42:33 +00:00
|
|
|
using INHERITED = SkRefCnt;
|
2008-12-17 15:59:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|