diff options
author | Kangho Hur <kangho.hur@samsung.com> | 2016-12-26 17:17:54 -0800 |
---|---|---|
committer | Gerrit Code Review <gerrit@review.vlan103.tizen.org> | 2016-12-26 17:17:54 -0800 |
commit | 1422e9ef1fbaf6cd8652290f132dd58685d995e9 (patch) | |
tree | 8a2714d7212a9434e648d3dc49a2d01e18bb1cc6 | |
parent | 4678bcda9ae352c0b7fdaaf10e87eef40900369f (diff) | |
parent | 35129de4b84e71802c3ba13bad965fe94d134fb9 (diff) | |
download | xamarin-forms-1422e9ef1fbaf6cd8652290f132dd58685d995e9.tar.gz xamarin-forms-1422e9ef1fbaf6cd8652290f132dd58685d995e9.tar.bz2 xamarin-forms-1422e9ef1fbaf6cd8652290f132dd58685d995e9.zip |
Merge "Fix Scrolling to Specific Element in ScrollView" into tizen
-rwxr-xr-x | Xamarin.Forms.Platform.Tizen/Renderers/ScrollViewRenderer.cs | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/Xamarin.Forms.Platform.Tizen/Renderers/ScrollViewRenderer.cs b/Xamarin.Forms.Platform.Tizen/Renderers/ScrollViewRenderer.cs index a566f24a..11195386 100755 --- a/Xamarin.Forms.Platform.Tizen/Renderers/ScrollViewRenderer.cs +++ b/Xamarin.Forms.Platform.Tizen/Renderers/ScrollViewRenderer.cs @@ -123,7 +123,16 @@ namespace Xamarin.Forms.Platform.Tizen void ScrollRequestHandler(object sender, ScrollToRequestedEventArgs e) { - Rect region = new Rect(ToNativeDimension(e.ScrollX), ToNativeDimension(e.ScrollY), ToNativeDimension(Element.Width), ToNativeDimension(Element.Height)); + var x = e.ScrollX; + var y = e.ScrollY; + if (e.Mode == ScrollToMode.Element) + { + Point itemPosition = (Element as IScrollViewController).GetScrollPositionForElement(e.Element as VisualElement, e.Position); + x = itemPosition.X; + y = itemPosition.Y; + } + + Rect region = new Rect(ToNativeDimension(x), ToNativeDimension(y), ToNativeDimension(Element.Width), ToNativeDimension(Element.Height)); Control.ScrollTo(region, e.ShouldAnimate); } } |