关于自带 MapKit 的简单应用,地图定位

@interface TwoViewController ()<MKMapViewDelegate,CLLocationManagerDelegate>

@property(nonatomic,strong)MKMapView *mapView;

@end
  
        _mapView =[[MKMapView alloc]initWithFrame:self.view.frame];
        _mapView.delegate=self;//设置代理
        _mapView.zoomEnabled=YES;//设置缩放
        _mapView.scrollEnabled=YES;//设置滚动
        _mapView.pitchEnabled=YES;
        _mapView.rotateEnabled=YES;//设置旋转
        _mapView.mapType =MKMapTypeStandard;//类型
        _mapView.showsUserLocation=YES;//显示区域
- (void)viewDidLoad {
    [super viewDidLoad];
    self.view.backgroundColor=[UIColor whiteColor];
    [self.view addSubview:self.mapView];
    
    UIBarButtonItem *bar1 =[[UIBarButtonItem alloc]initWithTitle:@"省会位置" style:
    UIBarButtonItemStylePlain target:self action:@selector(locateProvince)];
    UIBarButtonItem *bar2 =[[UIBarButtonItem alloc]initWithTitle:@"当前位置" style:
    UIBarButtonItemStylePlain target:self action:@selector(locateCurrentLocation)];
    self.navigationItem.rightBarButtonItems=@[bar1,bar2];
    
    
}
-(void)getmap:(NSString *)name
{
    CLGeocoder *geocoder =[[CLGeocoder alloc]init];
    [geocoder geocodeAddressString:name completionHandler:^(NSArray<CLPlacemark *> * _Nullable placemarks, NSError * _Nullable error) {
        
        CLPlacemark *place =[placemarks lastObject];
        CLLocation *loc =place.location;
        
        dispatch_async(dispatch_get_main_queue(), ^{
            
            [self.mapView setRegion:MKCoordinateRegionMake(loc.coordinate, MKCoordinateSpanMake(0.1, 0.1)) animated:YES];
            MKCircle *circle =[MKCircle circleWithCenterCoordinate:loc.coordinate radius:100];
            //添加图像覆盖层
            [self.mapView addOverlay:circle];
        });
    }];
    
}
-(MKOverlayRenderer *)mapView:(MKMapView *)mapView rendererForOverlay:(id<MKOverlay>)overlay
{
    MKCircle *circle =(MKCircle *)overlay;
    MKCircleRenderer *circleView =[[MKCircleRenderer alloc]initWithCircle:circle];
    circleView.fillColor =[UIColor redColor];
    circleView.strokeColor=[UIColor yellowColor];
    circleView.alpha=0.3;
    return circleView;
}

-(void)locateProvince
{
    [self getmap:city];
    
}
-(void)locateCurrentLocation
{
    [self getmap:@"齐齐哈尔火车站"];
}

#import <CoreLocation/CoreLocation.h>

- (void)locateToLatitude:(CGFloat)latitude longitude:(CGFloat)longitude

{

    // 设置地图中心的经、纬度

    CLLocationCoordinate2D center = {latitude , longitude};

    // 也可以使用如下方式设置经、纬度

    //    center.latitude = latitude;

    //    center.longitude = longitude;

    // 设置地图显示的范围,

    MKCoordinateSpan span;

    // 地图显示范围越小,细节越清楚

    span.latitudeDelta = 0.01;

    span.longitudeDelta = 0.01;

    // 创建MKCoordinateRegion对象,该对象代表了地图的显示中心和显示范围。

    MKCoordinateRegion region = {center,span};

    // 设置当前地图的显示中心和显示范围

    [self.mapView setRegion:region animated:YES];

}

// MKMapViewDelegate协议中的方法,当MKMapView显示区域将要发生改变时激发该方法

- (void)mapView:(MKMapView *)mapView regionWillChangeAnimated:(BOOL)animated

{

    NSLog(@"地图控件的显示区域将要发生改变!");

}

// MKMapViewDelegate协议中的方法,当MKMapView显示区域改变完成时激发该方法

- (void)mapView:(MKMapView *)mapView regionDidChangeAnimated:(BOOL)animated

{

    NSLog(@"地图控件的显示区域完成了改变!");

}

// MKMapViewDelegate协议中的方法,当MKMapView开始加载数据时激发该方法

- (void) mapViewWillStartLoadingMap:(MKMapView *)mapView

{

    NSLog(@"地图控件开始加载地图数据!");

}

// MKMapViewDelegate协议中的方法,当MKMapView加载数据完成时激发该方法

- (void) mapViewDidFinishLoadingMap:(MKMapView *)mapView

{

    NSLog(@"地图控件加载地图数据完成!");

}

// MKMapViewDelegate协议中的方法,当MKMapView加载数据失败时激发该方法

- (void) mapViewDidFailLoadingMap:(MKMapView *)mapView

    withError:(NSError *)error

{

    NSLog(@"地图控件加载地图数据发生错误,错误信息 %@!" , error);

}

// MKMapViewDelegate协议中的方法,当MKMapView开始渲染地图时激发该方法

- (void) mapViewWillStartRenderingMap:(MKMapView *)mapView

{

    NSLog(@"地图控件开始渲染地图!");

}

// MKMapViewDelegate协议中的方法,当MKMapView渲染地图完成时激发该方法

- (void) mapViewDidFinishRenderingMap:(MKMapView *)mapView

    fullyRendered:(BOOL)fullyRendered

{

    NSLog(@"地图控件渲染地图完成!");

}

转载于:https://my.oschina.net/chenchen9654321/blog/672435

以下是对提供的参考资料的总结,按照要求结构化多个要点分条输出: 4G/5G无线网络优化与网规案例分析: NSA站点下终端掉4G问题:部分用户反馈NSA终端频繁掉4G,主要因终端主动发起SCGfail导致。分析显示,在信号较好的环境下,终端可能因节能、过热保护等原因主动释放连接。解决方案建议终端侧进行分析处理,尝试关闭节电开关等。 RSSI算法识别天馈遮挡:通过计算RSSI平均值及差值识别天馈遮挡,差值大于3dB则认定有遮挡。不同设备分组规则不同,如64T和32T。此方法可有效帮助现场人员识别因环境变化引起的网络问题。 5G 160M组网小区CA不生效:某5G站点开启100M+60M CA功能后,测试发现UE无法正常使用CA功能。问题原因在于CA频点集标识配置错误,修正后测试正常。 5G网络优化与策略: CCE映射方式优化:针对诺基亚站点覆盖农村区域,通过优化CCE资源映射方式(交织、非交织),提升RRC连接建立成功率和无线接通率。非交织方式相比交织方式有显著提升。 5G AAU两扇区组网:与三扇区组网相比,AAU两扇区组网在RSRP、SINR、下载速率和上传速率上表现不同,需根据具体场景选择适合的组网方式。 5G语音解决方案:包括沿用4G语音解决方案、EPS Fallback方案和VoNR方案。不同方案适用于不同的5G组网策略,如NSA和SA,并影响语音连续性和网络覆盖。 4G网络优化与资源利用: 4G室分设备利旧:面对4G网络投资压减与资源需求矛盾,提出利旧多维度调优策略,包括资源整合、统筹调配既有资源,以满足新增需求和提质增效。 宏站RRU设备1托N射灯:针对5G深度覆盖需求,研究使用宏站AAU结合1托N射灯方案,快速便捷地开通5G站点,提升深度覆盖能力。 基站与流程管理: 爱立信LTE基站邻区添加流程:未提供具体内容,但通常涉及邻区规划、参数配置、测试验证等步骤,以确保基站间顺畅切换和覆盖连续性。 网络规划与策略: 新高铁跨海大桥覆盖方案试点:虽未提供详细内容,但可推测涉及高铁跨海大桥区域的4G/5G网络覆盖规划,需考虑信号穿透、移动性管理、网络容量等因素。 总结: 提供的参考资料涵盖了4G/5G无线网络优化、网规案例分析、网络优化策略、资源利用、基站管理等多个方面。 通过具体案例分析,展示了无线网络优化中的常见问题及解决方案,如NSA终端掉4G、RSSI识别天馈遮挡、CA不生效等。 强调了5G网络优化与策略的重要性,包括CCE映射方式优化、5G语音解决方案、AAU扇区组网选择等。 提出了4G网络优化与资源利用的策略,如室分设备利旧、宏站RRU设备1托N射灯等。 基站与流程管理方面,提到了爱立信LTE基站邻区添加流程,但未给出具体细节。 新高铁跨海大桥覆盖方案试点展示了特殊场景下的网络规划需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值