Xamarin.Forms 調用騰訊地圖

用Xamarin.Forms 也有一段時間了,跨平臺,生成native代碼的噱頭 天花亂墜的,java

其中的坑,只有用過的人才懂。。。android

就拿地圖來講。。。總不能用google地圖吧 因而只能本身想辦法了。git

首先官網上有篇文章,你們能夠看下 github

點我api

首先咱們須要作的是 將地圖的android sdk轉爲C#能用的dll ,也就是須要對android sdk作一個bindingapp

因爲百度地圖及高德地圖的api key申請都須要sha1值,我的嫌麻煩,因此選擇了騰訊地圖,騰訊地圖只要api key便可。ide

1.先建立一個Android Bindings Library項目,命名爲TencentMapBindingui

2.將騰訊地圖官網下載的sdk拖到Jars目錄下,並將此jar文件的屬性改成EmbeddedJarthis

3.修改Transforms目錄下的Metadata.xml,將MapController類刪掉google

4.編譯

 

而後再新建一個xamarin.forms項目,命名爲MyTencentMap,在Portable中添加地圖的頁面

 1 public class TencentMapPage : ContentPage {
 2 
 3         public static BindableProperty PinsProperty =
 4                     BindableProperty.Create<TencentMapPage, IEnumerable>(p => p.Pins, default(IEnumerable));
 5 
 6         public IEnumerable Pins {
 7             get {
 8                 return (IEnumerable)GetValue(PinsProperty);
 9             }
10             set {
11                 this.SetValue(PinsProperty, value);
12             }
13         }
14     }

再增長一個類

public class Page1:TencentMapPage {

    }

隨便弄個實體類,顯示數據用

 public class UserTaskEntInfo : BaseIntInfo {
        public string PsCode { get; set; }
        public string BaseInfo { get; set; }
        public string ProduceInfo { get; set; }
        public string TreatmentInfo { get; set; }
        public string DischargeInfo { get; set; }
        public string Address { get; set; }
        public double? Longitude { get; set; }
        public double? Latitude { get; set; }
    }

    public class BaseIntInfo : BaseInfo<int> {
    }

    public abstract class BaseInfo<TId> {

        /// <summary>
        /// 標識
        /// </summary>
        public TId Id { get; set; }

        /// <summary>
        /// 名稱
        /// </summary>
        public string Name { get; set; }

    }

App.cs文件中添加以下代碼:

 public App() {
            // The root page of your application
            var pins = new List<UserTaskEntInfo>() { };

            pins.Add(new UserTaskEntInfo() { Name = "上海市浦東新區陸家嘴街道乳山二村", Longitude = 31.2317331909, Latitude = 121.5170146362 });
            pins.Add(new UserTaskEntInfo() { Name = "上海市浦東新區昌邑路555弄", Longitude = 31.2431982838, Latitude = 121.5215228609 });
            pins.Add(new UserTaskEntInfo() { Name = "上海市浦東新區東昌路267號", Longitude = 31.2316324310, Latitude = 121.5063730654 });
            pins.Add(new UserTaskEntInfo() { Name = "上海市浦東新區濱江大道", Longitude = 31.2379863826, Latitude = 121.4959153979 });
            pins.Add(new UserTaskEntInfo() { Name = "上海市浦東新區即墨路", Longitude = 31.2435242682, Latitude = 121.5104350816 });
            
            NavigationTestPage = new NavigationPage(new Page1() { Pins = pins });
            MainPage = NavigationTestPage;
        }

 

在MyTencentMap.Droid中將第一步binding生成的dll引入進來,

添加CustomTencentMapRenderer.cs

[assembly: ExportRenderer(typeof(TencentMapPage), typeof(CustomTencentMapRenderer))]
namespace MyTencentMap.Droid {
    public class CustomTencentMapRenderer : PageRenderer {

        private TencentMapPage myAMapPage;
        private LinearLayout layout1;
        private MapView mapView;
        private Bundle bundle;

        protected override void OnElementChanged(ElementChangedEventArgs<Page> e) {

            base.OnElementChanged(e);
            myAMapPage = e.NewElement as TencentMapPage;
            layout1 = new LinearLayout(this.Context);
            this.AddView(layout1);

            mapView = new MapView(this.Context) {                
                LayoutParameters = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MatchParent, ViewGroup.LayoutParams.MatchParent)
            };            
            LatLng SHANGHAI = new LatLng( 31.238068,  121.501654);            
            mapView.Map.SetCenter(SHANGHAI);

            var pins = myAMapPage.Pins;

            Drawable d = Resources.GetDrawable(Resource.Drawable.red_location);
            Bitmap bitmap = ((BitmapDrawable)d).Bitmap;
            LatLng latLng1;
            foreach (UserTaskEntInfo pin in pins) {
                latLng1 = new LatLng(pin.Longitude ?? 31.238068, pin.Latitude ?? 121.501654);                
                var markOption = new MarkerOptions();
                markOption.InvokeIcon(new BitmapDescriptor(bitmap));
                markOption.InvokeTitle(pin.Name);
                markOption.InvokePosition(latLng1);
                var fix = mapView.Map.AddMarker(markOption);
                fix.ShowInfoWindow();
            }
            mapView.Map.SetZoom(15); 
            mapView.OnCreate(bundle);
            layout1.AddView(mapView);

        }

        protected override void OnLayout(bool changed, int l, int t, int r, int b) {
            base.OnLayout(changed, l, t, r, b);
            var msw = View.MeasureSpec.MakeMeasureSpec(r - l, MeasureSpecMode.Exactly);
            var msh = View.MeasureSpec.MakeMeasureSpec(b - t, MeasureSpecMode.Exactly);
            layout1.Measure(msw, msh);
            layout1.Layout(0, 0, r - l, b - t);
        }
    }
}

編譯便可。

最後附上截圖:

 

本文的代碼能夠從https://github.com/Joetangfb/Sharper中獲取。

 

點擊這裏給我發消息

相關文章
相關標籤/搜索