Настройка маркера

Выберите платформу: Android iOS JavaScript

Скриншот разных кастомов маркеры

Расширенные маркеры используют два класса для определения маркеров: класс GMSAdvancedMarker предоставляет возможности маркеров по умолчанию, а GMSPinImageOptions содержит параметры для дальнейшей настройки. На этой странице показано, как настроить маркеры следующими способами:

  • Изменить цвет фона
  • Изменить цвет границы
  • Изменение цвета глифа
  • Изменение текста глифа
  • Поддержка пользовательских представлений и анимации с помощью свойства iconView.
Части расширенного маркера
Рисунок 1. Части усовершенствованного маркера.

Изменить цвет фона

Используйте параметр GMSPinImageOptions.backgroundColor чтобы изменить цвет фона маркера.

Быстрый

//...

let options = GMSPinImageOptions()
options.backgroundColor = .blue

let pinImage = GMSPinImage(options: options)
advancedMarker.icon = pinImage

advancedMarker.map = mapView

Цель-C

//...

GMSPinImageOptions *options = [[GMSPinImageOptions alloc] init];
options.backgroundColor = [UIColor blueColor];

GMSPinImage *pin = [GMSPinImage pinImageWithOptions:options];
customTextMarker.icon = pin;

customTextMarker.map = mapView;

Изменить цвет границы

Используйте параметр GMSPinImageOptions.borderColor чтобы изменить цвет фона маркера.

Быстрый

//...

let options = GMSPinImageOptions()
options.borderColor = .blue

let pinImage = GMSPinImage(options: options)
advancedMarker.icon = pinImage

advancedMarker.map = mapView

Цель-C

//...

GMSPinImageOptions *options = [[GMSPinImageOptions alloc] init];
options.backgroundColor = [UIColor blueColor];

GMSPinImage *pin = [GMSPinImage pinImageWithOptions:options];
advancedMarker.icon = pin;

advancedMarker.map = mapView;

Изменение цвета глифа

Используйте GMSPinImageGlyph.glyphColor чтобы изменить цвет фона маркера.

Быстрый

//...

let options = GMSPinImageOptions()

let glyph = GMSPinImageGlyph(glyphColor: .yellow)
options.glyph = glyph

let glyphColor = GMSPinImage(options: options)

advancedMarker.icon = glyphColor
advancedMarker.map = mapView

Цель-C

//...

GMSPinImageOptions *options = [[GMSPinImageOptions alloc] init];

options.glyph = [[GMSPinImageGlyph alloc] initWithGlyphColor:[UIColor yellowColor]];
GMSPinImage *glyphColor = [GMSPinImage pinImageWithOptions:options];

advancedMarker.icon = glyphColor;
advancedMarker.map = mapView;

Изменение текста глифа

Используйте GMSPinImageGlyph , чтобы изменить текст глифа маркера.

Быстрый

//...

let options = GMSPinImageOptions()

let glyph = GMSPinImageGlyph(text: "ABC", textColor: .white)
options.glyph = glyph

let pinImage = GMSPinImage(options: options)

advancedMarker.icon = pinImage
advancedMarker.map = mapView

Цель-C

//...

GMSPinImageOptions *options = [[GMSPinImageOptions alloc] init];

options.glyph = [[GMSPinImageGlyph alloc] initWithText:@"ABC" textColor:[UIColor whiteColor]];
GMSPinImage *pin = [GMSPinImage pinImageWithOptions:options];

customTextMarker.icon = pin;
customTextMarker.map = mapView;

Поддержка пользовательских представлений и анимации с помощью свойства iconView

Подобно GMSMarker , GMSAdvancedMarker также поддерживает маркеры с iconView . Свойство iconView поддерживает анимацию всех анимируемых свойств UIView кроме рамки и центра. Он не поддерживает маркеры с iconViews и icons отображаемыми на одной карте.

Быстрый

//...

let advancedMarker = GMSAdvancedMarker(position: coordinate)
advancedMarker.iconView = customView()
advancedMarker.map = mapView

func customView() -> UIView {
// return your custom UIView.
}

Цель-C

//...

GMSAdvancedMarker *advancedMarker = [GMSAdvancedMarker markerWithPosition:kCoordinate];
advancedMarker.iconView = [self customView];
advancedMarker.map = self.mapView;

-   (UIView *)customView {
  // return custom view
}

Ограничения макета

GMSAdvancedMarker напрямую не поддерживает ограничения макета для своего iconView . Однако вы можете установить ограничения макета для элементов пользовательского интерфейса внутри iconView . При создании представления frame или size объекта должны быть переданы маркеру.

Быстрый

//do not set advancedMarker.iconView.translatesAutoresizingMaskIntoConstraints = false

let advancedMarker = GMSAdvancedMarker(position: coordinate)
let customView = customView()

//set frame
customView.frame = CGRect(0, 0, width, height)

advancedMarker.iconView = customView

Цель-C

//do not set advancedMarker.iconView.translatesAutoresizingMaskIntoConstraints = NO;

GMSAdvancedMarker *advancedMarker = [GMSAdvancedMarker markerWithPosition:kCoordinate];

CustomView *customView = [self customView];

//set frame
customView.frame = CGRectMake(0, 0, width, height);

advancedMarker.iconView = customView;