地圖自定義錨點+覆蓋物
匯入系統庫
通過拖控制元件的方式:
程式碼實現
匯入標頭檔案
#import< MapKit/MapKit.h>//地圖
#import <CoreLocation/CoreLocation.h>//定位
新增 <MKMapViewDelegate > 協議
@property (weak, nonatomic) IBOutlet MKMapView *mapView;
@property (weak, nonatomic) IBOutlet UITextField *weiduTf;
@property (weak, nonatomic) IBOutlet UITextField *jingduTf;
//地理編碼
@property(strong,nonatomic)CLGeocoder *geocoder;
- (void)viewDidLoad {
[super viewDidLoad];
//初始化地理編碼
_geocoder= [[CLGeocoder alloc]init];
//設定地圖的顯示風格,此處設定使用標準地圖
self.mapView.mapType=MKMapTypeStandard;
//設定地圖可縮放
self.mapView.zoomEnabled=YES;
//設定地圖可滾動
self.mapView.scrollEnabled=YES;
//設定地圖可旋轉
self.mapView.rotateEnabled=YES;
//設定顯示使用者當前位置
self.mapView.showsUserLocation=YES;
//呼叫自己實現的方法設定地圖的顯示位置和顯示區域
[self locateToLatitude:37.23 longitude:122.1234];
//建立手勢物件 (覆蓋物手勢)
UITapGestureRecognizer *tap =[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tapAction:)];
//配置屬性
//輕拍次數
tap.numberOfTapsRequired =1;
//輕拍手指
tap.numberOfTouchesRequired =1;
//新增到檢視
[self.view addGestureRecognizer:tap];
// 建立一個手勢處理器,用於檢測、處理長按手勢(錨點手勢)
UILongPressGestureRecognizer* gesture = [[UILongPressGestureRecognizer alloc]initWithTarget:self action:@selector(longPress:)];
//為該控制元件新增手勢處理器
[self.view addGestureRecognizer:gesture];
//遵守代理是要實現自定義錨點
self.mapView.delegate=self;
}
按鈕方法
- (IBAction)chazhao:(id)sender {
//緯度
NSString* latitudeStr =self.weiduTf.text;
//經度
NSString* longtitudeStr =self.jingduTf.text;
//如果使用者輸入的經度、緯度不為空
if(latitudeStr !=nil&& latitudeStr.length>0
&& longtitudeStr !=nil&& longtitudeStr.length>0)
{
//呼叫自己實現的方法設定地圖的顯示位置和顯示區域
[self locateToLatitude:latitudeStr.floatValue
longitude:longtitudeStr.floatValue];
}
}
手勢方法
#pragma mark --手勢回撥
- (void) longPress:(UILongPressGestureRecognizer*)gesture{
//獲取長按點的座標
CGPoint pos = [gesture locationInView:self.mapView];
//將長按點的座標轉換為經度、維度值
CLLocationCoordinate2D coord = [self.mapView convertPoint:pos toCoordinateFromView:self.mapView];
//將經度、維度值包裝為CLLocation物件
CLLocation* location = [[CLLocation alloc]initWithLatitude:coord.latitude
longitude:coord.longitude];
//根據經、緯度反向解析地址
[_geocoder reverseGeocodeLocation:location completionHandler:
^(NSArray*placemarks,NSError*error)
{
if(placemarks.count>0&& error ==nil)
{
//獲取解析得到的第一個地址資訊
CLPlacemark* placemark = [placemarks objectAtIndex:0];
//獲取地址資訊中的FormattedAddressLines對應的詳細地址
NSArray* addrArray = placemark
.addressDictionary[@"FormattedAddressLines"];
//將詳細地址拼接成一個字串
NSMutableString* address = [[NSMutableString alloc]init];
for(int i =0; i < addrArray.count; i ++)
{
[address appendString:addrArray[i]];
}
//建立MKPointAnnotation物件——代表一個錨點
MKPointAnnotation*annotation = [[MKPointAnnotation alloc]init];
annotation.title= placemark.name;
annotation.subtitle= address;
annotation.coordinate= coord;
//新增錨點
[self.mapView addAnnotation:annotation];
}
}];
}
# pragma 點按手勢回撥
//輕拍事件
-(void)tapAction:(UITapGestureRecognizer *)tap
{
// 獲取長按點的座標
CGPoint pos = [tap locationInView:self.mapView];
// 將長按點的座標轉換為經度、維度值
CLLocationCoordinate2D coord = [self.mapView convertPoint:pos
toCoordinateFromView:self.mapView];
// 建立MKCircle物件,該物件代表覆蓋層
MKCircle* circle = [MKCircle circleWithCenterCoordinate:coord radius:100];
// 新增MKOverlay
[self.mapView addOverlay:circle level:MKOverlayLevelAboveLabels];
}
自定義封裝定位方法
- (void)locateToLatitude:(CGFloat)latitude longitude:(CGFloat)longitude{
//設定地圖中心的經、緯度
CLLocationCoordinate2D center = {latitude , longitude};
//設定地圖顯示的範圍,
MKCoordinateSpan span;
//地圖顯示範圍越小,細節越清楚
span.latitudeDelta=0.01;
span.longitudeDelta=0.01;
//建立MKCoordinateRegion物件,該物件代表了地圖的顯示中心和顯示範圍。
MKCoordinateRegion region = {center,span};
//設定當前地圖的顯示中心和顯示範圍
[self.mapView setRegion:region animated:YES];
//建立MKPointAnnotation物件——代表一個錨點
MKPointAnnotation* annotation = [[MKPointAnnotation alloc]init];
annotation.title=@"北京石羿科技發展有限公司";
annotation.subtitle=@"海淀區中關村軟體園";
CLLocationCoordinate2D coordinate = {latitude , longitude};
annotation.coordinate= coordinate;
//新增錨點
[self.mapView addAnnotation:annotation];
}
#pragma mark -自定義錨點
// MKMapViewDelegate協議中的方法,該方法的返回值可用於定製錨點控制元件的外觀
- (MKAnnotationView*) mapView:(MKMapView*)mapView
viewForAnnotation:(id) annotation{
static NSString *annoId =@"fkAnno";
//獲取可重用的錨點控制元件
MKAnnotationView *annoView = [mapView
dequeueReusableAnnotationViewWithIdentifier:annoId];
//如果可重用的錨點控制元件不存在,建立新的可重用錨點控制元件
if(!annoView)
{
annoView= [[MKAnnotationView alloc]initWithAnnotation:annotation reuseIdentifier:annoId];
/*
如果不想改變錨點控制元件的圖片,只想改變顏色,則可建立MKPinAnnotationView例項
再修改MKPinAnnotationView物件的pinColor屬性即可。
*/
}
//為錨點控制元件設定圖片
annoView.image= [UIImage imageNamed:@"1.png"];
//設定該錨點控制元件是否可顯示氣泡資訊
annoView.canShowCallout=YES;
//定義一個按鈕,用於為錨點控制元件設定附加控制元件
UIButton *button = [UIButton buttonWithType:UIButtonTypeDetailDisclosure];
//為按鈕繫結事件處理方法
[button addTarget:self action:@selector(buttonTapped:)
forControlEvents:UIControlEventTouchUpInside];
//可通過錨點控制元件的rightCalloutAccessoryView、leftCalloutAccessoryView設定附加控制元件
annoView.rightCalloutAccessoryView= button;
return annoView;
}
#pragma mark -自定義錨點--裡面的詳情按鈕
- (void) buttonTapped:(id)sender
{
NSLog(@"您點選了錨點資訊!");
}
// MKMapViewDelegate協議中的方法,該方法返回的MKOverlayRenderer負責繪製覆蓋層控制元件- (MKOverlayRenderer *)mapView:(MKMapView *)mapViewrendererForOverlay:(id)overlay
{
MKCircle * circle = (MKCircle*)overlay;
// 建立一個MKCircleRenderer物件
MKCircleRenderer* render = [[MKCircleRenderer alloc] initWithCircle:circle];
// 設定MKCircleRenderer的透明度
render.alpha = 0.5;
// 設定MKCircleRenderer的填充顏色和邊框顏色
render.fillColor = [UIColor blueColor];
render.strokeColor = [UIColor redColor];
return render;
}
最終效果
覆蓋物效果
相關文章
- 百度地圖 ~ 覆蓋物地圖
- 【高德地圖API】從零開始學高德JS API(三)覆蓋物——標註|折線|多邊形|資訊視窗|聚合marker|麻點圖|圖片覆蓋物地圖APIJS
- 百度地圖javascript開發,刪除指定覆蓋物方法地圖JavaScript
- 222.map4-百度地圖新增覆蓋物地圖
- Datazen自定義地圖地圖
- 高德地圖自定義Marker點選時出現的InfoWindow地圖
- Angular CDK Overlay 彈出覆蓋物Angular
- 自定義百度地圖元件地圖元件
- Android 自定義 地圖 室內Android地圖
- Datazen地圖Chart自定義資料地圖
- 百度地圖API新增自定義標註多點標註地圖API
- 【爬坑日記】ivew中自定義css覆蓋原樣式無效CSS
- Android自定義View——從零開始實現覆蓋翻頁效果AndroidView
- 百度地圖大擴張:覆蓋全球1/4國家地圖
- 百度地圖API : 自定義標註圖示地圖API
- vue中使用高德地圖自定義開發Vue地圖
- Google Express現已覆蓋美國90%地區GoExpress
- ArcGIS API for Silverlight 點選地圖彈出自定義窗體API地圖
- 自定義室內地圖-商場室內地圖線上編輯工具地圖
- 二分圖最小點覆蓋等於二分圖最大匹配
- Dynamics CRM 匯入解決方案時如何做到不覆蓋目標系統的站點地圖地圖
- 自定義室內地圖線上工具編輯停車場室內地圖地圖
- 最小路徑可重複點覆蓋
- 如何實現OSM地圖本地釋出並自定義配圖地圖
- 最大匹配、最小頂點覆蓋、最大獨立集、最小路徑覆蓋(轉)(再轉)
- FineReport中如何用JavaScript自定義地圖示籤JavaScript地圖
- WIFI網路覆蓋的定義是什麼WiFi
- vue實現根據多選框按鈕,動態給百度地圖新增和刪除相應的覆蓋物Vue地圖
- iOS自定義控制元件:自定義TableView、CollectionView空資料佔點陣圖iOS控制元件View
- 演算法題:頂點覆蓋問題演算法
- Echarts 中國地圖各個省市自治區自定義顏色Echarts地圖
- ChinaMapInfoView - 基於 Android 的中國地圖自定義 ViewAPIViewAndroid地圖
- HTML 錨點定位HTML
- 錨點的使用
- Mysql索引覆蓋MySql索引
- 最小圓覆蓋
- 自定義Map集合,將重複的鍵值對不進行覆蓋而是進行疊加
- 用HMS Core地圖服務自定義地圖樣式,給你的應用製作專屬個性化地圖地圖