| OLD | NEW | 
|---|
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 #ifndef CCResourceProvider_h | 5 #ifndef CCResourceProvider_h | 
| 6 #define CCResourceProvider_h | 6 #define CCResourceProvider_h | 
| 7 | 7 | 
| 8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" | 
|  | 9 #include "base/hash_tables.h" | 
| 9 #include "CCGraphicsContext.h" | 10 #include "CCGraphicsContext.h" | 
| 10 #include "GraphicsContext3D.h" | 11 #include "GraphicsContext3D.h" | 
| 11 #include "IntSize.h" | 12 #include "IntSize.h" | 
| 12 #include "SkBitmap.h" | 13 #include "SkBitmap.h" | 
| 13 #include "SkCanvas.h" | 14 #include "SkCanvas.h" | 
| 14 #include "TextureCopier.h" | 15 #include "TextureCopier.h" | 
| 15 #include <wtf/Deque.h> | 16 #include <wtf/Deque.h> | 
| 16 #include <wtf/HashMap.h> |  | 
| 17 #include <wtf/OwnPtr.h> | 17 #include <wtf/OwnPtr.h> | 
| 18 #include <wtf/PassOwnPtr.h> | 18 #include <wtf/PassOwnPtr.h> | 
| 19 #include <wtf/PassRefPtr.h> | 19 #include <wtf/PassRefPtr.h> | 
| 20 #include <wtf/RefPtr.h> | 20 #include <wtf/RefPtr.h> | 
| 21 #include <wtf/Vector.h> | 21 #include <wtf/Vector.h> | 
| 22 | 22 | 
| 23 namespace WebKit { | 23 namespace WebKit { | 
| 24 class WebGraphicsContext3D; | 24 class WebGraphicsContext3D; | 
| 25 } | 25 } | 
| 26 | 26 | 
| 27 namespace cc { | 27 namespace cc { | 
| 28 | 28 | 
| 29 class IntRect; | 29 class IntRect; | 
| 30 class LayerTextureSubImage; | 30 class LayerTextureSubImage; | 
| 31 class TextureCopier; | 31 class TextureCopier; | 
| 32 class TextureUploader; | 32 class TextureUploader; | 
| 33 | 33 | 
| 34 // Thread-safety notes: this class is not thread-safe and can only be called | 34 // Thread-safety notes: this class is not thread-safe and can only be called | 
| 35 // from the thread it was created on (in practice, the compositor thread). | 35 // from the thread it was created on (in practice, the compositor thread). | 
| 36 class CCResourceProvider { | 36 class CCResourceProvider { | 
| 37 public: | 37 public: | 
| 38     typedef unsigned ResourceId; | 38     typedef unsigned ResourceId; | 
| 39     typedef Vector<ResourceId> ResourceIdArray; | 39     typedef Vector<ResourceId> ResourceIdArray; | 
| 40     typedef HashMap<ResourceId, ResourceId> ResourceIdMap; | 40     typedef base::hash_map<ResourceId, ResourceId> ResourceIdMap; | 
| 41     enum TextureUsageHint { TextureUsageAny, TextureUsageFramebuffer }; | 41     enum TextureUsageHint { TextureUsageAny, TextureUsageFramebuffer }; | 
| 42     enum ResourceType { | 42     enum ResourceType { | 
| 43         GLTexture = 1, | 43         GLTexture = 1, | 
| 44         Bitmap, | 44         Bitmap, | 
| 45     }; | 45     }; | 
| 46     struct Mailbox { | 46     struct Mailbox { | 
| 47         GC3Dbyte name[64]; | 47         GC3Dbyte name[64]; | 
| 48     }; | 48     }; | 
| 49     struct TransferableResource { | 49     struct TransferableResource { | 
| 50         unsigned id; | 50         unsigned id; | 
| (...skipping 170 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 221         int pool; | 221         int pool; | 
| 222         int lockForReadCount; | 222         int lockForReadCount; | 
| 223         bool lockedForWrite; | 223         bool lockedForWrite; | 
| 224         bool external; | 224         bool external; | 
| 225         bool exported; | 225         bool exported; | 
| 226         bool markedForDeletion; | 226         bool markedForDeletion; | 
| 227         IntSize size; | 227         IntSize size; | 
| 228         GC3Denum format; | 228         GC3Denum format; | 
| 229         ResourceType type; | 229         ResourceType type; | 
| 230     }; | 230     }; | 
| 231     typedef HashMap<ResourceId, Resource> ResourceMap; | 231     typedef base::hash_map<ResourceId, Resource> ResourceMap; | 
| 232     struct Child { | 232     struct Child { | 
| 233         Child(); | 233         Child(); | 
| 234         ~Child(); | 234         ~Child(); | 
| 235 | 235 | 
| 236         int pool; | 236         int pool; | 
| 237         ResourceIdMap childToParentMap; | 237         ResourceIdMap childToParentMap; | 
| 238         ResourceIdMap parentToChildMap; | 238         ResourceIdMap parentToChildMap; | 
| 239     }; | 239     }; | 
| 240     typedef HashMap<int, Child> ChildMap; | 240     typedef base::hash_map<int, Child> ChildMap; | 
| 241 | 241 | 
| 242     explicit CCResourceProvider(CCGraphicsContext*); | 242     explicit CCResourceProvider(CCGraphicsContext*); | 
| 243     bool initialize(); | 243     bool initialize(); | 
| 244 | 244 | 
| 245     const Resource* lockForRead(ResourceId); | 245     const Resource* lockForRead(ResourceId); | 
| 246     void unlockForRead(ResourceId); | 246     void unlockForRead(ResourceId); | 
| 247     const Resource* lockForWrite(ResourceId); | 247     const Resource* lockForWrite(ResourceId); | 
| 248     void unlockForWrite(ResourceId); | 248     void unlockForWrite(ResourceId); | 
| 249     static void populateSkBitmapWithResource(SkBitmap*, const Resource*); | 249     static void populateSkBitmapWithResource(SkBitmap*, const Resource*); | 
| 250 | 250 | 
| (...skipping 17 matching lines...) Expand all  Loading... | 
| 268     OwnPtr<TextureUploader> m_textureUploader; | 268     OwnPtr<TextureUploader> m_textureUploader; | 
| 269     OwnPtr<AcceleratedTextureCopier> m_textureCopier; | 269     OwnPtr<AcceleratedTextureCopier> m_textureCopier; | 
| 270     int m_maxTextureSize; | 270     int m_maxTextureSize; | 
| 271 | 271 | 
| 272     DISALLOW_COPY_AND_ASSIGN(CCResourceProvider); | 272     DISALLOW_COPY_AND_ASSIGN(CCResourceProvider); | 
| 273 }; | 273 }; | 
| 274 | 274 | 
| 275 } | 275 } | 
| 276 | 276 | 
| 277 #endif | 277 #endif | 
| OLD | NEW | 
|---|