سيتوفّر تصميم الخريطة الجديد قريبًا على "منصة خرائط Google". يتضمن هذا التحديث على تصميم الخريطة لوحة ألوان تلقائية جديدة وتحسينات على تجارب الخرائط وسهولة الاستخدام. سيتم تعديل جميع أنماط الخرائط تلقائيًا في آذار (مارس) 2025. للمزيد من المعلومات عن مدى التوفّر وكيفية تفعيل الميزة في وقت سابق، يُرجى الاطّلاع على نمط الخريطة الجديد في "منصة خرائط Google".
هذه الصفحة هي دليل سريع لتصميم خريطتك، باستخدام الوضع الليلي كمثال.
نظرة عامة
باستخدام خيارات الأنماط، يمكنك تخصيص عرض أنماط "خرائط Google" العادية، وتغيير العرض المرئي لميزات مثل الطرق والمتنزهات والأعمال التجارية وغيرها من نقاط الاهتمام. وهذا يعني أنّه يمكنك التأكيد على
مكونات معيّنة من الخريطة أو جعل الخريطة تكمل نمط
تطبيقك.
لا تعمل ميزة التصميم إلا على نوع الخريطة kGMSTypeNormal.
تطبيق الأنماط على خريطتك
لتطبيق أنماط خرائط مخصّصة على خريطة، استخدِم GMSMapStyle(...) لإنشاء مثيل
GMSMapStyle، مع إدخال عنوان URL لملف JSON على الجهاز أو سلسلة
JSON تحتوي على تعريفات الأنماط. عيِّن مثيل GMSMapStyle للسمة
mapStyle في الخريطة.
استخدام ملف JSON
تعرض الأمثلة التالية استدعاء GMSMapStyle(...) وضبط عنوان URL لملف
محلي:
Swift
importGoogleMapsclassMapStyling:UIViewController{// Set the status bar style to complement night-mode.overridevarpreferredStatusBarStyle:UIStatusBarStyle{return.lightContent}overridefuncloadView(){letcamera=GMSCameraPosition.camera(withLatitude:-33.86,longitude:151.20,zoom:14.0)letmapView=GMSMapView.map(withFrame:CGRect.zero,camera:camera)do{// Set the map style by passing the URL of the local file.ifletstyleURL=Bundle.main.url(forResource:"style",withExtension:"json"){mapView.mapStyle=tryGMSMapStyle(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}}
Objective-C
#import "MapStyling.h"@importGoogleMaps;@interfaceMapStyling()@end@implementationMapStyling// Set the status bar style to complement night-mode.-(UIStatusBarStyle)preferredStatusBarStyle{returnUIStatusBarStyleLightContent;}-(void)loadView{GMSCameraPosition*camera=[GMSCameraPositioncameraWithLatitude:-33.86longitude:151.20zoom:12];GMSMapView*mapView=[GMSMapViewmapWithFrame:CGRectZerocamera:camera];mapView.myLocationEnabled=YES;NSBundle*mainBundle=[NSBundlemainBundle];NSURL*styleUrl=[mainBundleURLForResource:@"style"withExtension:@"json"];NSError*error;// Set the map style by passing the URL for style.json.GMSMapStyle*style=[GMSMapStylestyleWithContentsOfFileURL:styleUrlerror:&error];if(!style){NSLog(@"The style definition could not be loaded: %@",error);}mapView.mapStyle=style;self.view=mapView;}@end
لتحديد خيارات التصميم، أضِف ملفًا جديدًا إلى مشروعك باسم style.json،
ولصِق بيان نمط JSON التالي لتصميم الوضع الليلي:
توضّح الأمثلة التالية استدعاء GMSMapStyle(...) ونقل مرجع
سلسلة:
Swift
classMapStylingStringResource:UIViewController{letMapStyle="JSON_STYLE_GOES_HERE"// Set the status bar style to complement night-mode.overridevarpreferredStatusBarStyle:UIStatusBarStyle{return.lightContent}overridefuncloadView(){letcamera=GMSCameraPosition.camera(withLatitude:-33.86,longitude:151.20,zoom:14.0)letmapView=GMSMapView.map(withFrame:CGRect.zero,camera:camera)do{// Set the map style by passing a valid JSON string.mapView.mapStyle=tryGMSMapStyle(jsonString:MapStyle)}catch{NSLog("One or more of the map styles failed to load. \(error)")}self.view=mapView}}
Objective-C
@implementationMapStylingStringResource// Paste the JSON string to use.staticNSString*constkMapStyle=@"JSON_STYLE_GOES_HERE";// Set the status bar style to complement night-mode.-(UIStatusBarStyle)preferredStatusBarStyle{returnUIStatusBarStyleLightContent;}-(void)loadView{GMSCameraPosition*camera=[GMSCameraPositioncameraWithLatitude:-33.86longitude:151.20zoom:12];GMSMapView*mapView=[GMSMapViewmapWithFrame:CGRectZerocamera:camera];mapView.myLocationEnabled=YES;NSError*error;// Set the map style by passing a valid JSON string.GMSMapStyle*style=[GMSMapStylestyleWithJSONString:kMapStyleerror:&error];if(!style){NSLog(@"The style definition could not be loaded: %@",error);}mapView.mapStyle=style;self.view=mapView;}@end
لتحديد خيارات التصميم، الصِق سلسلة التصميم التالية كقيمةvarikMapStyle:
تستخدِم الخرائط المخصّصة مفهومَين لتطبيق الألوان وتغييرات أخرى في التصميم على
الخريطة:
تحدِّد أدوات الاختيار العناصر الجغرافية التي يمكنك
تصميمها على الخريطة. وتشمل هذه العناصر الطرق والمتنزهات والمسطحات المائية وغيرها، بالإضافة إلى تصنيفاتها. تشمل أدوات الاختيار الميزات
والعناصر، التي يتم تحديدها كسمات featureType و
elementType.
أدوات الأسلوب هي خصائص اللون ومستوى الرؤية التي يمكنك
تطبيقها على عناصر الخريطة. وتحدِّد هذه القيم اللون المعروض من خلال
مزيج من قيم تدرج اللون واللون والسطوع/معامل غاما.
اطّلِع على مرجع الأنماط للحصول على وصف تفصيلي ل options
JSON styling.
استخدِم معالج تنسيق منصة خرائط Google كطريقة سريعة
لإنشاء عنصر تنسيق JSON. تتيح حزمة تطوير البرامج (SDK) لتطبيق "خرائط Google" على نظام التشغيل iOS استخدام
بيانات الأنماط نفسها المستخدَمة في واجهة برمجة التطبيقات JavaScript API لتطبيق "خرائط Google".
عيّنات التعليمات البرمجية الكاملة
يتضمّن مستودع ApiDemos على GitHub
عيّنات توضّح استخدام التنسيق.
تاريخ التعديل الأخير: 2025-01-14 (حسب التوقيت العالمي المتفَّق عليه)
[null,null,["تاريخ التعديل الأخير: 2025-01-14 (حسب التوقيت العالمي المتفَّق عليه)"],[[["This guide provides instructions for styling Google Maps using JSON to customize the appearance of map elements."],["You can style your map using a local JSON file or a JSON string, applying it to the `mapStyle` property of the map."],["JSON style declarations consist of selectors (`featureType`, `elementType`) to target map components and stylers to define their visual properties."],["Leverage the Maps Platform Styling Wizard to easily create custom JSON styles and apply them to your maps."],["Styling is applicable only to the `kGMSTypeNormal` map type and offers flexibility in highlighting or blending map features with your application's design."]]],[]]