Расширенные маркеры используют два класса для определения маркеров: класс GMSAdvancedMarker
предоставляет возможности маркеров по умолчанию, а GMSPinImageOptions
содержит параметры для дальнейшей настройки. На этой странице показано, как настроить маркеры следующими способами:
- Изменить цвет фона
- Изменить цвет границы
- Изменить цвет глифа
- Изменение текста глифа
- Поддержка пользовательских представлений и анимации с помощью свойства iconView.
Изменить цвет фона
Используйте параметр 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;