بالإضافة إلى تغيير نمط العناصر على الخريطة، يمكنك أيضًا إخفاؤها تمامًا. يوضّح لك هذا المثال كيفية إخفاء نقاط الاهتمام (POI) الخاصة بالأنشطة التجارية ومرموز وسائل النقل العام على خريطتك.
لا تعمل ميزة "التنسيق" إلا على نوع الخريطة normal
. لا يؤثّر التنسيق في
الخرائط الداخلية، لذا فإنّ استخدام التنسيق لإخفاء العناصر لا يمنع
ظهور المخطّطات الأرضية الداخلية على الخريطة.
تمرير كائن بتنسيق JSON إلى خريطتك
لتنسيق خريطتك، استخدِم GoogleMap.setMapStyle()
مع تضمين عنصر
MapStyleOptions
يحتوي على ملف تعريفات
النمط بتنسيق JSON. يمكنك تحميل ملف JSON من مصدر خام أو من سلسلة، كما هو موضّح في الأمثلة التالية:
المورد الأوّلي
يفترض نموذج الرمز البرمجي التالي أنّ مشروعك يحتوي على مورد خام باسم
style_json
:
// Copyright 2020 Google LLC // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package com.example.styledmap; import android.content.res.Resources; import android.os.Bundle; import android.util.Log; import androidx.appcompat.app.AppCompatActivity; import com.google.android.gms.maps.CameraUpdateFactory; import com.google.android.gms.maps.GoogleMap; import com.google.android.gms.maps.OnMapReadyCallback; import com.google.android.gms.maps.SupportMapFragment; import com.google.android.gms.maps.model.LatLng; import com.google.android.gms.maps.model.MapStyleOptions; /** * A styled map using JSON styles from a raw resource. */ public class MapsActivityRaw extends AppCompatActivity implements OnMapReadyCallback { private static final String TAG = MapsActivityRaw.class.getSimpleName(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // Retrieve the content view that renders the map. setContentView(R.layout.activity_maps_raw); // Get the SupportMapFragment and register for the callback // when the map is ready for use. SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager() .findFragmentById(R.id.map); mapFragment.getMapAsync(this); } /** * Manipulates the map when it's available. * The API invokes this callback when the map is ready for use. */ @Override public void onMapReady(GoogleMap googleMap) { try { // Customise the styling of the base map using a JSON object defined // in a raw resource file. boolean success = googleMap.setMapStyle( MapStyleOptions.loadRawResourceStyle( this, R.raw.style_json)); if (!success) { Log.e(TAG, "Style parsing failed."); } } catch (Resources.NotFoundException e) { Log.e(TAG, "Can't find style. Error: ", e); } // Position the map's camera near Sydney, Australia. googleMap.moveCamera(CameraUpdateFactory.newLatLng(new LatLng(-34, 151))); } }
حدِّد مصدرًا أوليًا في /res/raw/style_json.json
يحتوي على
بيان نمط JSON التالي لإخفاء نقاط الاهتمام
(POIs) للأنشطة التجارية:
يخفي تعريف النمط التالي نقاط الاهتمام (POIs) للأنشطة التجارية ورموز وسائل النقل العام:
يظهر التنسيق (activity_maps.xml
) على النحو التالي:
مورد سلسلة نصية
يفترض نموذج الرمز البرمجي التالي أنّ مشروعك يحتوي على مورد سلسلة
باسم style_json
:
package com.example.styledmap; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.util.Log; import com.google.android.gms.maps.CameraUpdateFactory; import com.google.android.gms.maps.GoogleMap; import com.google.android.gms.maps.OnMapReadyCallback; import com.google.android.gms.maps.SupportMapFragment; import com.google.android.gms.maps.model.LatLng; import com.google.android.gms.maps.model.MapStyleOptions; /** * A styled map using JSON styles from a string resource. */ public class MapsActivityString extends AppCompatActivity implements OnMapReadyCallback { private static final String TAG = MapsActivityString.class.getSimpleName(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // Retrieve the content view that renders the map. setContentView(R.layout.activity_maps_string); // Get the SupportMapFragment and register for the callback // when the map is ready for use. SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager() .findFragmentById(R.id.map); mapFragment.getMapAsync(this); } /** * Manipulates the map when it's available. * The API invokes this callback when the map is ready for use. */ @Override public void onMapReady(GoogleMap googleMap) { // Customise the styling of the base map using a JSON object defined // in a string resource file. First create a MapStyleOptions object // from the JSON styles string, then pass this to the setMapStyle // method of the GoogleMap object. boolean success = googleMap.setMapStyle(new MapStyleOptions(getResources() .getString(R.string.style_json))); if (!success) { Log.e(TAG, "Style parsing failed."); } // Position the map's camera near Sydney, Australia. googleMap.moveCamera(CameraUpdateFactory.newLatLng(new LatLng(-34, 151))); } }
حدِّد مورد سلسلة في /res/values/style_strings.xml
،
يحتوي على تعريف نمط JSON التالي لإخفاء نقاط اهتماااام
الأنشطة التجارية. في هذا الملف، عليك استخدام الشرطة المائلة للخلف لإلغاء أثر علامتَي quotation marks:
يخفي تعريف النمط التالي نقاط الاهتمام (POIs) للأنشطة التجارية ورموز وسائل النقل العام:
يظهر التنسيق (activity_maps.xml
) على النحو التالي:
تعريفات أنماط JSON
تستخدِم الخرائط المصمّمة مفهومَين لتطبيق الألوان وتغييرات أخرى في التصميم على الخريطة:
- تحدِّد أداة الاختيار المكوّنات الجغرافية التي يمكنك
تطبيق أنماط عليها على الخريطة. وتشمل هذه المساحات الطرق والمتنزّهات والمسطحات المائية وغيرها، بالإضافة إلى تصنيفاتها. تشمل أدوات الاختيار العناصر
والسمات، ويتم تحديدها كسمتَي
featureType
وelementType
. - أدوات الأسلوب هي خصائص اللون ومستوى الرؤية التي يمكنك تطبيقها على عناصر الخريطة. وتحدِّد هذه القيم اللون المعروض من خلال مزيج من قيم تدرج اللون واللون والسطوع/معامل غاما.
اطّلِع على مرجع الأنماط للحصول على وصف تفصيلي ل options JSON styling.
أداة تصميم الخرائط في "منصة خرائط Google"
استخدِم معالج تنسيق منصة خرائط Google كطريقة سريعة لإنشاء كائن تنسيق JSON. تتوافق حزمة تطوير البرامج بالاستناد إلى بيانات "خرائط Google" لنظام التشغيل Android مع تعريفات الأنماط نفسها المتوافقة مع واجهة برمجة التطبيقات JavaScript API لخرائط Google.
عيّنات التعليمات البرمجية الكاملة
يتضمّن مستودع ApiDemos على GitHub عيّنات توضّح استخدام التنسيق.