پلتفرم را انتخاب کنید: Android iOS JavaScript این صفحه یک راهنمای سریع برای طراحی نقشه شما با استفاده از حالت شب به عنوان مثال است.
نمای کلی
با گزینههای سبک میتوانید نمایش سبکهای استاندارد نقشه Google را سفارشی کنید، نمایش بصری ویژگیهایی مانند جادهها، پارکها، مشاغل و سایر نقاط مورد علاقه را تغییر دهید. این بدان معنی است که می توانید بر اجزای خاصی از نقشه تأکید کنید یا نقشه را مکمل سبک برنامه خود کنید.
یک ظاهر طراحی شده فقط در نوع نقشه kGMSTypeNormal
کار می کند.
اعمال سبک ها در نقشه شما
برای اعمال سبکهای نقشه سفارشی روی نقشه، با GMSMapStyle(...)
تماس بگیرید تا یک نمونه GMSMapStyle
ایجاد کنید، یک URL برای یک فایل JSON محلی یا یک رشته JSON حاوی تعاریف سبک ارسال کنید. نمونه GMSMapStyle
را به ویژگی mapStyle
نقشه اختصاص دهید.
استفاده از فایل JSON
مثال های زیر فراخوانی GMSMapStyle(...)
و ارسال URL برای یک فایل محلی را نشان می دهد:
سویفت
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 زیر را برای استایلسازی در حالت شب جایگذاری کنید:
نمایش/پنهان کردن JSON
[
{
"featureType": "all",
"elementType": "geometry",
"stylers": [
{
"color": "#242f3e"
}
]
},
{
"featureType": "all",
"elementType": "labels.text.stroke",
"stylers": [
{
"lightness": -80
}
]
},
{
"featureType": "administrative",
"elementType": "labels.text.fill",
"stylers": [
{
"color": "#746855"
}
]
},
{
"featureType": "administrative.locality",
"elementType": "labels.text.fill",
"stylers": [
{
"color": "#d59563"
}
]
},
{
"featureType": "poi",
"elementType": "labels.text.fill",
"stylers": [
{
"color": "#d59563"
}
]
},
{
"featureType": "poi.park",
"elementType": "geometry",
"stylers": [
{
"color": "#263c3f"
}
]
},
{
"featureType": "poi.park",
"elementType": "labels.text.fill",
"stylers": [
{
"color": "#6b9a76"
}
]
},
{
"featureType": "road",
"elementType": "geometry.fill",
"stylers": [
{
"color": "#2b3544"
}
]
},
{
"featureType": "road",
"elementType": "labels.text.fill",
"stylers": [
{
"color": "#9ca5b3"
}
]
},
{
"featureType": "road.arterial",
"elementType": "geometry.fill",
"stylers": [
{
"color": "#38414e"
}
]
},
{
"featureType": "road.arterial",
"elementType": "geometry.stroke",
"stylers": [
{
"color": "#212a37"
}
]
},
{
"featureType": "road.highway",
"elementType": "geometry.fill",
"stylers": [
{
"color": "#746855"
}
]
},
{
"featureType": "road.highway",
"elementType": "geometry.stroke",
"stylers": [
{
"color": "#1f2835"
}
]
},
{
"featureType": "road.highway",
"elementType": "labels.text.fill",
"stylers": [
{
"color": "#f3d19c"
}
]
},
{
"featureType": "road.local",
"elementType": "geometry.fill",
"stylers": [
{
"color": "#38414e"
}
]
},
{
"featureType": "road.local",
"elementType": "geometry.stroke",
"stylers": [
{
"color": "#212a37"
}
]
},
{
"featureType": "transit",
"elementType": "geometry",
"stylers": [
{
"color": "#2f3948"
}
]
},
{
"featureType": "transit.station",
"elementType": "labels.text.fill",
"stylers": [
{
"color": "#d59563"
}
]
},
{
"featureType": "water",
"elementType": "geometry",
"stylers": [
{
"color": "#17263c"
}
]
},
{
"featureType": "water",
"elementType": "labels.text.fill",
"stylers": [
{
"color": "#515c6d"
}
]
},
{
"featureType": "water",
"elementType": "labels.text.stroke",
"stylers": [
{
"lightness": -20
}
]
}
]
استفاده از منبع رشته ای
مثالهای زیر فراخوانی 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
برای تعریف گزینه های سبک، رشته سبک زیر را به عنوان مقدار متغیر kMapStyle
قرار دهید:
نمایش/پنهان کردن JSON
@"["
@" {"
@" \"featureType\": \"all\","
@" \"elementType\": \"geometry\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#242f3e\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"all\","
@" \"elementType\": \"labels.text.stroke\","
@" \"stylers\": ["
@" {"
@" \"lightness\": -80"
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"administrative\","
@" \"elementType\": \"labels.text.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#746855\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"administrative.locality\","
@" \"elementType\": \"labels.text.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#d59563\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"poi\","
@" \"elementType\": \"labels.text.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#d59563\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"poi.park\","
@" \"elementType\": \"geometry\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#263c3f\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"poi.park\","
@" \"elementType\": \"labels.text.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#6b9a76\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"road\","
@" \"elementType\": \"geometry.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#2b3544\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"road\","
@" \"elementType\": \"labels.text.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#9ca5b3\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"road.arterial\","
@" \"elementType\": \"geometry.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#38414e\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"road.arterial\","
@" \"elementType\": \"geometry.stroke\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#212a37\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"road.highway\","
@" \"elementType\": \"geometry.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#746855\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"road.highway\","
@" \"elementType\": \"geometry.stroke\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#1f2835\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"road.highway\","
@" \"elementType\": \"labels.text.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#f3d19c\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"road.local\","
@" \"elementType\": \"geometry.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#38414e\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"road.local\","
@" \"elementType\": \"geometry.stroke\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#212a37\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"transit\","
@" \"elementType\": \"geometry\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#2f3948\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"transit.station\","
@" \"elementType\": \"labels.text.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#d59563\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"water\","
@" \"elementType\": \"geometry\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#17263c\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"water\","
@" \"elementType\": \"labels.text.fill\","
@" \"stylers\": ["
@" {"
@" \"color\": \"#515c6d\""
@" }"
@" ]"
@" },"
@" {"
@" \"featureType\": \"water\","
@" \"elementType\": \"labels.text.stroke\","
@" \"stylers\": ["
@" {"
@" \"lightness\": -20"
@" }"
@" ]"
@" }"
@"]"
اعلان های سبک JSON
نقشه های سبک از دو مفهوم برای اعمال رنگ ها و سایر تغییرات سبک در نقشه استفاده می کنند:
- انتخابگرها اجزای جغرافیایی را مشخص میکنند که میتوانید روی نقشه استایل دهید. اینها شامل جاده ها، پارک ها، منابع آبی و موارد دیگر و همچنین برچسب های آنها می شود. انتخابگرها شامل ویژگیها و عناصر هستند که به عنوان ویژگیهای
featureType
و elementType
مشخص میشوند. - استایلرها ویژگیهای رنگ و دید هستند که میتوانید روی عناصر نقشه اعمال کنید. آنها رنگ نمایش داده شده را از طریق ترکیبی از مقادیر رنگ، رنگ و روشنایی/گاما تعریف می کنند.
برای توضیحات مفصل گزینه های سبک JSON به مرجع سبک مراجعه کنید.
جادوگر استایلینگ پلتفرم نقشه ها