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

Unified Diff: third_party/WebKit/Source/core/input/TouchActionUtil.cpp

Issue 2916563003: Compute effective touch action in StyleAdjuster. (Closed)
Patch Set: add test case Created 3 years, 6 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: third_party/WebKit/Source/core/input/TouchActionUtil.cpp
diff --git a/third_party/WebKit/Source/core/input/TouchActionUtil.cpp b/third_party/WebKit/Source/core/input/TouchActionUtil.cpp
index e482126c98af4e35d3c819b9410e3d3f779298b9..45ff9a2cf2692d7df72f1cae2c3c1ccae2ae090e 100644
--- a/third_party/WebKit/Source/core/input/TouchActionUtil.cpp
+++ b/third_party/WebKit/Source/core/input/TouchActionUtil.cpp
@@ -5,6 +5,7 @@
#include "core/input/TouchActionUtil.h"
#include "core/dom/Node.h"
+#include "core/dom/NodeComputedStyle.h"
#include "core/html/HTMLFrameOwnerElement.h"
#include "core/layout/LayoutBox.h"
#include "core/layout/LayoutObject.h"
@@ -12,66 +13,10 @@
namespace blink {
namespace TouchActionUtil {
-namespace {
-
-// touch-action applies to all elements with both width AND height properties.
-// According to the CSS Box Model Spec
-// (http://dev.w3.org/csswg/css-box/#the-width-and-height-properties)
-// width applies to all elements but non-replaced inline elements, table rows,
-// and row groups and height applies to all elements but non-replaced inline
-// elements, table columns, and column groups.
-bool SupportsTouchAction(const LayoutObject& object) {
- if (object.IsInline() && !object.IsAtomicInlineLevel())
- return false;
- if (object.IsTableRow() || object.IsLayoutTableCol())
- return false;
-
- return true;
-}
-
-const Node* ParentNodeAcrossFrames(const Node* cur_node) {
- Node* parent_node = FlatTreeTraversal::Parent(*cur_node);
- if (parent_node)
- return parent_node;
-
- if (cur_node->IsDocumentNode()) {
- const Document* doc = ToDocument(cur_node);
- return doc->LocalOwner();
- }
-
- return nullptr;
-}
-
-} // namespace
-
TouchAction ComputeEffectiveTouchAction(const Node& node) {
- // Start by permitting all actions, then walk the elements supporting
- // touch-action from the target node up to root document, exclude any
- // prohibited actions at or below the element that supports them.
- // I.e. pan-related actions are considered up to the nearest scroller,
- // and zoom related actions are considered up to the root.
- TouchAction effective_touch_action = TouchAction::kTouchActionAuto;
- TouchAction handled_touch_actions = TouchAction::kTouchActionNone;
- for (const Node* cur_node = &node; cur_node;
- cur_node = ParentNodeAcrossFrames(cur_node)) {
- if (LayoutObject* layout_object = cur_node->GetLayoutObject()) {
- if (SupportsTouchAction(*layout_object)) {
- TouchAction action = layout_object->Style()->GetTouchAction();
- action |= handled_touch_actions;
- effective_touch_action &= action;
- if (effective_touch_action == TouchAction::kTouchActionNone)
- break;
- }
-
- // If we've reached an ancestor that supports panning, stop allowing
- // panning to be disabled.
- if ((layout_object->IsBox() &&
- ToLayoutBox(layout_object)->ScrollsOverflow()) ||
- layout_object->IsLayoutView())
- handled_touch_actions |= TouchAction::kTouchActionPan;
- }
- }
- return effective_touch_action;
+ return node.GetComputedStyle()
flackr 2017/06/29 14:34:06 Do some nodes have a null ComputedStyle? Maybe we
sunxd 2017/06/29 15:21:19 Done.
+ ? node.GetComputedStyle()->GetEffectiveTouchAction()
+ : TouchAction::kTouchActionAuto;
}
} // namespace TouchActionUtil

Powered by Google App Engine
This is Rietveld 408576698