يوضّح لك هذا الدليل التعليمي كيفية إضافة خريطة بتصميم مخصّص إلى تطبيق Android. ويستخدم الدليل التعليمي وضع الليل كمثال على التصميم المخصّص.
باستخدام خيارات الأنماط، يمكنك تخصيص عرض أنماط "خرائط Google" العادية، وتغيير العرض المرئي لميزات مثل الطرق والمتنزهات والأنشطة التجارية وغيرها من نقاط الاهتمام. وهذا يعني أنّه يمكنك التأكيد على مكونات معيّنة من الخريطة أو جعل الخريطة تكمل نمط تطبيقك.
لا تعمل ميزة التصميم إلا على نوع الخريطة normal
. لا يؤثّر التصميم في
الخرائط الداخلية.
الحصول على الشفرة
استنسِخ أو نزِّل مستودع "نماذج Google Maps Android API 2" من GitHub.
إعداد مشروع التطوير
اتّبِع الخطوات التالية لإنشاء المشروع التعليمي في Android Studio.
- نزِّل "استوديو Android" وثبِّته.
- أضِف حزمة خدمات Google Play إلى Android Studio.
- انسخ أو نزِّل مستودع "عيّنات Google Maps Android API 2" إذا لم يسبق لك إجراء ذلك عند بدء قراءة هذا الدليل التعليمي.
استيراد مشروع البرنامج التعليمي:
- في "استوديو Android"، اختَر ملف > جديد > استيراد مشروع.
- انتقِل إلى الموقع الذي حفظت فيه مستودع نماذج Google Maps Android API v2 بعد تنزيله.
- ابحث عن مشروع StyledMap في هذا الموقع:
PATH-TO-SAVED-REPO/android-samples/tutorials/StyledMap
- اختَر دليل المشروع، ثم انقر على حسنًا. ينشئ "استوديو Android" الآن مشروعك باستخدام أداة إنشاء Gradle.
الحصول على مفتاح واجهة برمجة التطبيقات وتفعيل واجهات برمجة التطبيقات اللازمة
لإكمال هذا الدليل التعليمي، تحتاج إلى مفتاح Google API مفوَّض لاستخدام حزمة تطوير البرامج (SDK) لتطبيق "خرائط Google" على Android.
انقر على الزر أدناه للحصول على مفتاح وتفعيل واجهة برمجة التطبيقات.
لمزيد من التفاصيل، يُرجى الاطّلاع على دليل الحصول على مفتاح واجهة برمجة التطبيقات.
إضافة مفتاح واجهة برمجة التطبيقات إلى تطبيقك
- عدِّل ملف
gradle.properties
الخاص بمشروعك. الصِق مفتاح واجهة برمجة التطبيقات في قيمة السمة
GOOGLE_MAPS_API_KEY
. عند إنشاء تطبيقك، ينسخ Gradle مفتاح واجهة برمجة التطبيقات إلى بيان Android التطبيق.GOOGLE_MAPS_API_KEY=PASTE-YOUR-API-KEY-HERE
إنشاء تطبيقك وتشغيله
- وصِّل جهاز Android بالكمبيوتر. اتّبِع التعليمات لتفعيل خيارات المطوّرين على جهاز Android وضبط النظام لرصد الجهاز. (وبدلاً من ذلك، يمكنك استخدام مدير أجهزة Android الافتراضية (AVD) لضبط جهاز افتراضي. عند اختيار محاكي، احرص على اختيار صورة تتضمّن واجهات برمجة التطبيقات من Google. لمعرفة مزيد من التفاصيل، يُرجى الاطّلاع على دليل البدء.)
- في Android Studio، انقر على خيار القائمة تشغيل (أو رمز زر التشغيل). اختَر جهازًا كما هو مطلوب.
يستدعي Android Studio Gradle لإنشاء التطبيق، ثم يشغّل التطبيق على الجهاز أو على المحاكي. من المفترض أن تظهر لك خريطة بتصميم داكن (الوضع الليلي)، مثل الصورة الواردة في هذه الصفحة.
تحرّي الخلل وإصلاحه:
- إذا لم تظهر لك خريطة، تأكَّد من أنّك حصلت على مفتاح واجهة برمجة التطبيقات وأضفته إلى التطبيق، على النحو الموضّح أعلاه. اطّلِع على السجلّ في Android Monitor في "استوديو Android" بحثًا عن رسائل الخطأ المتعلّقة بمفتاح واجهة برمجة التطبيقات.
- استخدِم أدوات تصحيح الأخطاء في "استوديو Android" لعرض السجلات وتصحيح أخطاء التطبيق.
فهم الرمز
يوضّح هذا الجزء من الدليل التعليمي الأجزاء الأكثر أهمية في تطبيق StyledMap لمساعدتك في فهم كيفية إنشاء تطبيق مشابه.
إضافة مورد يحتوي على عنصر بتنسيق JSON
أضِف مرجعًا إلى مشروع التطوير يحتوي على تعريفات الأنماط بتنسيق JSON. يمكنك استخدام مورد خام أو سلسلة، كما هو موضّح في الأمثلة التالية.
المرجع الأوّلي
حدِّد موردًا أوليًا في /res/raw/style_json.json
يحتوي على
بيان نمط JSON لتصميم الوضع الليلي:
مورد سلسلة نصية
حدِّد مورد سلسلة في /res/values/style_strings.xml
،
يحتوي على تعريف نمط JSON لتصميم الوضع الليلي. يستخدم هذا الدليل التمهيدي
اسم السلسلة style_json
. في
هذا الملف، عليك استخدام الشرطة المائلة للخلف لإلغاء علامات الاقتباس:
تمرير كائن نمط JSON إلى خريطتك
لإضافة نمط إلى خريطتك، استخدِم GoogleMap.setMapStyle()
مع تضمين عنصر
MapStyleOptions
يحتوي على بيانات
النمط بتنسيق 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))); } }
يظهر التنسيق (activity_maps_raw.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))); } }
يظهر التنسيق (activity_maps_string.xml
) على النحو التالي:
مزيد من المعلومات عن بيانات أنماط JSON
تستخدِم الخرائط المخصّصة مفهومَين لتطبيق الألوان وتغييرات أخرى في التصميم على الخريطة:
- تحدِّد أدوات الاختيار العناصر الجغرافية التي يمكنك
تصميمها على الخريطة. وتشمل هذه العناصر الطرق والمتنزهات والمسطحات المائية وغيرها، بالإضافة إلى تصنيفاتها. تشمل أدوات الاختيار الميزات
والعناصر، التي يتم تحديدها كسمات
featureType
وelementType
. - أدوات الأسلوب هي خصائص اللون ومستوى الرؤية التي يمكنك تطبيقها على عناصر الخريطة. وتحدِّد هذه القيم اللون المعروض من خلال مزيج من قيم تدرج اللون واللون والسطوع/معامل غاما.
اطّلِع على مرجع الأنماط للحصول على وصف تفصيلي ل options JSON styling.
معالج تصميم "منصة خرائط Google"
استخدِم معالج تنسيق منصة خرائط Google كطريقة سريعة لإنشاء عنصر تنسيق JSON. تتيح حزمة تطوير البرامج (SDK) لـ "خرائط Google" لنظام التشغيل Android استخدام ملفّات تعريف الأنماط نفسها المستخدَمة في واجهة برمجة التطبيقات JavaScript لـ "خرائط Google".
الخطوة التالية
اطّلِع على كيفية إخفاء العناصر على الخريطة باستخدام التنسيق.