باستخدام مكتبة تتبُّع الأسطول JavaScript، يمكنك تخصيص مظهر العلامات المُضافة إلى الخريطة وأسلوبها. ويمكنك إجراء ذلك من خلال تحديد تخصيصات العلامات، التي تطبّقها مكتبة تتبُّع الأسطول بعد ذلك قبل إضافة العلامات إلى الخريطة مع كل تعديل على العلامة. يمكنك تخصيص مظهر العلامات وأسلوبها بالطُرق التالية:
علامات التنسيق استنادًا إلى النوع: حدِّد عنصر
MarkerOptions
لتنسيق علامات من النوع نفسه. بعد إنشاء كل علامة، يتم تطبيق التغيُّرات التي تحدّدها، ما يؤدي إلى استبدال أي خيارات تلقائية. للاطّلاع على مثال، راجِع علامات الأنماط استنادًا إلى النوع في هذا الدليل.تحديد نمط العلامات استنادًا إلى البيانات: يمكنك تحديد وظيفة تخصيص استنادًا إلى البيانات، بالإضافة إلى إضافة تفاعل إلى العلامات، مثل معالجة النقرات. يمكنك إنشاء تنسيقات استنادًا إلى بيانات من تتبُّع الأسطول أو من مصادر خارجية:
البيانات من تتبُّع الأسطول: تُرسِل ميزة "تتبُّع الأسطول" البيانات إلى دالة التخصيص، بما في ذلك نوع العنصر الذي يمثّله العلامة: مركبة أو محطة أو مهمة. يتغيّر تصميم العلامة بعد ذلك استنادًا إلى الحالة الحالية لعنصر العلامة. على سبيل المثال، عدد محطات التوقف المتبقية أو نوع المهمة.
المصادر الخارجية: يمكنك دمج بيانات تتبُّع الأسطول مع بيانات من مصادر خارج Fleet Engine وتنسيق العلامة استنادًا إلى تلك المعلومات أيضًا.
للحصول على أمثلة، اطّلِع على علامات الأنماط المستندة إلى البيانات.
إضافة معالجة النقرات إلى العلامات: للحصول على أمثلة، يُرجى الاطّلاع على إضافة معالجة النقرات.
فلترة العلامات المرئية: يمكنك فلترة العلامات التي تظهر باستخدام إمكانات الفلترة المتاحة في موفِّر الموقع الجغرافي باستخدام JavaScript. على سبيل المثال:
استخدام تخصيص العلامات لتتبُّع مركبة تسليم المهام المُجدوَلة: يمكنك تخصيص العلامات لتتبُّع المركبات. لمزيد من المعلومات، يُرجى الاطّلاع على مقالة استخدام تخصيص العلامة لرصد مركبة توصيل.
خيارات تخصيص قلم التحديد
توفّر مكتبة تتبُّع الأسطول مَعلمات التخصيص التالية:
مَعلمات تخصيص الرحلات عند الطلب
مَعلمات تخصيص المهام المُجدوَلة
أنماط علامات المواقع الجغرافية استنادًا إلى النوع
يوضّح المثال التالي كيفية ضبط نمط علامة المركبة باستخدام
عنصر MarkerOptions
. اتّبِع هذا النمط لتخصيص تصميم أي
علامة باستخدام أيّ من الخيارات المدرَجة في
خيارات تخصيص العلامات.
مثال على الرحلات عند الطلب
JavaScript
vehicleMarkerCustomization = {
cursor: 'grab'
};
TypeScript
vehicleMarkerCustomization = {
cursor: 'grab'
};
مثال على المهام المُجدوَلة
JavaScript
deliveryVehicleMarkerCustomization = {
cursor: 'grab'
};
TypeScript
deliveryVehicleMarkerCustomization = {
cursor: 'grab'
};
علامات الأنماط المستندة إلى البيانات
يوضّح المثال التالي كيفية ضبط تصميم علامة المركبة باستخدام وظائف التخصيص. اتّبِع هذا النمط لتخصيص تصميم أي علامة استنادًا إلى البيانات باستخدام أي من الخيارات المدرَجة في خيارات تخصيص العلامات المذكورة أعلاه.
مثال على الرحلات عند الطلب
JavaScript
vehicleMarkerCustomization =
(params) => {
const remainingWaypoints = params.vehicle.waypoints.length;
params.marker.setLabel(`${remainingWaypoints}`);
};
TypeScript
vehicleMarkerCustomization =
(params: VehicleMarkerCustomizationFunctionParams) => {
var remainingWaypoints = params.vehicle.waypoints.length;
params.marker.setLabel(`${remainingWaypoints}`);
};
مثال على المهام المُجدوَلة
JavaScript
deliveryVehicleMarkerCustomization =
(params) => {
var stopsLeft = params.vehicle.remainingVehicleJourneySegments.length;
params.marker.setLabel(`${stopsLeft}`);
};
TypeScript
deliveryVehicleMarkerCustomization =
(params: DeliveryVehicleMarkerCustomizationFunctionParams) => {
var stopsLeft = params.vehicle.remainingVehicleJourneySegments.length;
params.marker.setLabel(`${stopsLeft}`);
};
إضافة معالجة النقرات إلى العلامات
يوضّح المثال التالي كيفية إضافة معالجة النقرات إلى علامة مركبة. اتّبِع هذا النمط لإضافة معالجة النقر إلى أيّ علامة باستخدام أيّ من الخيارات المدرَجة في خيارات تخصيص العلامات المذكورة أعلاه.
مثال على الرحلات عند الطلب
JavaScript
vehicleMarkerCustomization =
(params) => {
if (params.isNew) {
params.marker.addListener('click', () => {
// Perform chosen action.
});
}
};
TypeScript
vehicleMarkerCustomization =
(params: VehicleMarkerCustomizationFunctionParams) => {
if (params.isNew) {
params.marker.addListener('click', () => {
// Perform chosen action.
});
}
};
مثال على المهام المُجدوَلة
JavaScript
deliveryVehicleMarkerCustomization =
(params) => {
if (params.isNew) {
params.marker.addListener('click', () => {
// Perform chosen action.
});
}
};
TypeScript
deliveryVehicleMarkerCustomization =
(params: DeliveryVehicleMarkerCustomizationFunctionParams) => {
if (params.isNew) {
params.marker.addListener('click', () => {
// Perform chosen action.
});
}
};
فلترة العلامات المرئية
إذا كنت بحاجة إلى استخدام setVisible
، اتّبِع هذا النمط لفلترة أيّ علامات باستخدام أيّ من الخيارات المدرَجة في خيارات تخصيص العلامات أعلاه.
مثال على الرحلات عند الطلب
JavaScript
vehicleMarkerCustomization =
(params) => {
var remainingWaypoints = params.vehicle.remainingWaypoints.length;
if (remainingWaypoints > 10) {
params.marker.setVisible(false);
}
};
TypeScript
vehicleMarkerCustomization =
(params: VehicleMarkerCustomizationFunctionParams) => {
var remainingWaypoints = params.vehicle.remainingWaypoints.length;
if (remainingWaypoints > 10) {
params.marker.setVisible(false);
}
};
مثال على المهام المُجدوَلة
JavaScript
deliveryVehicleMarkerCustomization =
(params) => {
var stopsLeft = params.vehicle.remainingVehicleJourneySegments.length;
if (stopsLeft > 10) {
params.marker.setVisible(false);
}
};
TypeScript
deliveryVehicleMarkerCustomization =
(params: DeliveryVehicleMarkerCustomizationFunctionParams) => {
var stopsLeft = params.vehicle.remainingVehicleJourneySegments.length;
if (stopsLeft > 10) {
params.marker.setVisible(false);
}
};