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

Unified Diff: Source/web/ViewportAnchor.h

Issue 556703005: Initial draft - modify ViewportAnchor to know about both inner and outer viewports. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Accounted for inner and outer viewport constraints Created 6 years, 3 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: Source/web/ViewportAnchor.h
diff --git a/Source/web/ViewportAnchor.h b/Source/web/ViewportAnchor.h
index 8bd0a7b92b1ef0c77917e4b37fc754c2e69e768d..2ce7aead15a88e918c34c7e6c77bb5544a696a14 100644
--- a/Source/web/ViewportAnchor.h
+++ b/Source/web/ViewportAnchor.h
@@ -43,6 +43,7 @@ namespace blink {
class EventHandler;
class IntSize;
class Node;
+class ScrollView;
// ViewportAnchor provides a way to anchor a viewport origin to a DOM node.
// In particular, the user supplies the current viewport (in CSS coordinates)
@@ -56,19 +57,29 @@ class ViewportAnchor {
public:
explicit ViewportAnchor(EventHandler*);
- void setAnchor(const IntRect& viewRect, const FloatSize& anchorInViewCoords);
+ void setAnchor(const IntRect& outerViewRect, const IntRect& innerViewRect, const FloatSize& anchorInViewCoords);
- IntPoint computeOrigin(const IntSize& currentViewSize) const;
+ void computeOrigins(const ScrollView* frameView,
+ const IntSize& outerSize, const FloatSize& innerSize,
+ IntPoint* mainFrameOffset, FloatPoint* pinchViewportOffset) const;
+
+private:
+ FloatPoint getInnerOrigin(const FloatSize& innerSize) const;
private:
RawPtrWillBeMember<EventHandler> m_eventHandler;
- IntRect m_viewRect;
+ // Inner viewport origin in the reference frame of the document in CSS pixels
+ FloatPoint m_pinchViewportInDocument;
+
+ // Inner viewport origin in the reference frame of the outer viewport
+ // normalized to the outer viewport size.
+ FloatSize m_normalizedPinchViewportOffset;
RefPtrWillBeMember<Node> m_anchorNode;
LayoutRect m_anchorNodeBounds;
- FloatSize m_anchorInViewCoords;
+ FloatSize m_anchorInInnerViewCoords;
FloatSize m_anchorInNodeCoords;
};

Powered by Google App Engine
This is Rietveld 408576698