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

Unified Diff: ui/surface/accelerated_surface_win.cc

Issue 10825053: Use DwmGetCompositionTimingInfo to get vsync info on Windows (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Elaborate comments and fix pointer formatting Created 8 years, 5 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
Index: ui/surface/accelerated_surface_win.cc
diff --git a/ui/surface/accelerated_surface_win.cc b/ui/surface/accelerated_surface_win.cc
index 698f5fcd3d3dbb53c5c241514b1bb8c9de93187c..a3a7b86fbc8a0252bab306a77124158d887f6c18 100644
--- a/ui/surface/accelerated_surface_win.cc
+++ b/ui/surface/accelerated_surface_win.cc
@@ -4,6 +4,7 @@
#include "ui/surface/accelerated_surface_win.h"
+#include <dwmapi.h>
#include <windows.h>
#include <algorithm>
@@ -843,6 +844,24 @@ void AcceleratedPresenter::DoReleaseSurface() {
source_texture_.Release();
}
+void AcceleratedPresenter::GetPresentationStats(base::TimeTicks* timebase,
+ uint32* interval_numerator,
+ uint32* interval_denominator) {
+ lock_.AssertAcquired();
+
+ DWM_TIMING_INFO timingInfo;
+ timingInfo.cbSize = sizeof(timingInfo);
+ HRESULT gctiResult = DwmGetCompositionTimingInfo(window_, &timingInfo);
+ if (gctiResult != S_OK)
+ return;
+
+ *timebase = base::TimeTicks::FromQPCValue(
+ static_cast<LONGLONG>(timingInfo.qpcVBlank));
+ // Swap the numerator/denominator to convert frequency to period.
+ *interval_numerator = timingInfo.rateRefresh.uiDenominator;
+ *interval_denominator = timingInfo.rateRefresh.uiNumerator;
+}
+
AcceleratedSurface::AcceleratedSurface(gfx::NativeWindow window)
: presenter_(g_accelerated_presenter_map.Pointer()->CreatePresenter(
window)) {
« base/time_win.cc ('K') | « ui/surface/accelerated_surface_win.h ('k') | ui/ui.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698