Index: webrtc/modules/desktop_capture/win/dxgi_duplicator_controller.cc |
diff --git a/webrtc/modules/desktop_capture/win/dxgi_duplicator_controller.cc b/webrtc/modules/desktop_capture/win/dxgi_duplicator_controller.cc |
index 12876c2c89d4612731de10c6e1ba51932f1d8003..497bd9569afac3af1a9829ea9d6f09b44887c0af 100644 |
--- a/webrtc/modules/desktop_capture/win/dxgi_duplicator_controller.cc |
+++ b/webrtc/modules/desktop_capture/win/dxgi_duplicator_controller.cc |
@@ -193,6 +193,7 @@ bool DxgiDuplicatorController::DoInitialize() { |
std::max(left.right(), right.right()), |
std::max(left.bottom(), right.bottom())); |
} |
+ Translate(); |
} |
HDC hdc = GetDC(nullptr); |
@@ -295,7 +296,7 @@ int64_t DxgiDuplicatorController::GetNumFramesCaptured() const { |
} |
DesktopSize DxgiDuplicatorController::desktop_size() const { |
- return DesktopSize(desktop_rect_.right(), desktop_rect_.bottom()); |
+ return desktop_rect_.size(); |
} |
DesktopRect DxgiDuplicatorController::ScreenRect(int id) const { |
@@ -378,4 +379,13 @@ bool DxgiDuplicatorController::EnsureFrameCaptured(Context* context, |
return true; |
} |
+void DxgiDuplicatorController::Translate() { |
+ const int32_t dx = -desktop_rect_.left(); |
+ const int32_t dy = -desktop_rect_.top(); |
+ desktop_rect_.Translate(dx, dy); |
+ for (auto& duplicator : duplicators_) { |
+ duplicator.Translate(dx, dy); |
+ } |
+} |
+ |
} // namespace webrtc |