Xamarin.Forms.WebView 初始加载指标

Xamarin.Forms.WebView initial loading indicator

我采用 Xamarin forms WebView 并为第一次加载添加加载进度条的最简单方法是什么?

我的应用程序简单地包装了一个网站,但在带宽不足的情况下,当初始屏幕消失并且 WebView 正在加载它的内容时,我当然会看到一个白屏。

我想查看进度指示器。我环顾四周,但还没有找到一个简单的解决方案,而且大多数问题都不是针对 Xamarin.Forms.

提前致谢。

亲切的问候, 马克

只需将 StackLayoutActivityIindicatorWebView 一起用作子项,并根据 WebView.Navigating[= 中设置的 IsWorking 属性 值设置其可见性21=] 和 WebView.Navigated 事件。您的 ViewModel 必须实现 IOnPropertyChanged.

var webViewView = new WebView() {
    HorizontalOptions = LayoutOptions.FillAndExpand,
    VerticalOptions = LayoutOptions.FillAndExpand,
};
webViewView.SetBinding<YourViewModel>(View.IsVisibleProperty, v => v.IsWorking, 
    BindingMode.OneWay, new Converters.NegateBoolConverter());

webViewView.Navigating += (sender, e) => {
    viewModel.IsWorking = true;
};

webViewView.Navigated += (sender, e) => {
    viewModel.IsWorking = false;
};

var activityIndicator = new ActivityIndicator() {
    HorizontalOptions = LayoutOptions.Center,
    VerticalOptions = LayoutOptions.Center,
};
activityIndicator.SetBinding<YourViewModel>(ActivityIndicator.IsRunningProperty, v => v.IsWorking);

var isWorkingView = new ContentView() {
    HorizontalOptions = LayoutOptions.FillAndExpand,
    VerticalOptions = LayoutOptions.FillAndExpand,
    Content = activityIndicator
};
isWorkingView.SetBinding<YourViewModel>(ContentView.IsVisibleProperty, v => v.IsWorking);

var root = new StackLayout() {
    HorizontalOptions = LayoutOptions.FillAndExpand,
    VerticalOptions = LayoutOptions.FillAndExpand,
    Children = {
        webViewView,
        isWorkingView,
    }
};