Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "ui/ozone/platform/dri/dri_surface_factory.h" | 5 #include "ui/ozone/platform/dri/dri_surface_factory.h" |
| 6 | 6 |
| 7 #include <drm.h> | 7 #include <drm.h> |
| 8 #include <errno.h> | 8 #include <errno.h> |
| 9 #include <xf86drm.h> | 9 #include <xf86drm.h> |
| 10 | 10 |
| 11 #include "base/debug/trace_event.h" | 11 #include "base/debug/trace_event.h" |
| 12 #include "base/message_loop/message_loop.h" | 12 #include "base/message_loop/message_loop.h" |
| 13 #include "third_party/skia/include/core/SkBitmap.h" | 13 #include "third_party/skia/include/core/SkBitmap.h" |
| 14 #include "third_party/skia/include/core/SkDevice.h" | 14 #include "third_party/skia/include/core/SkDevice.h" |
| 15 #include "third_party/skia/include/core/SkSurface.h" | |
| 15 #include "ui/gfx/native_widget_types.h" | 16 #include "ui/gfx/native_widget_types.h" |
| 16 #include "ui/gfx/ozone/surface_ozone_canvas.h" | 17 #include "ui/gfx/ozone/surface_ozone_canvas.h" |
| 17 #include "ui/ozone/platform/dri/dri_surface.h" | 18 #include "ui/ozone/platform/dri/dri_surface.h" |
| 18 #include "ui/ozone/platform/dri/dri_util.h" | 19 #include "ui/ozone/platform/dri/dri_util.h" |
| 19 #include "ui/ozone/platform/dri/dri_vsync_provider.h" | 20 #include "ui/ozone/platform/dri/dri_vsync_provider.h" |
| 20 #include "ui/ozone/platform/dri/dri_wrapper.h" | 21 #include "ui/ozone/platform/dri/dri_wrapper.h" |
| 21 #include "ui/ozone/platform/dri/hardware_display_controller.h" | 22 #include "ui/ozone/platform/dri/hardware_display_controller.h" |
| 22 | 23 |
| 23 namespace ui { | 24 namespace ui { |
| 24 | 25 |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 71 // For DRI the hadware surface & canvas are owned by the platform, so | 72 // For DRI the hadware surface & canvas are owned by the platform, so |
| 72 // the compositor merely owns this proxy object. | 73 // the compositor merely owns this proxy object. |
| 73 // | 74 // |
| 74 // TODO(spang): Should the compositor own any bits of the DriSurface? | 75 // TODO(spang): Should the compositor own any bits of the DriSurface? |
| 75 class DriSurfaceAdapter : public gfx::SurfaceOzoneCanvas { | 76 class DriSurfaceAdapter : public gfx::SurfaceOzoneCanvas { |
| 76 public: | 77 public: |
| 77 DriSurfaceAdapter(gfx::AcceleratedWidget w, DriSurfaceFactory* dri) | 78 DriSurfaceAdapter(gfx::AcceleratedWidget w, DriSurfaceFactory* dri) |
| 78 : widget_(w), dri_(dri) {} | 79 : widget_(w), dri_(dri) {} |
| 79 virtual ~DriSurfaceAdapter() {} | 80 virtual ~DriSurfaceAdapter() {} |
| 80 | 81 |
| 81 // gfx::SurfaceOzoneCanvas overrides: | 82 // SurfaceOzoneCanvas: |
| 82 virtual skia::RefPtr<SkCanvas> GetCanvas() OVERRIDE { | 83 virtual skia::RefPtr<SkCanvas> GetCanvas() OVERRIDE { |
| 83 return skia::SharePtr(dri_->GetCanvasForWidget(widget_)); | 84 return skia::SharePtr(surface_->getCanvas()); |
| 84 } | 85 } |
| 85 virtual bool ResizeCanvas(const gfx::Size& viewport_size) OVERRIDE { | 86 virtual bool ResizeCanvas(const gfx::Size& viewport_size) OVERRIDE { |
| 86 NOTIMPLEMENTED(); | 87 SkImageInfo info = SkImageInfo::MakeN32( |
|
danakj
2014/04/23 19:05:38
Is there any test to show this working now?
spang
2014/04/23 20:57:18
Resize at runtime isn't really supported. I'm usin
| |
| 87 return false; | 88 viewport_size.width(), viewport_size.height(), kOpaque_SkAlphaType); |
| 89 surface_ = skia::AdoptRef(SkSurface::NewRaster(info)); | |
| 90 return true; | |
| 88 } | 91 } |
| 89 virtual bool PresentCanvas() OVERRIDE { | 92 virtual bool PresentCanvas(const gfx::Rect& damage) OVERRIDE { |
| 93 SkCanvas* canvas = dri_->GetCanvasForWidget(widget_); | |
| 94 SkRect real_damage = RectToSkRect(UnionRects(damage, last_damage_)); | |
|
danakj
2014/04/23 19:05:38
Why do you always present a damage rect for two ca
spang
2014/04/23 20:57:18
The incoming buffer is missing the prior update du
| |
| 95 | |
| 96 // Copy damage region. | |
| 97 skia::RefPtr<SkImage> image = skia::AdoptRef(surface_->newImageSnapshot()); | |
| 98 image->draw(canvas, &real_damage, real_damage, NULL); | |
| 99 | |
| 100 last_damage_ = damage; | |
| 90 return dri_->SchedulePageFlip(widget_); | 101 return dri_->SchedulePageFlip(widget_); |
| 91 } | 102 } |
| 92 virtual scoped_ptr<gfx::VSyncProvider> CreateVSyncProvider() OVERRIDE { | 103 virtual scoped_ptr<gfx::VSyncProvider> CreateVSyncProvider() OVERRIDE { |
| 93 return dri_->CreateVSyncProvider(widget_); | 104 return dri_->CreateVSyncProvider(widget_); |
| 94 } | 105 } |
| 95 | 106 |
| 96 private: | 107 private: |
| 108 skia::RefPtr<SkSurface> surface_; | |
| 109 gfx::Rect last_damage_; | |
| 110 | |
| 97 gfx::AcceleratedWidget widget_; | 111 gfx::AcceleratedWidget widget_; |
| 98 DriSurfaceFactory* dri_; | 112 DriSurfaceFactory* dri_; |
| 99 }; | 113 }; |
| 100 | 114 |
| 101 } // namespace | 115 } // namespace |
| 102 | 116 |
| 103 // static | 117 // static |
| 104 const gfx::AcceleratedWidget DriSurfaceFactory::kDefaultWidgetHandle = 1; | 118 const gfx::AcceleratedWidget DriSurfaceFactory::kDefaultWidgetHandle = 1; |
| 105 | 119 |
| 106 DriSurfaceFactory::DriSurfaceFactory() | 120 DriSurfaceFactory::DriSurfaceFactory() |
| (...skipping 241 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 348 | 362 |
| 349 HardwareDisplayController* DriSurfaceFactory::GetControllerForWidget( | 363 HardwareDisplayController* DriSurfaceFactory::GetControllerForWidget( |
| 350 gfx::AcceleratedWidget w) { | 364 gfx::AcceleratedWidget w) { |
| 351 CHECK_GE(w, 1); | 365 CHECK_GE(w, 1); |
| 352 CHECK_LE(static_cast<size_t>(w), controllers_.size()); | 366 CHECK_LE(static_cast<size_t>(w), controllers_.size()); |
| 353 | 367 |
| 354 return controllers_[w - 1]; | 368 return controllers_[w - 1]; |
| 355 } | 369 } |
| 356 | 370 |
| 357 } // namespace ui | 371 } // namespace ui |
| OLD | NEW |