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

Side by Side Diff: cc/raster/zero_copy_raster_buffer_provider.cc

Issue 2525453002: Raster: Allow a RasterSource to specify its color space (Closed)
Patch Set: Only set implied space when color correct rendering is disabled Created 4 years 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 unified diff | Download patch
« no previous file with comments | « cc/raster/one_copy_raster_buffer_provider.cc ('k') | cc/resources/resource_provider.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 #include "cc/raster/zero_copy_raster_buffer_provider.h" 5 #include "cc/raster/zero_copy_raster_buffer_provider.h"
6 6
7 #include <stdint.h> 7 #include <stdint.h>
8 8
9 #include <algorithm> 9 #include <algorithm>
10 10
(...skipping 30 matching lines...) Expand all
41 if (!buffer) 41 if (!buffer)
42 return; 42 return;
43 43
44 DCHECK_EQ(1u, gfx::NumberOfPlanesForBufferFormat(buffer->GetFormat())); 44 DCHECK_EQ(1u, gfx::NumberOfPlanesForBufferFormat(buffer->GetFormat()));
45 bool rv = buffer->Map(); 45 bool rv = buffer->Map();
46 DCHECK(rv); 46 DCHECK(rv);
47 DCHECK(buffer->memory(0)); 47 DCHECK(buffer->memory(0));
48 // RasterBufferProvider::PlaybackToMemory only supports unsigned strides. 48 // RasterBufferProvider::PlaybackToMemory only supports unsigned strides.
49 DCHECK_GE(buffer->stride(0), 0); 49 DCHECK_GE(buffer->stride(0), 0);
50 50
51 sk_sp<SkColorSpace> raster_color_space =
52 raster_source->HasImpliedColorSpace() ? nullptr
53 : lock_.sk_color_space();
54
51 // TODO(danakj): Implement partial raster with raster_dirty_rect. 55 // TODO(danakj): Implement partial raster with raster_dirty_rect.
52 RasterBufferProvider::PlaybackToMemory( 56 RasterBufferProvider::PlaybackToMemory(
53 buffer->memory(0), resource_->format(), resource_->size(), 57 buffer->memory(0), resource_->format(), resource_->size(),
54 buffer->stride(0), raster_source, raster_full_rect, raster_full_rect, 58 buffer->stride(0), raster_source, raster_full_rect, raster_full_rect,
55 scales, lock_.sk_color_space(), playback_settings); 59 scales, raster_color_space, playback_settings);
56 buffer->Unmap(); 60 buffer->Unmap();
57 } 61 }
58 62
59 private: 63 private:
60 ResourceProvider::ScopedWriteLockGpuMemoryBuffer lock_; 64 ResourceProvider::ScopedWriteLockGpuMemoryBuffer lock_;
61 const Resource* resource_; 65 const Resource* resource_;
62 66
63 DISALLOW_COPY_AND_ASSIGN(RasterBufferImpl); 67 DISALLOW_COPY_AND_ASSIGN(RasterBufferImpl);
64 }; 68 };
65 69
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after
117 } 121 }
118 122
119 bool ZeroCopyRasterBufferProvider::CanPartialRasterIntoProvidedResource() 123 bool ZeroCopyRasterBufferProvider::CanPartialRasterIntoProvidedResource()
120 const { 124 const {
121 return false; 125 return false;
122 } 126 }
123 127
124 void ZeroCopyRasterBufferProvider::Shutdown() {} 128 void ZeroCopyRasterBufferProvider::Shutdown() {}
125 129
126 } // namespace cc 130 } // namespace cc
OLDNEW
« no previous file with comments | « cc/raster/one_copy_raster_buffer_provider.cc ('k') | cc/resources/resource_provider.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698