مخفی کردن ویژگی های نقشه با یک ظاهر طراحی

پلتفرم را انتخاب کنید: Android iOS JavaScript

علاوه بر تغییر سبک ویژگی‌های روی نقشه، می‌توانید آنها را به طور کامل پنهان کنید. این مثال به شما نشان می دهد که چگونه نقاط مورد علاقه تجاری (POI) و نمادهای حمل و نقل عمومی را روی نقشه خود پنهان کنید.

یک ظاهر طراحی شده فقط در نوع نقشه kGMSTypeNormal کار می کند.

اعمال سبک ها در نقشه شما

برای اعمال سبک‌های نقشه سفارشی روی نقشه، با GMSMapStyle(...) تماس بگیرید تا یک نمونه GMSMapStyle ایجاد کنید، یک URL برای یک فایل JSON محلی یا یک رشته JSON حاوی تعاریف سبک ارسال کنید. نمونه GMSMapStyle را به ویژگی mapStyle نقشه اختصاص دهید.

استفاده از فایل JSON

مثال های زیر فراخوانی GMSMapStyle(...) و ارسال URL برای یک فایل محلی را نشان می دهد:

نمونه کد زیر فرض می کند که پروژه شما حاوی فایلی به نام style.json است:

سویفت

import GoogleMaps

class MapStyling: UIViewController {

  // Set the status bar style to complement night-mode.
  override var preferredStatusBarStyle: UIStatusBarStyle {
    return .lightContent
  }

  override func loadView() {
    let camera = GMSCameraPosition.camera(withLatitude: -33.86, longitude: 151.20, zoom: 14.0)
    let mapView = GMSMapView.map(withFrame: CGRect.zero, camera: camera)

    do {
      // Set the map style by passing the URL of the local file.
      if let styleURL = Bundle.main.url(forResource: "style", withExtension: "json") {
        mapView.mapStyle = try GMSMapStyle(contentsOfFileURL: styleURL)
      } else {
        NSLog("Unable to find style.json")
      }
    } catch {
      NSLog("One or more of the map styles failed to load. \(error)")
    }

    self.view = mapView
  }
}
      

هدف-C

#import "MapStyling.h"
@import GoogleMaps;

@interface MapStyling ()

@end

@implementation MapStyling

// Set the status bar style to complement night-mode.
- (UIStatusBarStyle)preferredStatusBarStyle {
  return UIStatusBarStyleLightContent;
}

- (void)loadView {
  GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:-33.86
                                                          longitude:151.20
                                                               zoom:12];
  GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera];
  mapView.myLocationEnabled = YES;

  NSBundle *mainBundle = [NSBundle mainBundle];
  NSURL *styleUrl = [mainBundle URLForResource:@"style" withExtension:@"json"];
  NSError *error;

  // Set the map style by passing the URL for style.json.
  GMSMapStyle *style = [GMSMapStyle styleWithContentsOfFileURL:styleUrl error:&error];

  if (!style) {
    NSLog(@"The style definition could not be loaded: %@", error);
  }

  mapView.mapStyle = style;
  self.view = mapView;
}

@end
      

برای تعریف گزینه‌های سبک، یک فایل جدید به نام style.json را به پروژه خود اضافه کنید و اعلان سبک JSON زیر را برای پنهان کردن نقاط مورد علاقه تجاری (POI) و نمادهای حمل‌ونقل عمومی جای‌گذاری کنید:

استفاده از منبع رشته ای

مثال‌های زیر فراخوانی GMSMapStyle() و ارسال یک منبع رشته را نشان می‌دهند:

سویفت

class MapStylingStringResource: UIViewController {

  let MapStyle = "JSON_STYLE_GOES_HERE"

  // Set the status bar style to complement night-mode.
  override var preferredStatusBarStyle: UIStatusBarStyle {
    return .lightContent
  }

  override func loadView() {
    let camera = GMSCameraPosition.camera(withLatitude: -33.86, longitude: 151.20, zoom: 14.0)
    let mapView = GMSMapView.map(withFrame: CGRect.zero, camera: camera)

    do {
      // Set the map style by passing a valid JSON string.
      mapView.mapStyle = try GMSMapStyle(jsonString: MapStyle)
    } catch {
      NSLog("One or more of the map styles failed to load. \(error)")
    }

    self.view = mapView
  }
}
      

هدف-C

@implementation MapStylingStringResource

// Paste the JSON string to use.
static NSString *const kMapStyle = @"JSON_STYLE_GOES_HERE";

// Set the status bar style to complement night-mode.
- (UIStatusBarStyle)preferredStatusBarStyle {
  return UIStatusBarStyleLightContent;
}

- (void)loadView {
  GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:-33.86
                                                          longitude:151.20
                                                               zoom:12];
  GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera];
  mapView.myLocationEnabled = YES;

  NSError *error;

  // Set the map style by passing a valid JSON string.
  GMSMapStyle *style = [GMSMapStyle styleWithJSONString:kMapStyle error:&error];

  if (!style) {
    NSLog(@"The style definition could not be loaded: %@", error);
  }

  mapView.mapStyle = style;
  self.view = mapView;
}

@end
      

اعلان سبک زیر نقاط مورد علاقه تجاری (POI) و نمادهای حمل و نقل عمومی را پنهان می کند. رشته سبک زیر را به عنوان مقدار متغیر kMapStyle قرار دهید:

اعلان های سبک JSON

نقشه های سبک از دو مفهوم برای اعمال رنگ ها و سایر تغییرات سبک در نقشه استفاده می کنند:

  • انتخابگرها اجزای جغرافیایی را مشخص می‌کنند که می‌توانید روی نقشه استایل دهید. اینها شامل جاده ها، پارک ها، منابع آبی و موارد دیگر و همچنین برچسب های آنها می شود. انتخابگرها شامل ویژگی‌ها و عناصر هستند که به عنوان ویژگی‌های featureType و elementType مشخص می‌شوند.
  • استایلرها ویژگی‌های رنگ و دید هستند که می‌توانید روی عناصر نقشه اعمال کنید. آنها رنگ نمایش داده شده را از طریق ترکیبی از مقادیر رنگ، رنگ و روشنایی/گاما تعریف می کنند.

برای توضیحات مفصل گزینه های سبک JSON به مرجع سبک مراجعه کنید.

جادوگر استایلینگ پلتفرم نقشه ها

از Maps Platform Styling Wizard به عنوان یک راه سریع برای تولید یک شی استایل JSON استفاده کنید. Maps SDK برای iOS از اعلان‌های سبک مشابه با Maps JavaScript API پشتیبانی می‌کند.

نمونه کد کامل

مخزن ApiDemos در GitHub شامل نمونه هایی است که استفاده از استایل را نشان می دهد.