Index: third_party/WebKit/Source/core/input/ScrollManager.cpp |
diff --git a/third_party/WebKit/Source/core/input/ScrollManager.cpp b/third_party/WebKit/Source/core/input/ScrollManager.cpp |
index 6d05fe059f6f8a7ddb8b1370866f43cd5abda5ea..1b503e07ef6e136c286063407a821e42ab71c7cd 100644 |
--- a/third_party/WebKit/Source/core/input/ScrollManager.cpp |
+++ b/third_party/WebKit/Source/core/input/ScrollManager.cpp |
@@ -22,6 +22,7 @@ |
#include "core/page/scrolling/RootScrollerController.h" |
#include "core/page/scrolling/ScrollState.h" |
#include "core/paint/PaintLayer.h" |
+#include "platform/Histogram.h" |
#include "platform/RuntimeEnabledFeatures.h" |
#include "wtf/PtrUtil.h" |
@@ -221,6 +222,13 @@ WebInputEventResult ScrollManager::handleGestureScrollBegin( |
passScrollGestureEvent(gestureEvent, |
m_scrollGestureHandlingNode->layoutObject()); |
+ if (m_scrollGestureHandlingNode->layoutObject() && |
+ (gestureEvent.sourceDevice == WebGestureDeviceTouchpad || |
+ gestureEvent.sourceDevice == WebGestureDeviceTouchscreen)) { |
+ recordScrollerSize(*(m_scrollGestureHandlingNode->layoutObject()), |
+ gestureEvent.sourceDevice); |
+ } |
+ |
m_currentScrollChain.clear(); |
std::unique_ptr<ScrollStateData> scrollStateData = |
WTF::makeUnique<ScrollStateData>(); |
@@ -559,4 +567,26 @@ bool ScrollManager::canHandleGestureEvent( |
return false; |
} |
+void ScrollManager::recordScrollerSize(const LayoutObject& layoutObject, |
+ const WebGestureDevice device) { |
+ if (!layoutObject.enclosingLayer()) |
+ return; |
+ |
+ if (device == WebGestureDeviceTouchpad) { |
+ DEFINE_STATIC_LOCAL( |
+ CustomCountHistogram, sizeHistogram, |
tdresser
2017/03/28 13:30:12
It looks like these macros are defining a static l
yigu
2017/03/29 15:32:03
It's better we differentiate the names. There are
|
+ ("Event.Scroll.ScrollerSize.OnScroll_Wheel", 1, 90000, 50)); |
flackr
2017/03/28 14:40:23
As I mentioned in the cc file we should use consta
yigu
2017/03/29 15:32:03
500*400 makes sense to me.
There is gonna be anoth
|
+ sizeHistogram.count( |
+ layoutObject.enclosingLayer()->visualRect().width().toInt() * |
+ layoutObject.enclosingLayer()->visualRect().height().toInt()); |
+ } else { |
+ DEFINE_STATIC_LOCAL( |
+ CustomCountHistogram, sizeHistogram, |
+ ("Event.Scroll.ScrollerSize.OnScroll_Touch", 1, 90000, 50)); |
+ sizeHistogram.count( |
+ layoutObject.enclosingLayer()->visualRect().width().toInt() * |
+ layoutObject.enclosingLayer()->visualRect().height().toInt()); |
+ } |
+} |
+ |
} // namespace blink |