// // Copyright 2016 Pixar // // Licensed under the Apache License, Version 2.0 (the "Apache License") // with the following modification; you may not use this file except in // compliance with the Apache License and the following modification to it: // Section 6. Trademarks. is deleted and replaced with: // // 6. Trademarks. This License does not grant permission to use the trade // names, trademarks, service marks, or product names of the Licensor // and its affiliates, except as required to comply with Section 4(c) of // the License and to reproduce the content of the NOTICE file. // // You may obtain a copy of the Apache License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the Apache License with the above modification is // distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY // KIND, either express or implied. See the Apache License for the specific // language governing permissions and limitations under the Apache License. // #ifndef PXR_IMAGING_GLF_TEXTURE_REGISTRY_H #define PXR_IMAGING_GLF_TEXTURE_REGISTRY_H /// \file glf/textureRegistry.h #include "pxr/pxr.h" #include "pxr/imaging/glf/api.h" #include "pxr/imaging/glf/image.h" #include "pxr/base/tf/declarePtrs.h" #include "pxr/base/tf/refPtr.h" #include "pxr/base/tf/singleton.h" #include "pxr/base/tf/token.h" #include "pxr/base/tf/weakPtr.h" #include "pxr/base/vt/dictionary.h" #include #include PXR_NAMESPACE_OPEN_SCOPE TF_DECLARE_WEAK_AND_REF_PTRS(GlfTextureHandle); TF_DECLARE_WEAK_AND_REF_PTRS(GlfTexture); class GlfRankedTypeMap; class GlfTextureFactoryBase; /// \class GlfTextureRegistry /// class GlfTextureRegistry { public: GLF_API static GlfTextureRegistry & GetInstance(); GLF_API GlfTextureHandleRefPtr GetTextureHandle(const TfToken &texture, GlfImage::ImageOriginLocation originLocation = GlfImage::OriginUpperLeft); GLF_API GlfTextureHandleRefPtr GetTextureHandle(const TfTokenVector &textures, GlfImage::ImageOriginLocation originLocation = GlfImage::OriginUpperLeft); GLF_API GlfTextureHandleRefPtr GetTextureHandle(GlfTextureRefPtr texture); GLF_API GlfTextureHandleRefPtr GetTextureHandle( const TfToken& texture, GlfImage::ImageOriginLocation originLocation, const GlfTextureFactoryBase* textureFactory); // garbage collection methods GLF_API void RequiresGarbageCollection(); GLF_API void GarbageCollectIfNeeded(); // Returns true if the registry contains a texture sampler for \a texture; GLF_API bool HasTexture(const TfToken &texture, GlfImage::ImageOriginLocation originLocation = GlfImage::OriginUpperLeft) const; // diagnostics GLF_API std::vector GetTextureInfos() const; // Resets the registry contents. Clients that call this are expected to // manage their texture handles accordingly. GLF_API void Reset(); private: friend class TfSingleton< GlfTextureRegistry >; GlfTextureRegistry(); // Disallow copies GlfTextureRegistry(const GlfTextureRegistry&) = delete; GlfTextureRegistry& operator=(const GlfTextureRegistry&) = delete; GlfTextureHandleRefPtr _CreateTexture(const TfToken &texture, GlfImage::ImageOriginLocation originLocation); GlfTextureHandleRefPtr _CreateTexture(const TfTokenVector &textures, const size_t numTextures, GlfImage::ImageOriginLocation originLocation); GlfTextureHandleRefPtr _CreateTexture(const TfToken &texture, GlfImage::ImageOriginLocation originLocation, const GlfTextureFactoryBase *textureFactory); GlfTextureFactoryBase* _GetTextureFactory(const TfToken &filename); // Metadata for texture files to aid in cache invalidation. // Because texture arrays are stored as a single registry entry, their // metadata is also aggregated into a single _TextureMetadata instance. class _TextureMetadata { public: _TextureMetadata(); // Collect metadata for a texture. explicit _TextureMetadata(const TfToken &texture); // Collect metadata for a texture array. explicit _TextureMetadata(const TfTokenVector &textures); // Compares metadata (but not handles) to see if two _TextureMetadatas // are the same (i.e. they are very likely to be the same on disk.) bool IsMetadataEqual(const _TextureMetadata &other) const; const GlfTextureHandleRefPtr &GetHandle() const; void SetHandle(const GlfTextureHandleRefPtr &handle); private: _TextureMetadata(const TfToken *textures, const std::uint32_t numTextures); std::uint32_t _numTextures; off_t _fileSize; double _mtime; GlfTextureHandleRefPtr _handle; }; public: typedef std::map, _TextureMetadata> TextureRegistryMap; typedef std::map TextureRegistryNonSharedMap; private: // Map of file extensions to texture types. std::unique_ptr _typeMap; // registry for shared textures TextureRegistryMap _textureRegistry; // registry for non-shared textures (drawtargets) TextureRegistryNonSharedMap _textureRegistryNonShared; bool _requiresGarbageCollection; }; PXR_NAMESPACE_CLOSE_SCOPE #endif // PXR_IMAGING_GLF_TEXTURE_REGISTRY_H