diff options
author | ccameron@chromium.org <ccameron@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-05-21 03:21:07 +0000 |
---|---|---|
committer | ccameron@chromium.org <ccameron@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-05-21 03:21:07 +0000 |
commit | 7b4bff53c5278de18e6e565743aabee1e1a5bcbe (patch) | |
tree | b28981432f1df0a97dad2e055c64abea92705837 /content/renderer/gpu/compositor_software_output_device.cc | |
parent | d5801aea4ece5a63b3ed83365f957a6d38556293 (diff) | |
download | chromium_src-7b4bff53c5278de18e6e565743aabee1e1a5bcbe.zip chromium_src-7b4bff53c5278de18e6e565743aabee1e1a5bcbe.tar.gz chromium_src-7b4bff53c5278de18e6e565743aabee1e1a5bcbe.tar.bz2 |
Make delegated software renderer work on Mac
Add a device scale factor parameter to SoftwareOutputDevice::Resize and
plumb that parameter through to the contentsScale property of the CALayer
that is used to draw the software frame.
Change the way that RWHVMac draws software frames (both delegated and
non-delegated) so that the CALayer for the software frame has setContents
called on it with a CGImageRef of the software frame, instead of drawing
the CGImageRef to the inside the CALayer's displayInContext function. This
is the way that things should have been done to begin with (it involves a lot
less copying and a lot more idle time in the browser main thread), but wasn't
compatible with the (now-defunct) legacy software path.
Change the software rendering path to set the contentsScale of the software
CALayer at the time that the software frame is received, when the contents
are updated, instead of in RWHVMac::LayoutLayers.
BUG=314190
Review URL: https://codereview.chromium.org/297573003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@271839 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/renderer/gpu/compositor_software_output_device.cc')
-rw-r--r-- | content/renderer/gpu/compositor_software_output_device.cc | 28 |
1 files changed, 16 insertions, 12 deletions
diff --git a/content/renderer/gpu/compositor_software_output_device.cc b/content/renderer/gpu/compositor_software_output_device.cc index a8c893b..c656d45 100644 --- a/content/renderer/gpu/compositor_software_output_device.cc +++ b/content/renderer/gpu/compositor_software_output_device.cc @@ -78,7 +78,7 @@ unsigned CompositorSoftwareOutputDevice::GetNextId() { CompositorSoftwareOutputDevice::Buffer* CompositorSoftwareOutputDevice::CreateBuffer() { scoped_ptr<cc::SharedBitmap> shared_bitmap = - shared_bitmap_manager_->AllocateSharedBitmap(viewport_size_); + shared_bitmap_manager_->AllocateSharedBitmap(viewport_pixel_size_); CHECK(shared_bitmap); return new Buffer(GetNextId(), shared_bitmap.Pass()); } @@ -94,10 +94,14 @@ size_t CompositorSoftwareOutputDevice::FindFreeBuffer(size_t hint) { return buffers_.size() - 1; } -void CompositorSoftwareOutputDevice::Resize(const gfx::Size& viewport_size) { +void CompositorSoftwareOutputDevice::Resize( + const gfx::Size& viewport_pixel_size, + float scale_factor) { DCHECK(CalledOnValidThread()); - if (viewport_size_ == viewport_size) + scale_factor_ = scale_factor; + + if (viewport_pixel_size_ == viewport_pixel_size) return; // Keep non-ACKed buffers in awaiting_ack_ until they get acknowledged. @@ -110,7 +114,7 @@ void CompositorSoftwareOutputDevice::Resize(const gfx::Size& viewport_size) { buffers_.clear(); current_index_ = -1; - viewport_size_ = viewport_size; + viewport_pixel_size_ = viewport_pixel_size; } void CompositorSoftwareOutputDevice::DiscardBackbuffer() { @@ -141,14 +145,14 @@ SkCanvas* CompositorSoftwareOutputDevice::BeginPaint( current->SetFree(false); // Set up a canvas for the current front buffer. - SkImageInfo info = SkImageInfo::MakeN32Premul(viewport_size_.width(), - viewport_size_.height()); + SkImageInfo info = SkImageInfo::MakeN32Premul(viewport_pixel_size_.width(), + viewport_pixel_size_.height()); SkBitmap bitmap; bitmap.installPixels(info, current->memory(), info.minRowBytes()); canvas_ = skia::AdoptRef(new SkCanvas(bitmap)); if (!previous) { - DCHECK(damage_rect == gfx::Rect(viewport_size_)); + DCHECK(damage_rect == gfx::Rect(viewport_pixel_size_)); } else { // Find the smallest damage region that needs // to be copied from the |previous| buffer. @@ -157,15 +161,15 @@ SkCanvas* CompositorSoftwareOutputDevice::BeginPaint( current->FindDamageDifferenceFrom(previous, ®ion) || previous->FindDamageDifferenceFrom(current, ®ion); if (!found) - region = SkRegion(RectToSkIRect(gfx::Rect(viewport_size_))); + region = SkRegion(RectToSkIRect(gfx::Rect(viewport_pixel_size_))); region.op(RectToSkIRect(damage_rect), SkRegion::kDifference_Op); // Copy over the damage region. if (!region.isEmpty()) { SkBitmap back_bitmap; back_bitmap.setConfig(SkBitmap::kARGB_8888_Config, - viewport_size_.width(), - viewport_size_.height()); + viewport_pixel_size_.width(), + viewport_pixel_size_.height()); back_bitmap.setPixels(previous->memory()); for (SkRegion::Iterator it(region); !it.done(); it.next()) { @@ -181,7 +185,7 @@ SkCanvas* CompositorSoftwareOutputDevice::BeginPaint( for (size_t i = 0; i < buffers_.size(); ++i) { Buffer* buffer = buffers_[i]; if (buffer->parent() == current) - buffer->SetParent(NULL, gfx::Rect(viewport_size_)); + buffer->SetParent(NULL, gfx::Rect(viewport_pixel_size_)); } damage_rect_ = damage_rect; @@ -195,7 +199,7 @@ void CompositorSoftwareOutputDevice::EndPaint( Buffer* buffer = buffers_[current_index_]; frame_data->id = buffer->id(); - frame_data->size = viewport_size_; + frame_data->size = viewport_pixel_size_; frame_data->damage_rect = damage_rect_; frame_data->bitmap_id = buffer->shared_bitmap_id(); } |