لمتابعة رحلة في تطبيق المستهلك، تحتاج أولاً إلى تحديد خريطة وإضافة الدعم للخرائط المتجهة، إذا لزم الأمر.
لإعداد خريطة في تطبيقك، اتبع الخطوات التالية:
- تحديد جزء من الخريطة لمشاركة الرحلة:
- يمكنك إضافة دعم للطبقة الأساسية للخرائط ووحدة التحكّم بالعرض.
- إضافة إمكانية استخدام رسومات المتجهات في Android لعرض المتجه الخرائط، إذا لزم الأمر.
بعد تحديد الخريطة، يمكنك إضافة طرق عرض وكاميرا إضافية عناصر التحكم التي تريد تخصيص التجربة المرئية. لمزيد من التفاصيل، راجع تصميم الخريطة.
الخطوة 1: تحديد جزء من الخريطة لمشاركة الرحلة
يمكنك تحديد الخريطة من خلال إضافة جزء من الخريطة أو عرض الخريطة لإنشاء مكان تشارك رحلة عند الطلب في تطبيق المستهلك. لتحديد خريطتك، اتّبِع إحدى الطرق التالية:
ConsumerMapFragment
: استخدِم هذا العمود لتحديد خريطتكFragment
ConsumerMapView
: استخدِم هذا العمود لتحديد خريطة باستخدامView
تعتبر الميزات متماثلة في أي من الطريقتين، لذا اختر طريقة بشكل أفضل لتطبيقك.
يتم شرح كلا الطريقتين بمزيد من التفصيل في القسم التالي.
إضافة جزء من الخريطة أو عرضها
لإنشاء خريطة لعرض تقدم الرحلة باستخدام أي مما يلي جزء Android أو طريقة عرض، اتبع هذه الخطوات وراجع أمثلة على التعليمات البرمجية.
تحديد جزء أو طريقة عرض في ملف XML لتخطيط التطبيق الموجود في
/res/layout
حدد خريطة مشاركة الرحلة إما كجزء باستخدامConsumerMapFragment
، أو كعرض باستخدامConsumerMapView
.يوفر الجزء أو طريقة العرض بعد ذلك إمكانية الوصول إلى الرحلة مشاركة خريطة يمكن لتطبيقك الوصول إليها وتعديلها. توفر الخريطة أيضًا المقبض إلى
ConsumerController
، والذي يسمح لتطبيقك بالتحكم تخصيص تجربة مشاركة الرحلة.من طريقة
onCreate()
، يمكنك الاتصال بالرقمgetConsumerGoogleMapAsync(callback)
، الذي يعرضConsumerGoogleMap
بشكل غير متزامن في معاودة الاتصال.استخدِم "
ConsumerGoogleMap
" لعرض مدى تقدُّم الرحلة وتعديلها حسب الحاجة.
مثال على كيفية إضافة ConsumerMapFragment
تحديد الجزء في ملف XML لتنسيق التطبيق، كما هو موضّح في مثال التعليمة البرمجية التالي.
<fragment xmlns:android="http://schemas.android.com/apk/res/android" android:name="com.google.android.libraries.mapsplatform.transportation.consumer.view.ConsumerMapFragment" android:id="@+id/consumer_map_fragment" android:layout_width="match_parent" android:layout_height="match_parent" />
إجراء مكالمة مع "
getConsumerGoogleMapAsync()
" من خلال "onCreate()
" .
Java
public class SampleAppActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
// Find the ConsumerMapFragment.
ConsumerMapFragment consumerMapFragment =
(ConsumerMapFragment) fragmentManager.findFragmentById(R.id.consumer_map_fragment);
// Initiate the callback that returns the map.
if (consumerMapFragment != null) {
consumerMapFragment.getConsumerGoogleMapAsync(
new ConsumerMapReadyCallback() {
// The map returned in the callback is used to access the ConsumerController.
@Override
public void onConsumerMapReady(@NonNull ConsumerGoogleMap consumerGoogleMap) {
ConsumerController consumerController = consumerGoogleMap.getConsumerController();
}
});
}
}
}
Kotlin
class SampleAppActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
// Find the ConsumerMapFragment.
val consumerMapFragment =
fragmentManager.findFragmentById(R.id.consumer_map_fragment) as ConsumerMapFragment
consumerMapFragment.getConsumerGoogleMapAsync(
object : ConsumerMapReadyCallback() {
override fun onConsumerMapReady(consumerGoogleMap: ConsumerGoogleMap) {
val consumerController = consumerGoogleMap.getConsumerController()!!
}
}
)
}
}
مثال على كيفية إضافة ConsumerMapView
استخدم طريقة العرض إما في جزء أو في نشاط، كما هو محدد في ملف XML.
<com.google.android.libraries.mapsplatform.transportation.consumer.view.ConsumerMapView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/consumer_map_view" android:layout_width="match_parent" android:layout_height="match_parent" />
يمكنك إجراء مكالمة من "
onCreate()
" إلى "getConsumerGoogleMapAsync()
". ضِمن بالإضافة إلى مَعلمة معاودة الاتصال، عليك تضمين التفاصيل التالية:النشاط أو الجزء الذي يتضمّن الصورة قاعدة النشاط أو التجزئة يجب أن تكون الفئة
FragmentActivity
أوFragment
لفريق الدعم. (على التوالي)، نظرًا لأنها تتيح الوصول إلى مراحل نشاطها.GoogleMapOptions
(يمكن أن تكون قيمة خالية)، تحتوي على الإعدادات لـMapView
.
Java
public class SampleAppActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
ConsumerMapView mapView = findViewById(R.id.consumer_map_view);
if (mapView != null) {
mapView.getConsumerGoogleMapAsync(
new ConsumerMapReadyCallback() {
// The map returned in the callback is used to access the ConsumerController.
@Override
public void onConsumerMapReady(@NonNull ConsumerGoogleMap consumerGoogleMap) {
ConsumerController consumerController = consumerGoogleMap.getConsumerController();
}
}, this, null);
}
}
}
Kotlin
class SampleAppActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
val mapView = findViewById(R.id.consumer_map_view) as ConsumerMapView
mapView.getConsumerGoogleMapAsync(
object : ConsumerMapReadyCallback() {
// The map returned in the callback is used to access the ConsumerController.
override fun onConsumerMapReady(consumerGoogleMap: ConsumerGoogleMap) {
val consumerController = consumerGoogleMap.getConsumerController()!!
}
},
/* fragmentActivity= */ this,
/* googleMapOptions= */ null,
)
}
}
علامة MapView
في أحد الأجزاء هي نفسها في المثال السابق
MapView
في أحد الأنشطة، إلا أن الجزء يُضخّم التنسيق الذي
على MapView
في طريقة onCreateView()
للجزء.
Java
public class MapViewInFragment extends Fragment {
@Override
public View onCreateView(
@NonNull LayoutInflater layoutInflater,
@Nullable ViewGroup viewGroup,
@Nullable Bundle bundle) {
return layoutInflater.inflate(R.layout.consumer_map_view, viewGroup, false);
}
}
Kotlin
class MapViewInFragment : Fragment() {
override fun onCreateView(
layoutInflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?,
): View {
return layoutInflater.inflate(R.layout.consumer_map_view, viewGroup, false)
}
}
الخطوة 2: إضافة دعم للطبقة الأساسية للخرائط ووحدة التحكّم في العرض
لتفعيل ميزة "مشاركة الرحلة" في تطبيقك، أضِف
الصفوف التالية إلى تطبيقك: ConsumerGoogleMap
وConsumerController
.
احصل على
ConsumerGoogleMap
منConsumerMapFragment
أوConsumerMapView
، وكلاهما يعرض بشكل غير متزامنConsumerGoogleMap
فيConsumerMapReadyCallback
.تمثّل
ConsumerGoogleMap
فئة تضمين للفئةGoogleMap
. فهي تستخدم واجهة برمجة تطبيقات مكافئة لـGoogleMap
بحيث يمكن لتطبيقك التفاعل مع الخريطة. وبهذه الطريقة، يمكن لتطبيقك التفاعل بسلاسة مع خدمات Google الأساسية نفسها الخريطة. على سبيل المثال، لا يسمح النطاقGoogleMap
إلا بتسجيل معاودة الاتصال مرة واحدة، ولكن يتيحConsumerGoogleMap
عمليات معاودة الاتصال المسجَّلة المزدوجة. تتيح عمليات الاستدعاء هذه يسجّل تطبيقك استدعاءات تسمى بشكل تسلسلي.احصل على
ConsumerController
منConsumerGoogleMap
فيgetConsumerController()
.يوفّر
ConsumerController
إمكانية الوصول إلى ميزات مشاركة الرحلة، مثل: كمراقبة الرحلات والتحكم في حالتها وتعيين المواقع.
لمعرفة كيفية إضافة ConsumerGoogleMap
وConsumerController
إلى تطبيقك
Java وKotlin، اطلع على الأمثلة التالية.
Java
private ConsumerGoogleMap consumerGoogleMap;
private ConsumerController consumerController;
private ConsumerMapView consumerMapView;
consumerMapView.getConsumerGoogleMapAsync(
new ConsumerMapReadyCallback() {
@Override
public void onConsumerMapReady(@NonNull ConsumerGoogleMap consumerMap) {
consumerGoogleMap = consumerMap;
consumerController = consumerMap.getConsumerController();
}
},
this, null);
Kotlin
var consumerGoogleMap: ConsumerGoogleMap
var consumerController: ConsumerController
val consumerMapView = findViewById(R.id.consumer_map_view) as ConsumerMapView
consumerMapView.getConsumerGoogleMapAsync(
object : ConsumerMapReadyCallback() {
override fun onConsumerMapReady(consumerMap: ConsumerGoogleMap) {
consumerGoogleMap = consumerMap
consumerController = consumerMap.getConsumerController()
},
/* fragmentActivity= */ this,
/* googleMapOptions= */ null,
}
)
الخطوة 3: إضافة إمكانية استخدام الرسومات الموجّهة من Android
إذا كان تصميم التطبيق الخاص بك يتطلب دعمًا للرسومات المتجهة، فأضف دعمًا أجهزة Android والعناصر القابلة للرسم المتجهة باستخدام هذه الخطوات:
- أضِف الرمز التالي إلى سجلّ "نشاطك". يمتد هذا الرمز
AppCompatActivity
لاستخدام عناصر رسم المتجهات في حزمة تطوير البرامج (SDK) الخاصة بالمستهلكين.
Java
// ...
import android.support.v7.app.AppCompatActivity;
// ...
public class ConsumerTestActivity extends AppCompatActivity {
// ...
}
Kotlin
// ...
import android.support.v7.app.AppCompatActivity
// ...
class ConsumerTestActivity : AppCompatActivity() {
// ...
}