Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(152)

Unified Diff: cc/blink/web_external_texture_layer_impl.cc

Issue 2212163002: Add some plumbing for the color management of canvases (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: minor corrections Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | cc/resources/resource_provider.cc » ('j') | cc/resources/resource_provider.cc » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/blink/web_external_texture_layer_impl.cc
diff --git a/cc/blink/web_external_texture_layer_impl.cc b/cc/blink/web_external_texture_layer_impl.cc
index 2eef8658361ce36e26bad09113ed390b5d4ac225..08c37106c45ce81c2da23f3082ccc651ef090b3b 100644
--- a/cc/blink/web_external_texture_layer_impl.cc
+++ b/cc/blink/web_external_texture_layer_impl.cc
@@ -61,6 +61,22 @@ void WebExternalTextureLayerImpl::setNearestNeighbor(bool nearest_neighbor) {
->SetNearestNeighbor(nearest_neighbor);
}
+static gfx::ColorSpace toGfxColorSpace(const SkColorSpace* skColorSpace) {
+ // TODO(crbug.com/634102): eliminate this clumsy conversion by unifying
+ // SkColorSpace and gfx::ColorSpace
+ if (!skColorSpace)
+ return gfx::ColorSpace::ColorSpace();
+
+ // assumption: using srgb or linear-rgb
Stephen White 2016/08/11 20:41:27 Assert that assumption?
Justin Novosad 2016/08/12 17:40:18 Done.
+ gfx::ColorSpace::TransferID transfer =
+ skColorSpace->gammaNamed() == SkColorSpace::kSRGB_GammaNamed
+ ? gfx::ColorSpace::TransferID::IEC61966_2_1
+ : gfx::ColorSpace::TransferID::LINEAR;
+ return gfx::ColorSpace::ColorSpace(gfx::ColorSpace::PrimaryID::BT709,
+ transfer, gfx::ColorSpace::MatrixID::RGB,
+ gfx::ColorSpace::RangeID::FULL);
+}
+
bool WebExternalTextureLayerImpl::PrepareTextureMailbox(
cc::TextureMailbox* mailbox,
std::unique_ptr<cc::SingleReleaseCallback>* release_callback,
@@ -97,6 +113,7 @@ bool WebExternalTextureLayerImpl::PrepareTextureMailbox(
client_mailbox.allowOverlay, false);
}
mailbox->set_nearest_neighbor(client_mailbox.nearestNeighbor);
+ mailbox->set_color_space(toGfxColorSpace(client_mailbox.colorSpace));
if (mailbox->IsValid()) {
*release_callback = cc::SingleReleaseCallback::Create(
« no previous file with comments | « no previous file | cc/resources/resource_provider.cc » ('j') | cc/resources/resource_provider.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698