IOS实现百度地图自定义大头针和气泡样式

一、自定义大头针和气泡

// 根据anntation生成对应的View
- (BMKAnnotationView *)mapView:(BMKMapView *)mapView viewForAnnotation:(id <BMKAnnotation>)annotation
{
 NSString *AnnotationViewID = [NSString stringWithFormat:@"renameMark%d",i];
 newAnnotation = [[BMKPinAnnotationView alloc] initWithAnnotation:annotation reuseIdentifier:AnnotationViewID];
 // 设置颜色
 ((BMKPinAnnotationView*)newAnnotation).pinColor = BMKPinAnnotationColorPurple;
 // 从天上掉下效果
 ((BMKPinAnnotationView*)newAnnotation).animatesDrop = YES;
 // 设置可拖拽
 ((BMKPinAnnotationView*)newAnnotation).draggable = YES;
 //设置大头针图标
 ((BMKPinAnnotationView*)newAnnotation).image = [UIImage imageNamed:@"zhaohuoche"];
 UIView *popView = [[UIView alloc]initWithFrame:CGRectMake(0, 0, 100, 60)];
 //设置弹出气泡图片
 UIImageView *image = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"wenzi"]];
 image.frame = CGRectMake(0, 0, 100, 60);
 [popView addSubview:image];
 //自定义显示的内容
 UILabel *driverName = [[UILabel alloc]initWithFrame:CGRectMake(0, 3, 100, 20)];
 driverName.text = @"张XX师傅";
 driverName.backgroundColor = [UIColor clearColor];
 driverName.font = [UIFont systemFontOfSize:14];
 driverName.textColor = [UIColor whiteColor];
 driverName.textAlignment = NSTextAlignmentCenter;
 [popView addSubview:driverName];
 UILabel *carName = [[UILabel alloc]initWithFrame:CGRectMake(0, 25, 100, 20)];
 carName.text = @"京A123456";
 carName.backgroundColor = [UIColor clearColor];
 carName.font = [UIFont systemFontOfSize:14];
 carName.textColor = [UIColor whiteColor];
 carName.textAlignment = NSTextAlignmentCenter;
 [popView addSubview:carName];
 BMKActionPaopaoView *pView = [[BMKActionPaopaoView alloc]initWithCustomView:popView];
 pView.frame = CGRectMake(0, 0, 100, 60);
 ((BMKPinAnnotationView*)newAnnotation).paopaoView = nil;
 ((BMKPinAnnotationView*)newAnnotation).paopaoView = pView;
 i++;
 return newAnnotation;
} 

二、气泡自定义内容

最简单,最直接的方法。。。

自定义一个 UIView

核心代码如下:

//改变标注图片和自定义气泡
-(BMKAnnotationView *)mapView:(BMKMapView *)mapView viewForAnnotation:(id<BMKAnnotation>)annotation
{
 BMKAnnotationView *annotationView=[[BMKAnnotationViewalloc]initWithAnnotation:annotationreuseIdentifier:@"myAnnotation"];
 annotationView.image =[UIImageimageNamed:@"bike.gif"];
 //自定义内容气泡
 UIView *areaPaoView=[[UIViewalloc]initWithFrame:CGRectMake(0, 0, 200, 100)];
 areaPaoView.layer.cornerRadius=8;
 areaPaoView.layer.masksToBounds=YES;
 areaPaoView.layer.contents =(id)[UIImageimageNamed:@"pao.png"].CGImage;//这张图片是做好的透明
 //areaPaoView.backgroundColor=[UIColor whiteColor];
  if ([annotation.titleisEqualToString:@"1"]) { //假设title的标题为1,那么就把添加上这个自定义气泡内容
      UILabel * labelNo = [[UILabelalloc]initWithFrame:CGRectMake(10, 0, 200, 30)];
   labelNo.text =[NSStringstringWithFormat:@"站点编号:%@"];
   labelNo.textColor = [UIColorblackColor];
   labelNo.backgroundColor = [UIColorclearColor];
   [areaPaoViewaddSubview:labelNo];
   UILabel * labelStationName = [[UILabelalloc]initWithFrame:CGRectMake(10, 20, 200, 30)];
   labelStationName.text = [NSStringstringWithFormat:@"站点名称:昆山中学"];
   labelStationName.textColor = [UIColorblackColor];
   labelStationName.backgroundColor = [UIColorclearColor];
   [areaPaoViewaddSubview:labelStationName];
   UILabel * labelSumNum = [[UILabelalloc]initWithFrame:CGRectMake(10, 40, 200, 30)];
   labelSumNum.text = [NSStringstringWithFormat:@"总桩数:30"];
   labelSumNum.textColor = [UIColorblackColor];
   labelSumNum.backgroundColor = [UIColorclearColor];
   [areaPaoViewaddSubview:labelSumNum];
   UILabel * labelBicycleNum = [[UILabelalloc]initWithFrame:CGRectMake(10, 60, 200, 30)];
   labelBicycleNum.text = [NSStringstringWithFormat:@"可借车:20"];
   labelBicycleNum.textColor = [UIColorblackColor];
   labelBicycleNum.backgroundColor = [UIColorclearColor];
   [areaPaoViewaddSubview:labelBicycleNum];
 }
 BMKActionPaopaoView *paopao=[[BMKActionPaopaoViewalloc]initWithCustomView:areaPaoView];
 annotationView.paopaoView=paopao;
 return annotationView;
}

三、添加标注自定义气泡

1.首先实现添加多个标注和自定义气泡

添加自定义标注

[_mapView addAnnotations:array];

arry 中放入标注(BMKPointAnnotation)的数组,此方法添加多个标注。

当添加多个标注时就触发以下代理方法

#pragma mark -- BMKMapdelegate
/**
 *根据anntation生成对应的View
 *@param mapView 地图View
 *@param annotation 指定的标注
 *@return 生成的标注View
 */
-(BMKAnnotationView *)mapView:(BMKMapView *)mapView viewForAnnotation:(id <BMKAnnotation>)annotation
{
 if ([annotation isKindOfClass:[BMKPointAnnotation class]]) {
  BMKPinAnnotationView *newAnnotationView = [[BMKPinAnnotationView alloc]initWithAnnotation:annotation reuseIdentifier:@"myAnnotation"];
  newAnnotationView.animatesDrop = YES;
  newAnnotationView.annotation = annotation;
  //这里我根据自己需要,继承了BMKPointAnnotation,添加了标注的类型等需要的信息
  MyBMKPointAnnotation *tt = (MyBMKPointAnnotation *)annotation;
  //判断类别,需要添加不同类别,来赋予不同的标注图片
  if (tt.profNumber == 100000) {
   newAnnotationView.image = [UIImage imageNamed:@"ic_map_mode_category_merchants_normal.png"];
  }else if (tt.profNumber == 100001){
  }
  //设定popView的高度,根据是否含有缩略图
  double popViewH = 60;
  if (annotation.subtitle == nil) {
   popViewH = 38;
  }
  UIView *popView = [[UIView alloc]initWithFrame:CGRectMake(0, 0, ScreenWidth-100, popViewH)];
  popView.backgroundColor = [UIColor whiteColor];
  [popView.layer setMasksToBounds:YES];
  [popView.layer setCornerRadius:3.0];
  popView.alpha = 0.9;
//  //设置弹出气泡图片
//  UIImageView *image = [[UIImageView alloc]initWithImage:[UIImage imageNamed:tt.imgPath]];
//  image.frame = CGRectMake(0, 160, 50, 60);
//  [popView addSubview:image];
  //自定义气泡的内容,添加子控件在popView上
  UILabel *driverName = [[UILabel alloc]initWithFrame:CGRectMake(8, 4, 160, 30)];
  driverName.text = annotation.title;
  driverName.numberOfLines = 0;
  driverName.backgroundColor = [UIColor clearColor];
  driverName.font = [UIFont systemFontOfSize:15];
  driverName.textColor = [UIColor blackColor];
  driverName.textAlignment = NSTextAlignmentLeft;
  [popView addSubview:driverName];
  UILabel *carName = [[UILabel alloc]initWithFrame:CGRectMake(8, 30, 180, 30)];
  carName.text = annotation.subtitle;
  carName.backgroundColor = [UIColor clearColor];
  carName.font = [UIFont systemFontOfSize:11];
  carName.textColor = [UIColor lightGrayColor];
  carName.textAlignment = NSTextAlignmentLeft;
  [popView addSubview:carName];
  if (annotation.subtitle != nil) {
  UIButton *searchBn = [[UIButton alloc]initWithFrame:CGRectMake(170, 0, 50, 60)];
  [searchBn setTitle:@"查看路线" forState:UIControlStateNormal];
  searchBn.backgroundColor = mainColor;
   searchBn.titleLabel.numberOfLines = 0;
  [searchBn addTarget:self action:@selector(searchLine)];
  [popView addSubview:searchBn];
  }
  BMKActionPaopaoView *pView = [[BMKActionPaopaoView alloc]initWithCustomView:popView];
  pView.frame = CGRectMake(0, 0, ScreenWidth-100, popViewH);
  ((BMKPinAnnotationView*)newAnnotationView).paopaoView = nil;
  ((BMKPinAnnotationView*)newAnnotationView).paopaoView = pView;
  return newAnnotationView;
 }
 return nil;
}

点击标注和气泡响应方法

/**
 * 当选中一个annotation views时,调用此接口
 * @param mapView 地图View
 * @param views 选中的annotation views
 */
- (void)mapView:(BMKMapView *)mapView didSelectAnnotationView:(BMKAnnotationView *)view
{
 _shopCoor = view.annotation.coordinate;
}
/**
 * 选中气泡调用方法
 * @param mapView 地图
 * @param view annotation
 */
- (void)mapView:(BMKMapView *)mapView annotationViewForBubble:(BMKAnnotationView *)view
{
 MyBMKPointAnnotation *tt = (MyBMKPointAnnotation *)view.annotation;
 if (tt.shopID) {
  BusinessIfonUVC *BusinessIfonVC = [[BusinessIfonUVC alloc]init];
  BusinessIfonVC.shopId = tt.shopID;
  [self.navigationController pushViewController:BusinessIfonVC animated:YES];
 }
}

2.实现路线搜索,路径规划,获取街道名称等功能

通过经纬度获取地址,逆地理编码

-(void)getStartAddress
{
 //起点地址
 CLGeocoder *Geocoder = [[CLGeocoder alloc]init];
 CLGeocodeCompletionHandler handler = ^(NSArray *place,NSError *error){
  for(CLPlacemark *placemark in place){
   NSString *tmp = [[NSString alloc]init];
   tmp = placemark.subThoroughfare;
   if (tmp == nil) {
    tmp = @"";
   }
   NSString *startAdr = [[NSString alloc]initWithFormat:@"%@%@",placemark.thoroughfare,tmp];
   _startCityText.text = placemark.locality;
   if ([startAdr isEqualToString:@"(null)"]) {
    _startAddrText.text = @"获取地址失败";
   }else{
   _startAddrText.text = startAdr;
   }
 }
 };
 CLLocation *loc = [[CLLocation alloc]initWithLatitude:self.startCoor.latitude longitude:self.startCoor.longitude];
 [Geocoder reverseGeocodeLocation:loc completionHandler:handler];
}

路径检索,该部分没有整理,将乘车和换乘信息放到了LineInfo,steps等模型中。

- (void)onGetTransitRouteResult:(BMKRouteSearch*)searcher result:(BMKTransitRouteResult*)result errorCode:(BMKSearchErrorCode)error
{
 NSMutableArray *lineArr = [[NSMutableArray alloc]init];
 NSArray* array = [NSArray arrayWithArray:_mapView.annotations];
 [_mapView removeAnnotations:array];
 array = [NSArray arrayWithArray:_mapView.overlays];
 [_mapView removeOverlays:array];
 if (error == BMK_SEARCH_NO_ERROR) {
  for(int j = 0; j < [result.routes count];j++)
  {
  NSMutableArray *busTitleArr = [[NSMutableArray alloc]init];
  NSMutableArray *lineStepsArr = [[NSMutableArray alloc]init];
  NSMutableArray *stepsArr = [[NSMutableArray alloc]init];
 //生成数据模型
  LineInfoModel *lineInfo = [[LineInfoModel alloc]init];
  BMKTransitRouteLine* plan = (BMKTransitRouteLine*)[result.routes objectAtIndex:j];
 //数据模型:获得路线长度
  lineInfo.distance = plan.distance;
 //数据模型:获得路线消耗时间
  lineInfo.dates = plan.duration.dates;
  lineInfo.hours = plan.duration.hours;
  lineInfo.minutes = plan.duration.minutes;
  lineInfo.seconds = plan.duration.seconds;
 // 获得轨迹点
  lineInfo.planStepsArr = plan.steps;
  // 计算路线方案中的路段数目
  int size = [plan.steps count];
  int planPointCounts = 0;
  for (int i = 0; i < size; i++) {
   BMKTransitStep* transitStep = [plan.steps objectAtIndex:i];
 //数据模型:获得乘坐公交数组
   DLog(@"%@",transitStep.vehicleInfo.title);
   if (transitStep.vehicleInfo.title) {
    [busTitleArr addObject:transitStep.vehicleInfo.title];
   }
 //数据模型:获取换乘信息
   if (transitStep.instruction) {
    transitStep.instruction = [transitStep.instruction stringByReplacingOccurrencesOfString:@"<font color=\"#313233\">" withString:@""];
    [lineStepsArr addObject:transitStep.instruction];
   }
   DLog(@"%@ %@",transitStep.vehicleInfo.title,transitStep.instruction);
   if(i==0){
    RouteAnnotation* item = [[RouteAnnotation alloc]init];
    item.coordinate = plan.starting.location;
    item.title = @"起点";
    item.type = 0;
//    [_mapView addAnnotation:item]; // 添加起点标注
//
//
    [stepsArr addObject:item];
   }else if(i==size-1){
    RouteAnnotation* item = [[RouteAnnotation alloc]init];
    item.coordinate = plan.terminal.location;
    item.title = @"终点";
    item.type = 1;
    [stepsArr addObject:item];
//    [_mapView addAnnotation:item]; // 添加起点标注
//
   }
   RouteAnnotation* item = [[RouteAnnotation alloc]init];
   item.coordinate = transitStep.entrace.location;
   item.title = transitStep.instruction;
   transitStep.instruction = [transitStep.instruction stringByReplacingOccurrencesOfString:@"<font color=\"#313233\">" withString:@""];
   item.type = 3;
   [stepsArr addObject:item];
//   [_mapView addAnnotation:item];
//
//
//   //轨迹点总数累计
   planPointCounts += transitStep.pointsCount;
  }
  lineInfo.vehicleInfoArr = busTitleArr;
  lineInfo.lineStepsArr = lineStepsArr;
  lineInfo.stepsArr = stepsArr;
  lineInfo.planPointCounts = planPointCounts;
  [lineArr addObject:lineInfo];
//  //轨迹点
//  BMKMapPoint * temppoints = new BMKMapPoint[planPointCounts];
//  int i = 0;
//  for (int j = 0; j < size; j++) {
//   BMKTransitStep* transitStep = [plan.steps objectAtIndex:j];
//   int k=0;
//   for(k=0;k<transitStep.pointsCount;k++) {
//    temppoints[i].x = transitStep.points[k].x;
//    temppoints[i].y = transitStep.points[k].y;
//    i++;
//   }
  }
  self.lineStatusArr = lineArr;
  // 通过points构建BMKPolyline
//  BMKPolyline* polyLine = [BMKPolyline polylineWithPoints:temppoints count:planPointCounts];
//  [_mapView addOverlay:polyLine]; // 添加路线overlay
//  delete []temppoints;
//  }
  [_tableView reloadData];
 }
}
- (void)onGetDrivingRouteResult:(BMKRouteSearch*)searcher result:(BMKDrivingRouteResult*)result errorCode:(BMKSearchErrorCode)error
{
 NSArray* array = [NSArray arrayWithArray:_mapView.annotations];
 [_mapView removeAnnotations:array];
 array = [NSArray arrayWithArray:_mapView.overlays];
 [_mapView removeOverlays:array];
 if (error == BMK_SEARCH_NO_ERROR) {
  BMKDrivingRouteLine* plan = (BMKDrivingRouteLine*)[result.routes objectAtIndex:0];
  // 计算路线方案中的路段数目
  int size = [plan.steps count];
  int planPointCounts = 0;
  for (int i = 0; i < size; i++) {
   BMKDrivingStep* transitStep = [plan.steps objectAtIndex:i];
   if(i==0){
    RouteAnnotation* item = [[RouteAnnotation alloc]init];
    item.coordinate = plan.starting.location;
    item.title = @"起点";
    item.type = 0;
    [_mapView addAnnotation:item]; // 添加起点标注
   }else if(i==size-1){
    RouteAnnotation* item = [[RouteAnnotation alloc]init];
    item.coordinate = plan.terminal.location;
    item.title = @"终点";
    item.type = 1;
    [_mapView addAnnotation:item]; // 添加起点标注
   }
   //添加annotation节点
   RouteAnnotation* item = [[RouteAnnotation alloc]init];
   item.coordinate = transitStep.entrace.location;
   item.title = transitStep.entraceInstruction;
   item.degree = transitStep.direction * 30;
   item.type = 4;
   [_mapView addAnnotation:item];
   //轨迹点总数累计
   planPointCounts += transitStep.pointsCount;
  }
  // 添加途经点
  if (plan.wayPoints) {
   for (BMKPlanNode* tempNode in plan.wayPoints) {
    RouteAnnotation* item = [[RouteAnnotation alloc]init];
    item = [[RouteAnnotation alloc]init];
    item.coordinate = tempNode.pt;
    item.type = 5;
    item.title = tempNode.name;
    [_mapView addAnnotation:item];
   }
  }
  //轨迹点
  BMKMapPoint * temppoints = new BMKMapPoint[planPointCounts];
  int i = 0;
  for (int j = 0; j < size; j++) {
   BMKDrivingStep* transitStep = [plan.steps objectAtIndex:j];
   int k=0;
   for(k=0;k<transitStep.pointsCount;k++) {
    temppoints[i].x = transitStep.points[k].x;
    temppoints[i].y = transitStep.points[k].y;
    i++;
   }
  }
  // 通过points构建BMKPolyline
  BMKPolyline* polyLine = [BMKPolyline polylineWithPoints:temppoints count:planPointCounts];
  [_mapView addOverlay:polyLine]; // 添加路线overlay
  delete []temppoints;
 }
}
- (void)onGetWalkingRouteResult:(BMKRouteSearch*)searcher result:(BMKWalkingRouteResult*)result errorCode:(BMKSearchErrorCode)error
{
 NSArray* array = [NSArray arrayWithArray:_mapView.annotations];
 [_mapView removeAnnotations:array];
 array = [NSArray arrayWithArray:_mapView.overlays];
 [_mapView removeOverlays:array];
 if (error == BMK_SEARCH_NO_ERROR) {
  BMKWalkingRouteLine* plan = (BMKWalkingRouteLine*)[result.routes objectAtIndex:0];
  int size = [plan.steps count];
  int planPointCounts = 0;
  for (int i = 0; i < size; i++) {
   BMKWalkingStep* transitStep = [plan.steps objectAtIndex:i];
   if(i==0){
    RouteAnnotation* item = [[RouteAnnotation alloc]init];
    item.coordinate = plan.starting.location;
    item.title = @"起点";
    item.type = 0;
    [_mapView addAnnotation:item]; // 添加起点标注
   }else if(i==size-1){
    RouteAnnotation* item = [[RouteAnnotation alloc]init];
    item.coordinate = plan.terminal.location;
    item.title = @"终点";
    item.type = 1;
    [_mapView addAnnotation:item]; // 添加起点标注
   }
   //添加annotation节点
   RouteAnnotation* item = [[RouteAnnotation alloc]init];
   item.coordinate = transitStep.entrace.location;
   item.title = transitStep.entraceInstruction;
   item.degree = transitStep.direction * 30;
   item.type = 4;
   [_mapView addAnnotation:item];
   //轨迹点总数累计
   planPointCounts += transitStep.pointsCount;
  }
  //轨迹点
  BMKMapPoint * temppoints = new BMKMapPoint[planPointCounts];
  int i = 0;
  for (int j = 0; j < size; j++) {
   BMKWalkingStep* transitStep = [plan.steps objectAtIndex:j];
   int k=0;
   for(k=0;k<transitStep.pointsCount;k++) {
    temppoints[i].x = transitStep.points[k].x;
    temppoints[i].y = transitStep.points[k].y;
    i++;
   }
  }
  // 通过points构建BMKPolyline
  BMKPolyline* polyLine = [BMKPolyline polylineWithPoints:temppoints count:planPointCounts];
  [_mapView addOverlay:polyLine]; // 添加路线overlay
  delete []temppoints;
 }
}

3.画路径

我这里实现是跳转到另一个控制器中了,下面是他一些需要的数据

//路线长度
@property (nonatomic,assign) int distance;
//路线消耗时间
@property (nonatomic,assign) int dates;
@property (nonatomic,assign) int hours;
@property (nonatomic,assign) int minutes;
@property (nonatomic,assign) int seconds;
//交通工具数组
@property (nonatomic,strong) NSArray *vehicleInfoArr;
//换乘信息
@property (nonatomic,strong) NSArray *lineStepsArr;
//节点
@property (nonatomic,strong) NSArray *stepsArr;
//轨迹点个数
@property (nonatomic,assign) int planPointCounts;
//轨迹点
@property (nonatomic,strong) NSArray *planStepsArr;

接下来是画路经,关于乘车数据的展示,就是一个tableview上添加了手势,不做解释。

-(void)drawMap
{
 BMKPointAnnotation* item = [[BMKPointAnnotation alloc]init];
 item = [_lineInfo.stepsArr firstObject];
 [_mapView setCenterCoordinate:item.coordinate];
 [_mapView addAnnotations:_lineInfo.stepsArr];
 BMKMapPoint* temppoints = (BMKMapPoint *)malloc(sizeof(CLLocationCoordinate2D) * _lineInfo.planPointCounts);
 int i = 0;
 for (int j = 0; j < [_lineInfo.planStepsArr count]; j++) {
   BMKTransitStep* transitStep = [_lineInfo.planStepsArr objectAtIndex:j];
   int k=0;
   for(k=0;k<transitStep.pointsCount;k++) {
    temppoints[i].x = transitStep.points[k].x;
    temppoints[i].y = transitStep.points[k].y;
    i++;
  }
 }
 BMKPolyline* polyLine =[BMKPolyline polylineWithPoints:temppoints count:_lineInfo.planPointCounts];
 if (nil != polyLine) {
   [_mapView addOverlay:polyLine]; // 添加路线overlay
 }
 free(temppoints);
}
- (BMKOverlayView*)mapView:(BMKMapView *)map viewForOverlay:(id<BMKOverlay>)overlay
{
 if ([overlay isKindOfClass:[BMKPolyline class]]) {
  BMKPolylineView* polylineView = [[BMKPolylineView alloc] initWithOverlay:overlay];
  polylineView.fillColor = [[UIColor cyanColor] colorWithAlphaComponent:1];
  polylineView.strokeColor = [[UIColor blueColor] colorWithAlphaComponent:0.7];
  polylineView.lineWidth = 3.0;
  return polylineView;
 }
 return nil;
}
// 判断标注类型,来处理
- (BMKAnnotationView*)getRouteAnnotationView:(BMKMapView *)mapview viewForAnnotation:(MyBMKPointAnnotation*)routeAnnotation
{
 BMKAnnotationView* view = nil;
 switch (routeAnnotation.type) {
  case 0:
  {
   view = [mapview dequeueReusableAnnotationViewWithIdentifier:@"start_node"];
   if (view == nil) {
    view = [[BMKAnnotationView alloc]initWithAnnotation:routeAnnotation reuseIdentifier:@"start_node"];
    view.image = [UIImage imageWithContentsOfFile:[self getMyBundlePath1:@"images/icon_nav_start.png"]];
    view.centerOffset = CGPointMake(0, -(view.frame.size.height * 0.5));
    view.canShowCallout = TRUE;
   }
   view.annotation = routeAnnotation;
  }
   break;
  case 1:
  {
   view = [mapview dequeueReusableAnnotationViewWithIdentifier:@"end_node"];
   if (view == nil) {
    view = [[BMKAnnotationView alloc]initWithAnnotation:routeAnnotation reuseIdentifier:@"end_node"];
    view.image = [UIImage imageWithContentsOfFile:[self getMyBundlePath1:@"images/icon_nav_end.png"]];
    view.centerOffset = CGPointMake(0, -(view.frame.size.height * 0.5));
    view.canShowCallout = TRUE;
   }
   view.annotation = routeAnnotation;
  }
   break;
  case 2:
  {
   view = [mapview dequeueReusableAnnotationViewWithIdentifier:@"bus_node"];
   if (view == nil) {
    view = [[BMKAnnotationView alloc]initWithAnnotation:routeAnnotation reuseIdentifier:@"bus_node"];
    view.image = [UIImage imageWithContentsOfFile:[self getMyBundlePath1:@"images/icon_nav_bus.png"]];
    view.canShowCallout = TRUE;
   }
   view.annotation = routeAnnotation;
  }
   break;
  case 3:
  {
   view = [mapview dequeueReusableAnnotationViewWithIdentifier:@"rail_node"];
   if (view == nil) {
    view = [[BMKAnnotationView alloc]initWithAnnotation:routeAnnotation reuseIdentifier:@"rail_node"];
    view.image = [UIImage imageWithContentsOfFile:[self getMyBundlePath1:@"images/icon_nav_rail.png"]];
    view.canShowCallout = TRUE;
   }
   view.annotation = routeAnnotation;
  }
   break;
  case 4:
  {
   view = [mapview dequeueReusableAnnotationViewWithIdentifier:@"route_node"];
   if (view == nil) {
    view = [[BMKAnnotationView alloc]initWithAnnotation:routeAnnotation reuseIdentifier:@"route_node"];
    view.canShowCallout = TRUE;
   } else {
    [view setNeedsDisplay];
   }
   UIImage* image = [UIImage imageWithContentsOfFile:[self getMyBundlePath1:@"images/icon_direction.png"]];
   view.image = [image imageRotatedByDegrees:routeAnnotation.degree];
   view.annotation = routeAnnotation;
  }
   break;
  case 5:
  {
   view = [mapview dequeueReusableAnnotationViewWithIdentifier:@"waypoint_node"];
   if (view == nil) {
    view = [[BMKAnnotationView alloc]initWithAnnotation:routeAnnotation reuseIdentifier:@"waypoint_node"];
    view.canShowCallout = TRUE;
   } else {
    [view setNeedsDisplay];
   }
   UIImage* image = [UIImage imageWithContentsOfFile:[self getMyBundlePath1:@"images/icon_nav_waypoint.png"]];
   view.image = [image imageRotatedByDegrees:routeAnnotation.degree];
   view.annotation = routeAnnotation;
  }
   break;
  default:
   break;
 }
 return view;
}
- (BMKAnnotationView *)mapView:(BMKMapView *)view viewForAnnotation:(id <BMKAnnotation>)annotation
{
 if ([annotation isKindOfClass:[BMKPointAnnotation class]]) {
  return [self getRouteAnnotationView:view viewForAnnotation:(MyBMKPointAnnotation *)annotation];
 }
 return nil;
}
- (UIImage*)imageRotatedByDegrees:(CGFloat)degrees
{
 CGFloat width = CGImageGetWidth(self.CGImage);
 CGFloat height = CGImageGetHeight(self.CGImage);
 CGSize rotatedSize;
 rotatedSize.width = width;
 rotatedSize.height = height;
 UIGraphicsBeginImageContext(rotatedSize);
 CGContextRef bitmap = UIGraphicsGetCurrentContext();
 CGContextTranslateCTM(bitmap, rotatedSize.width/2, rotatedSize.height/2);
 CGContextRotateCTM(bitmap, degrees * M_PI / 180);
 CGContextRotateCTM(bitmap, M_PI);
 CGContextScaleCTM(bitmap, -1.0, 1.0);
 CGContextDrawImage(bitmap, CGRectMake(-rotatedSize.width/2, -rotatedSize.height/2, rotatedSize.width, rotatedSize.height), self.CGImage);
 UIImage* newImage = UIGraphicsGetImageFromCurrentImageContext();
 UIGraphicsEndImageContext();
 return newImage;
}

四、另一种方法

///////////////////////////////
if ([annotation isKindOfClass:[SiteAnnotation class]]) {
   static NSString *identifier = @"MKAnnotationView";
   BMKAnnotationView *pin = [mapView dequeueReusableAnnotationViewWithIdentifier:identifier];
   if (pin == nil) {
    pin = [[BMKAnnotationView alloc] initWithAnnotation:annotation reuseIdentifier:identifier];
    //在图中我们可以看到图标的上方,有个气泡弹窗里面写着当前用户的位置所在地
    pin.image = [UIImage imageNamed:@"default_marker.png"];
   }
   pin.annotation = annotation;
   pin.paopaoView = [[BMKActionPaopaoView alloc]initWithCustomView:[[UIView alloc] init]];
   return pin;
  } 

以上所述是小编给大家介绍的IOS实现百度地图自定义大头针和气泡样式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • iOS百度地图简单使用详解

    百度地图 iOS SDK是一套基于iOS 5.0及以上版本设备的应用程序接口,不仅提供展示地图的基本接口,还提供POI检索.路径规划.地图标注.离线地图.定位.周边雷达等丰富的LBS能力 . 今天主要介绍以下接口 基础地图 POI检索 定位 首先配置环境 1.自动配置.framework形式开发包(使用CocoaPods)<推荐> 2.手动配置.framework形式开发包 特别注意: (API里有很多注意点,大家可以具体去看.但是我说的后两点少其中一个都会失败,第一点是有需求的话,必须加上)

  • IOS百度地图导航开发功能实现简述

    以下通过图文并茂的方式给大家讲述百度地图导航开发功能: 第一步:在使用百度导航之前,我们需要在百度地图开放平台上下载导航的 SDK,共85.8M,网速不好的同学可提前准备好. 第二步:引入导航所需的系统包 将AudioToolbox.framework.ImageIO.framework.CoreMotion.framework.CoreLocation.framework.CoreTelephony.framework.MediaPlayer.framework.AVFoundation.fr

  • ios百度地图的使用(普通定位、反地理编码)

    iOS定位 - 普通定位(没有地图) - 反地理编码(得到具体位置),下面通过代码给大家详解,代码如下: #import <CoreLocation/CoreLocation.h> 使用到的头文件 要引入CoreLocation这个包 <CLLocationManagerDelegate> 使用的代理名称 //1.使用定位服务 //设置app有访问定位服务的权限 //在使用应用期间 / 始终(app在后台) //info.plist文件添加以下两条(或者其中一条): //NSLoc

  • IOS实现百度地图自定义大头针和气泡样式

    一.自定义大头针和气泡 // 根据anntation生成对应的View - (BMKAnnotationView *)mapView:(BMKMapView *)mapView viewForAnnotation:(id <BMKAnnotation>)annotation { NSString *AnnotationViewID = [NSString stringWithFormat:@"renameMark%d",i]; newAnnotation = [[BMKPi

  • Android百度地图自定义公交路线导航

    一.问题描述 基于百度地图实现检索指定城市指定公交的交通路线图,效果如图所示 二.通用组件Application类,主要创建并初始化BMapManager public class App extends Application { static App mDemoApp; //百度MapAPI的管理类 public BMapManager mBMapMan = null; // 授权Key // 申请地址:http://dev.baidu.com/wiki/static/imap/key/ p

  • android实现百度地图自定义弹出窗口功能

    我们使用百度地图的时候,点击地图上的Marker,会弹出一个该地点详细信息的窗口,如下左图所示,有时候,我们希望自己定义这个弹出窗口的内容,或者,干脆用自己的数据来构造这样的弹出窗口,但是,在百度地图最新的Android SDK中,没有方便操作这种弹出窗口的类,虽然有一个PopupOverlay,但是它只支持将弹出内容转化为不多于三个Bitmap,如果这个弹出窗口里想有按钮来响应点击事件,用这个就不能满足要求了,于是,看了一遍百度地图覆盖物的API,我决定用自定义View的方法来实现类似的效果,

  • iOS实现百度地图定位签到功能

    写在前面: 项目需求用到这个功能,主要目的是实现老师设置位置签到范围,学生在一定范围内进行签到的功能. 功能如下方截图: 屏幕快照 2019-01-28 上午10.29.26.png 简要介绍: 下面记录一下主要的实现流程,功能的实现主要是根据百度地图开发者官网提供的api文档,各项功能之间组合.百度地图的SDK现在分成了地图功能和定位功能两块不同的SDK,BaiduMapAPI这个是基础的地图功能,BMKLocationKit这个是定位功能.项目里实现定位签到功能用的的SDK包括上面说的这两个

  • iOS实现百度地图拖拽后更新位置以及反编码

    前言 最近在开发中遇到了百度地图的开发,功能类似于微信中的发送位置,拖拽从新定位,以及反编码,列表附近的位置.分析出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 效果图: 百度地图拖拽更新位置.gif 实现思路 思路就是将一个UIImageView固定在地图中间,每次更新位置,给UIImageView添加动画即可. 代码如下: #import "FTBasicController.h" typedef void (^SelectBlock) (NSString *addr

  • 在网页中插入百度地图的步骤详解

    第一步:进入百度创建地图的网站http://api.map.baidu.com/lbsapi/creatmap/,搜索出自己要展示的位置,如下图所示. 第二步:设置地图,大家可以对网站显示地图的宽高进行设置,其余选项不动. 第三步:添加标注.点击第一个图标后,在右侧找到自己的位置,单击鼠标左键可定位.标记图标处可更换图标形状,名称和备注填入位置相关信息. 第四步:获取代码.将代码贴到你的网页里 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tra

  • Android百度地图添加Marker失真问题的解决方案

    Marker失真问题 由于公司项目原因,用了很多次百度地图API,基础的地图定位.显示地图就不多说了,这里主要说一下百度地图添加Marker图标. 最开始接触百度地图添加Marker图标的时候,发现自己设置的图标是多大地图上就显示多大,感觉有点失真,看起来很不舒服,但通过网上搜索,并没有找到解决办法,就没怎么注意图标失真的问题,毕竟是一个小项目,不是面向大众的,最近开发的一个项目同样有这个需求,而且是面向大众开发的,我就想为什么摩拜单车的图标那么清晰,我的图标却失真. 就是这么清晰 通过Reso

  • Vue2项目中对百度地图的封装使用详解

    目录 需求 知识点 实现 打点控件封装 代码总览 代码 总结 百度地图的使用: vue项目,有个 vue-baidu-map 可以用,但是好久不更新了. React项目,百度官方出了个React版的,可以直接用,React-BMapGL. 除此以外,百度官方的都是 JavaScript API,这里以此来用vue封装下,方便使用. 需求 组件按需引入.个人喜欢代码干干净净,只要项目需要的功能就行了 简单的封装下,方便直接按官方文档使用需要的功能,方便复用 基于Vue2 .JavaScript A

随机推荐