Chromium Code Reviews| 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 CC_RESOURCES_RESOURCE_PROVIDER_H_ | 5 #ifndef CC_RESOURCES_RESOURCE_PROVIDER_H_ |
| 6 #define CC_RESOURCES_RESOURCE_PROVIDER_H_ | 6 #define CC_RESOURCES_RESOURCE_PROVIDER_H_ |
| 7 | 7 |
| 8 #include <deque> | 8 #include <deque> |
| 9 #include <set> | 9 #include <set> |
| 10 #include <string> | 10 #include <string> |
| 11 #include <utility> | 11 #include <utility> |
| 12 #include <vector> | 12 #include <vector> |
| 13 | 13 |
| 14 #include "base/basictypes.h" | 14 #include "base/basictypes.h" |
| 15 #include "base/callback.h" | 15 #include "base/callback.h" |
| 16 #include "base/containers/hash_tables.h" | 16 #include "base/containers/hash_tables.h" |
| 17 #include "base/memory/scoped_ptr.h" | 17 #include "base/memory/scoped_ptr.h" |
| 18 #include "base/memory/weak_ptr.h" | |
| 18 #include "base/threading/thread_checker.h" | 19 #include "base/threading/thread_checker.h" |
| 19 #include "cc/base/cc_export.h" | 20 #include "cc/base/cc_export.h" |
| 20 #include "cc/output/context_provider.h" | 21 #include "cc/output/context_provider.h" |
| 21 #include "cc/output/output_surface.h" | 22 #include "cc/output/output_surface.h" |
| 22 #include "cc/resources/release_callback.h" | 23 #include "cc/resources/release_callback.h" |
| 23 #include "cc/resources/resource_format.h" | 24 #include "cc/resources/resource_format.h" |
| 24 #include "cc/resources/return_callback.h" | 25 #include "cc/resources/return_callback.h" |
| 25 #include "cc/resources/single_release_callback.h" | 26 #include "cc/resources/single_release_callback.h" |
| 26 #include "cc/resources/texture_mailbox.h" | 27 #include "cc/resources/texture_mailbox.h" |
| 27 #include "cc/resources/transferable_resource.h" | 28 #include "cc/resources/transferable_resource.h" |
| 28 #include "third_party/khronos/GLES2/gl2.h" | 29 #include "third_party/khronos/GLES2/gl2.h" |
| 29 #include "third_party/khronos/GLES2/gl2ext.h" | 30 #include "third_party/khronos/GLES2/gl2ext.h" |
| 30 #include "third_party/skia/include/core/SkBitmap.h" | 31 #include "third_party/skia/include/core/SkBitmap.h" |
| 31 #include "third_party/skia/include/core/SkCanvas.h" | 32 #include "third_party/skia/include/core/SkCanvas.h" |
| 32 #include "ui/gfx/size.h" | 33 #include "ui/gfx/size.h" |
| 33 | 34 |
| 34 namespace WebKit { class WebGraphicsContext3D; } | 35 namespace WebKit { class WebGraphicsContext3D; } |
| 35 | 36 |
| 36 namespace gfx { | 37 namespace gfx { |
| 37 class Rect; | 38 class Rect; |
| 38 class Vector2d; | 39 class Vector2d; |
| 39 } | 40 } |
| 40 | 41 |
| 41 namespace cc { | 42 namespace cc { |
| 42 class SharedBitmap; | 43 class SharedBitmap; |
| 43 class SharedBitmapManager; | 44 class SharedBitmapManager; |
| 44 class TextureUploader; | 45 class TextureUploader; |
| 46 class ResourceProviderClient; | |
| 45 | 47 |
| 46 // This class is not thread-safe and can only be called from the thread it was | 48 // This class is not thread-safe and can only be called from the thread it was |
| 47 // created on (in practice, the impl thread). | 49 // created on (in practice, the impl thread). |
| 48 class CC_EXPORT ResourceProvider { | 50 class CC_EXPORT ResourceProvider |
| 51 : public base::SupportsWeakPtr<ResourceProvider> { | |
|
piman
2013/10/25 21:51:11
we want to remove the use of SupportsWeakPtr in th
| |
| 49 public: | 52 public: |
| 50 typedef unsigned ResourceId; | 53 typedef unsigned ResourceId; |
| 51 typedef std::vector<ResourceId> ResourceIdArray; | 54 typedef std::vector<ResourceId> ResourceIdArray; |
| 52 typedef std::set<ResourceId> ResourceIdSet; | 55 typedef std::set<ResourceId> ResourceIdSet; |
| 53 typedef base::hash_map<ResourceId, ResourceId> ResourceIdMap; | 56 typedef base::hash_map<ResourceId, ResourceId> ResourceIdMap; |
| 54 enum TextureUsageHint { | 57 enum TextureUsageHint { |
| 55 TextureUsageAny, | 58 TextureUsageAny, |
| 56 TextureUsageFramebuffer, | 59 TextureUsageFramebuffer, |
| 57 }; | 60 }; |
| 58 enum ResourceType { | 61 enum ResourceType { |
| 59 InvalidType = 0, | 62 InvalidType = 0, |
| 60 GLTexture = 1, | 63 GLTexture = 1, |
| 61 Bitmap, | 64 Bitmap, |
| 62 }; | 65 }; |
| 63 | 66 |
| 64 static scoped_ptr<ResourceProvider> Create( | 67 static scoped_ptr<ResourceProvider> Create( |
| 65 OutputSurface* output_surface, | 68 OutputSurface* output_surface, |
| 66 SharedBitmapManager* shared_bitmap_manager, | 69 SharedBitmapManager* shared_bitmap_manager, |
| 67 int highp_threshold_min, | 70 int highp_threshold_min, |
| 68 bool use_rgba_4444_texture_format); | 71 bool use_rgba_4444_texture_format); |
| 69 virtual ~ResourceProvider(); | 72 virtual ~ResourceProvider(); |
| 70 | 73 |
| 74 void SetClient(ResourceProviderClient* client); | |
| 75 | |
| 71 void InitializeSoftware(); | 76 void InitializeSoftware(); |
| 72 bool InitializeGL(); | 77 bool InitializeGL(); |
| 73 | 78 |
| 74 void DidLoseOutputSurface() { lost_output_surface_ = true; } | 79 void DidLoseOutputSurface() { lost_output_surface_ = true; } |
| 75 | 80 |
| 76 int max_texture_size() const { return max_texture_size_; } | 81 int max_texture_size() const { return max_texture_size_; } |
| 77 ResourceFormat memory_efficient_texture_format() const { | 82 ResourceFormat memory_efficient_texture_format() const { |
| 78 return use_rgba_4444_texture_format_ ? RGBA_4444 : best_texture_format_; | 83 return use_rgba_4444_texture_format_ ? RGBA_4444 : best_texture_format_; |
| 79 } | 84 } |
| 80 ResourceFormat best_texture_format() const { return best_texture_format_; } | 85 ResourceFormat best_texture_format() const { return best_texture_format_; } |
| 81 size_t num_resources() const { return resources_.size(); } | 86 size_t num_resources() const { return resources_.size(); } |
| 82 | 87 |
| 83 // Checks whether a resource is in use by a consumer. | 88 // Checks whether a resource is in use by a consumer. |
| 84 bool InUseByConsumer(ResourceId id); | 89 bool InUseByConsumer(ResourceId id); |
| 85 | 90 |
| 86 bool IsLost(ResourceId id); | 91 bool IsLost(ResourceId id); |
| 92 bool IsExported(ResourceId id); | |
| 87 | 93 |
| 88 // Producer interface. | 94 // Producer interface. |
| 89 | 95 |
| 90 ResourceType default_resource_type() const { return default_resource_type_; } | 96 ResourceType default_resource_type() const { return default_resource_type_; } |
| 91 ResourceType GetResourceType(ResourceId id); | 97 ResourceType GetResourceType(ResourceId id); |
| 92 | 98 |
| 93 // Creates a resource of the default resource type. | 99 // Creates a resource of the default resource type. |
| 94 ResourceId CreateResource(gfx::Size size, | 100 ResourceId CreateResource(gfx::Size size, |
| 95 GLint wrap_mode, | 101 GLint wrap_mode, |
| 96 TextureUsageHint hint, | 102 TextureUsageHint hint, |
| (...skipping 365 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 462 // specified filter for both minification and magnification. The resource | 468 // specified filter for both minification and magnification. The resource |
| 463 // must be locked for reading. | 469 // must be locked for reading. |
| 464 void BindForSampling(ResourceProvider::ResourceId resource_id, | 470 void BindForSampling(ResourceProvider::ResourceId resource_id, |
| 465 GLenum target, | 471 GLenum target, |
| 466 GLenum unit, | 472 GLenum unit, |
| 467 GLenum filter); | 473 GLenum filter); |
| 468 | 474 |
| 469 // Returns NULL if the output_surface_ does not have a ContextProvider. | 475 // Returns NULL if the output_surface_ does not have a ContextProvider. |
| 470 WebKit::WebGraphicsContext3D* Context3d() const; | 476 WebKit::WebGraphicsContext3D* Context3d() const; |
| 471 | 477 |
| 478 ResourceProviderClient* client_; | |
| 472 OutputSurface* output_surface_; | 479 OutputSurface* output_surface_; |
| 473 SharedBitmapManager* shared_bitmap_manager_; | 480 SharedBitmapManager* shared_bitmap_manager_; |
| 474 bool lost_output_surface_; | 481 bool lost_output_surface_; |
| 475 int highp_threshold_min_; | 482 int highp_threshold_min_; |
| 476 ResourceId next_id_; | 483 ResourceId next_id_; |
| 477 ResourceMap resources_; | 484 ResourceMap resources_; |
| 478 int next_child_; | 485 int next_child_; |
| 479 ChildMap children_; | 486 ChildMap children_; |
| 480 | 487 |
| 481 ResourceType default_resource_type_; | 488 ResourceType default_resource_type_; |
| 482 bool use_texture_storage_ext_; | 489 bool use_texture_storage_ext_; |
| 483 bool use_texture_usage_hint_; | 490 bool use_texture_usage_hint_; |
| 484 bool use_shallow_flush_; | 491 bool use_shallow_flush_; |
| 485 bool use_compressed_texture_etc1_; | 492 bool use_compressed_texture_etc1_; |
| 486 scoped_ptr<TextureUploader> texture_uploader_; | 493 scoped_ptr<TextureUploader> texture_uploader_; |
| 487 int max_texture_size_; | 494 int max_texture_size_; |
| 488 ResourceFormat best_texture_format_; | 495 ResourceFormat best_texture_format_; |
| 489 | 496 |
| 490 base::ThreadChecker thread_checker_; | 497 base::ThreadChecker thread_checker_; |
| 491 | 498 |
| 492 scoped_refptr<Fence> current_read_lock_fence_; | 499 scoped_refptr<Fence> current_read_lock_fence_; |
| 493 bool use_rgba_4444_texture_format_; | 500 bool use_rgba_4444_texture_format_; |
| 494 | 501 |
| 495 DISALLOW_COPY_AND_ASSIGN(ResourceProvider); | 502 DISALLOW_COPY_AND_ASSIGN(ResourceProvider); |
| 496 }; | 503 }; |
| 497 | 504 |
| 505 class ResourceProviderClient { | |
| 506 public: | |
| 507 virtual void ResourceExported(ResourceProvider::ResourceId id) = 0; | |
| 508 virtual void ResourceReturned(ResourceProvider::ResourceId id) = 0; | |
| 509 }; | |
| 498 | 510 |
| 499 // TODO(epenner): Move these format conversions to resource_format.h | 511 // TODO(epenner): Move these format conversions to resource_format.h |
| 500 // once that builds on mac (npapi.h currently #includes OpenGL.h). | 512 // once that builds on mac (npapi.h currently #includes OpenGL.h). |
| 501 inline unsigned BitsPerPixel(ResourceFormat format) { | 513 inline unsigned BitsPerPixel(ResourceFormat format) { |
| 502 DCHECK_LE(format, RESOURCE_FORMAT_MAX); | 514 DCHECK_LE(format, RESOURCE_FORMAT_MAX); |
| 503 static const unsigned format_bits_per_pixel[RESOURCE_FORMAT_MAX + 1] = { | 515 static const unsigned format_bits_per_pixel[RESOURCE_FORMAT_MAX + 1] = { |
| 504 32, // RGBA_8888 | 516 32, // RGBA_8888 |
| 505 16, // RGBA_4444 | 517 16, // RGBA_4444 |
| 506 32, // BGRA_8888 | 518 32, // BGRA_8888 |
| 507 8, // LUMINANCE_8 | 519 8, // LUMINANCE_8 |
| (...skipping 29 matching lines...) Expand all Loading... | |
| 537 return format_gl_data_format[format]; | 549 return format_gl_data_format[format]; |
| 538 } | 550 } |
| 539 | 551 |
| 540 inline GLenum GLInternalFormat(ResourceFormat format) { | 552 inline GLenum GLInternalFormat(ResourceFormat format) { |
| 541 return GLDataFormat(format); | 553 return GLDataFormat(format); |
| 542 } | 554 } |
| 543 | 555 |
| 544 } // namespace cc | 556 } // namespace cc |
| 545 | 557 |
| 546 #endif // CC_RESOURCES_RESOURCE_PROVIDER_H_ | 558 #endif // CC_RESOURCES_RESOURCE_PROVIDER_H_ |
| OLD | NEW |