OpenStreetMap使用OsmSharp和Mapsui不再显示

问题描述 投票:0回答:1

我对Visual Studio / Xamarin还是相当陌生,但是我有一个简单的OpenStreetMap示例,不久前它为Android运行,它确实显示了地图,但似乎不再显示地图,尽管我没有更改此代码据我所知,在一段时间内采样。我不确定是否某些Visual Studio / Xamarin或MacOS更新可能导致其不再起作用。

我正在macOS Mojava 10.14.6和以下软件包上使用Visual Studio for Mac社区8.4.4(内部版本91):

  • Mapsui 1.4.8
  • OsmSharp 6.2.0
  • Xamarin.Android.Support.Core.Utils 28.0.0.1
  • Xamarin.Android.Support.CustomTabs 28.0.0.1
  • Xamarin.Android.Support.Design 28.0.0.1
  • Xamarin.Essentials 1.2.0

我的MainActivity.cs文件包含以下代码:

using System;
using Android.App;
using Android.OS;
using Android.Runtime;
using Android.Support.Design.Widget;
using Android.Support.V7.App;
using Android.Views;
using Android.Widget;
using Mapsui;
using Mapsui.Geometries;
using Mapsui.Projection;
using Mapsui.Styles;
using Mapsui.Utilities;
using Mapsui.UI.Android;
using Mapsui.Widgets.ScaleBar;
using Mapsui.Widgets.Zoom;
using Xamarin.Essentials;

namespace mvp_android
{
    [Activity(Label = "@string/app_name", Theme = "@style/AppTheme.NoActionBar", MainLauncher = true)]
    public class MainActivity : AppCompatActivity
    {
        protected override void OnCreate(Bundle savedInstanceState)
        {
            base.OnCreate(savedInstanceState);
            Xamarin.Essentials.Platform.Init(this, savedInstanceState);
            SetContentView(Resource.Layout.Main);

            var mapControl = FindViewById<MapControl>(Resource.Id.mapcontrol);
            var map = new Mapsui.Map();
            map.Layers.Add(OpenStreetMap.CreateTileLayer());
            map.Widgets.Add(
                new ZoomInOutWidget(map) {
                    HorizontalAlignment = Mapsui.Widgets.HorizontalAlignment.Left,
                    VerticalAlignment = Mapsui.Widgets.VerticalAlignment.Top,
                    Orientation = Mapsui.Widgets.Zoom.Orientation.Horizontal,
                }
            );
            var centerOfLondonOntario = new Point(-81.2497, 42.9837);
            map.NavigateTo(SphericalMercator.FromLonLat(centerOfLondonOntario.X, centerOfLondonOntario.Y));
            map.NavigateTo(map.Resolutions[9]);
            mapControl.Map = map;
        }

        public override bool OnCreateOptionsMenu(IMenu menu)
        {
            MenuInflater.Inflate(Resource.Menu.menu_main, menu);
            return true;
        }

        public override bool OnOptionsItemSelected(IMenuItem item)
        {
            int id = item.ItemId;
            if (id == Resource.Id.action_settings)
            {
                return true;
            }

            return base.OnOptionsItemSelected(item);
        }

        private void FabOnClick(object sender, EventArgs eventArgs)
        {
            View view = (View)sender;
            Snackbar.Make(view, "Replace with your own action", Snackbar.LengthLong)
                .SetAction("Action", (Android.Views.View.IOnClickListener)null).Show();
        }

        public override void OnRequestPermissionsResult(int requestCode, string[] permissions, [GeneratedEnum] Android.Content.PM.Permission[] grantResults)
        {
            Xamarin.Essentials.Platform.OnRequestPermissionsResult(requestCode, permissions, grantResults);

            base.OnRequestPermissionsResult(requestCode, permissions, grantResults);
        }
    }
}

而且我的Main.xml包含以下代码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
  <Mapsui.UI.Android.MapControl
           android:id="@+id/mapcontrol"
           android:layout_width="match_parent"
           android:layout_height="match_parent" />
</LinearLayout>

最初,此示例显示了带有缩放按钮的OpenStreetMap的地图,以安大略省伦敦市为中心,但现在只显示了地图应显示的白色,仍然显示了缩放按钮,并显示了( c)OpenStreetMap水印。

我在这里想念什么?

c# xamarin openstreetmap mapsui
1个回答
0
投票

Mapsui 1.4.8中使用的BruTile版本未将用户代理发送为请求的一部分,因此,openstreetmap服务器有时出于这个原因开始阻止请求。

作为解决方法,您可以按照Matt Schneeberger的描述创建自定义ITileSource:https://github.com/Mapsui/Mapsui/issues/668#issuecomment-497947690

© www.soinside.com 2019 - 2024. All rights reserved.