Implementations
<testapp:CustomWebView Source="url" SwipeUpCommand="{Binding CommandName}" SwipeDownCommand="{Binding CommandName}"> </testapp:CustomWebView>
How To Create
Create CustomWebView class in your Xamarin Form Project.
CustomWebView.cs
public class CustomWebView : WebView { public static readonly BindableProperty SwipeUpCommandProperty = BindableProperty.Create( propertyName: nameof(SwipeUpCommand), returnType: typeof(Command), declaringType: typeof(CustomWebView), defaultValue: null); public ICommand SwipeUpCommand { get => (Command)base.GetValue(SwipeUpCommandProperty); set => base.SetValue(SwipeUpCommandProperty, value); } public static readonly BindableProperty SwipeDownCommandProperty = BindableProperty.Create( propertyName: nameof(SwipeDownCommand), returnType: typeof(Command), declaringType: typeof(CustomWebView), defaultValue: null); public ICommand SwipeDownCommand { get => (Command)base.GetValue(SwipeDownCommandProperty); set => base.SetValue(SwipeDownCommandProperty, value); } }
Now Implement this CustomWebView in your platform specific code.
Xamarin.Android
CustomWebViewRenderer.cs
[assembly: ExportRenderer(typeof(CustomWebView), typeof(CustomWebViewRenderer))] namespace TestApp.Droid { public class CustomWebViewRenderer : WebViewRenderer { public CustomWebViewRenderer(Context context) : base(context) { } protected override void OnElementChanged(ElementChangedEventArgs<WebView> e) { base.OnElementChanged(e); Control.SetOnTouchListener(new MyOnTouchListener((CustomWebView)Element)); } public class MyOnTouchListener : Java.Lang.Object, Android.Views.View.IOnTouchListener { float oldYValue; float newYValue; CustomWebView myWebView; public MyOnTouchListener(CustomWebView webView) { myWebView = webView; } public bool OnTouch(Android.Views.View v, MotionEvent e) { if (e.Action == MotionEventActions.Down) { oldYValue = e.GetY(0); } if (e.Action == MotionEventActions.Up) { newYValue = e.GetY(); float diff = newYValue - oldYValue; if (diff > 25) { myWebView.SwipeDownCommand.Execute(null); } else if (diff < -25) { myWebView.SwipeUpCommand.Execute(null); } } return false; } } } }
Xamarin.ios
CustomWebViewRenderer.cs
using Foundation; using System; using System.Collections.Generic; using System.Linq; using System.Text; using UIKit; using Xamarin.Forms; using Xamarin.Forms.Platform.iOS; using ObjCRuntime; [assembly: ExportRenderer(typeof(CustomWebView), typeof(CustomWebViewRenderer))] namespace TestApp.iOS { public class CustomWebViewRenderer :WkWebViewRenderer { protected override void OnElementChanged(VisualElementChangedEventArgs e) { base.OnElementChanged(e); if (e.NewElement != null) { this.BackgroundColor = UIColor.Red; UISwipeGestureRecognizer swipeUpGestureRecognizer = new UISwipeGestureRecognizer(this, new Selector("SwipeEvent:")); swipeUpGestureRecognizer.Direction = UISwipeGestureRecognizerDirection.Up; UISwipeGestureRecognizer swipeDownGestureRecognizer = new UISwipeGestureRecognizer(this, new Selector("SwipeEvent:")); swipeDownGestureRecognizer.Direction = UISwipeGestureRecognizerDirection.Down; swipeUpGestureRecognizer.Delegate = new MyWebViewDelegate(); swipeDownGestureRecognizer.Delegate = new MyWebViewDelegate(); this.AddGestureRecognizer(swipeUpGestureRecognizer); this.AddGestureRecognizer(swipeDownGestureRecognizer); } } [Export("SwipeEvent:")] void SwipeEvent(UISwipeGestureRecognizer recognizer) { var webview = Element as CustomWebView; if (recognizer.Direction == UISwipeGestureRecognizerDirection.Up) { webview.SwipeUpCommand.Execute(null); } else if (recognizer.Direction == UISwipeGestureRecognizerDirection.Down) { webview.SwipeDownCommand.Execute(null); } } } public class MyWebViewDelegate : UIGestureRecognizerDelegate { public override bool ShouldRecognizeSimultaneously(UIGestureRecognizer gestureRecognizer, UIGestureRecognizer otherGestureRecognizer) { return false; } } }