এই ডকুমেন্টে বর্ণনা করা হয়েছে কিভাবে একটি বহু-গন্তব্যস্থল ভ্রমণ তৈরি করতে হয়, সঠিক ক্ষেত্রগুলি সেট করতে হয় এবং এটি পূরণ করার জন্য একটি যানবাহনকে বরাদ্দ করতে হয়। এটি ধরে নেয় যে আপনি ফ্লিট ইঞ্জিন সেট আপ করেছেন, আপনি যানবাহন তৈরি করেছেন, একটি কার্যকর ড্রাইভার অ্যাপ আছে এবং ঐচ্ছিকভাবে, একটি গ্রাহক অ্যাপ আছে। অন-ডিমান্ড ভ্রমণের জন্য উপলব্ধ বিভিন্ন ভ্রমণের পরিস্থিতির সাথেও আপনার পরিচিত হওয়া উচিত। এর জন্য নিম্নলিখিত সম্পর্কিত নির্দেশিকাগুলি দেখুন:
- ফ্লিট ইঞ্জিন সেট আপ করুন
- একটি যানবাহন তৈরি করুন
- অন-ডিমান্ড ট্রিপ ওভারভিউতে ট্রিপের পরিস্থিতি
ট্রিপ তৈরির মূল বিষয়গুলি
এই বিভাগে Fleet Engine-এ একটি ট্রিপ তৈরি করার জন্য প্রয়োজনীয় অনুরোধের বিবরণ বর্ণনা করা হয়েছে। আপনি gRPC এবং REST ব্যবহার করে একটি তৈরির অনুরোধ জারি করেন।
ভ্রমণ ক্ষেত্র
ফ্লিট ইঞ্জিনে একটি ট্রিপ তৈরি করতে নিম্নলিখিত ক্ষেত্রগুলি ব্যবহার করুন। আপনি বিভিন্ন ধরণের ট্রিপের জন্য বিভিন্ন ক্ষেত্র ব্যবহার করতে পারেন: একক বা বহু-গন্তব্য, পরপর, অথবা ভাগ করা পুলিং ট্রিপ। ট্রিপ তৈরি করার সময় আপনি ঐচ্ছিক ক্ষেত্রগুলি সরবরাহ করতে পারেন, অথবা আপনি ট্রিপ আপডেট করার সময় পরে সেগুলি সেট করতে পারেন।
| নাম | প্রয়োজন? | বিবরণ |
|---|---|---|
| পিতামাতা | হাঁ | একটি স্ট্রিং যাতে প্রোজেক্ট আইডি থাকে। এই আইডিটি আপনার সম্পূর্ণ ফ্লিট ইঞ্জিন ইন্টিগ্রেশন জুড়ে ব্যবহৃত একই আইডি হতে হবে, একই পরিষেবা অ্যাকাউন্টের ভূমিকা সহ। |
| ট্রিপ_আইডি | হাঁ | আপনার তৈরি করা একটি স্ট্রিং যা এই ট্রিপটিকে অনন্যভাবে শনাক্ত করে। রেফারেন্সে উল্লেখিত ট্রিপ আইডিগুলির কিছু বিধিনিষেধ রয়েছে। |
| ট্রিপ_টাইপ | হাঁ | আপনার তৈরি করা ট্রিপ টাইপের জন্য ট্রিপটাইপকে নিম্নলিখিত মানগুলিতে সেট করুন:
|
| পিকআপ_পয়েন্ট | হাঁ | ভ্রমণের উৎপত্তিস্থল। |
| মধ্যবর্তী গন্তব্যস্থল | হাঁ | একাধিক গন্তব্যস্থল ভ্রমণ : পিকআপ এবং ড্রপ-অফের মধ্যে ড্রাইভার যে মধ্যবর্তী গন্তব্যস্থলগুলিতে যান তার তালিকা। |
| যানবাহনের_পথপয়েন্ট | হাঁ | শুধুমাত্র শেয়ার্ড-পুলিং ট্রিপ : এই ক্ষেত্রটি একাধিক ট্রিপের ওয়েপয়েন্টগুলিকে ইন্টারলিভিং সমর্থন করে। এতে নির্ধারিত গাড়ির জন্য অবশিষ্ট সমস্ত ওয়েপয়েন্ট রয়েছে, সেইসাথে এই ট্রিপের জন্য পিকআপ এবং ড্রপ-অফ ওয়েপয়েন্টও রয়েছে। আপনি |
| যাত্রীর_সংখ্যা | না | ট্রিপে যাত্রীর সংখ্যা। |
| ড্রপঅফ_পয়েন্ট | না | ভ্রমণের গন্তব্য। |
| গাড়ির_আইডি | না | ভ্রমণের জন্য নির্ধারিত গাড়ির পরিচয়পত্র। |
উদাহরণ: একাধিক গন্তব্যস্থলে ভ্রমণ তৈরি করুন
নিম্নলিখিতটি দেখানো হয়েছে কিভাবে একটি এক্সক্লুসিভ মাল্টি-ডেস্টিনেশন ট্রিপ তৈরি করা যায় যেখানে একটি পিকআপ পয়েন্ট, একটি ড্রপ-অফ পয়েন্ট এবং একটি মধ্যবর্তী গন্তব্য থাকবে।
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "multi-destination-trip-A";
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// Trip initial settings.
String parent = "providers/" + PROJECT_ID;
Trip trip = Trip.newBuilder()
.setTripType(TripType.EXCLUSIVE)
.setPickupPoint(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)))
.setNumberOfPassengers(1)
.setDropoffPoint(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.1275).setLongitude(106.6537)))
// Add the list of intermediate destinations.
.addAllIntermediateDestinations(
ImmutableList.of(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)).build()))
.build();
// Create the Trip request.
CreateTripRequest createTripRequest = CreateTripRequest.newBuilder()
.setParent(parent)
.setTripId(TRIP_ID) // Trip ID assigned by the Provider server.
.setTrip(trip) // Initial state is NEW.
.build();
// Error handling.
try {
Trip createdTrip =
tripService.createTrip(createTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case ALREADY_EXISTS: // Trip already exists.
break;
case PERMISSION_DENIED:
break;
}
return;
}
একাধিক গন্তব্যস্থলে ভ্রমণ আপডেট করুন
আপনাকে অবশ্যই একটি গাড়ির আইডি দিয়ে ট্রিপটি কনফিগার করতে হবে যাতে ফ্লিট ইঞ্জিন তার রুটে গাড়িটি ট্র্যাক করতে পারে। ট্রিপ আপডেট করার বিশদ বিবরণের জন্য, ট্রিপ আপডেট করুন এবং তাদের অবস্থা পরিচালনা করুন দেখুন।
ট্রিপ তৈরি করার সময় যদি আপনি কোনও ড্রপ-অফ বা মধ্যবর্তী গন্তব্য নির্দিষ্ট না করেন, তাহলে আপনি এই সময়ে সর্বদা এটি করতে পারেন।
ট্রিপ আপডেটের উদাহরণ
নিম্নলিখিতটি দেখানো হয়েছে কিভাবে একটি ট্রিপ আপডেট করে মধ্যবর্তী গন্তব্যের তালিকা যোগ করতে হয় এবং একটি গাড়ির আইডি সেট করতে হয়।
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "multi-destination-trip-A";
String tripName = "providers/" + PROJECT_ID + "/trips/" + TRIP_ID;
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// The trip settings to be updated.
Trip trip = Trip.newBuilder()
// Add the list of intermediate destinations.
.addAllIntermediateDestinations(
ImmutableList.of(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)).build()))
.setVehicleId("8241890")
.build();
// The trip update request.
UpdateTripRequest updateTripRequest = UpdateTripRequest.newBuilder()
.setName(tripName)
.setTrip(trip)
.setUpdateMask(
FieldMask.newBuilder()
.addPaths("intermediate_destinations")
.addPaths("vehicle_id")
.build())
.build();
// Error handling.
try {
Trip updatedTrip =
tripService.updateTrip(updateTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND: // The trip doesn't exist.
break;
case PERMISSION_DENIED:
break;
}
return;
}
একাধিক গন্তব্যস্থলে ভ্রমণের জন্য ভ্রমণের অবস্থা পরিচালনা করুন
আপনি TripStatus গণনার মানগুলির একটি ব্যবহার করে একটি ট্রিপের অবস্থা নির্দিষ্ট করেন। যখন একটি ট্রিপের অবস্থা পরিবর্তিত হয়, উদাহরণস্বরূপ ENROUTE_TO_PICKUP থেকে ARRIVED_AT_PICKUP , তখন আপনাকে Fleet Engine-এ ট্রিপের অবস্থা আপডেট করতে হবে। ট্রিপের অবস্থা সর্বদা NEW মান দিয়ে শুরু হয় এবং COMPLETE অথবা CANCELED মান দিয়ে শেষ হয়।
একাধিক গন্তব্যস্থলে ভ্রমণের জন্য, একক গন্তব্যস্থলে ভ্রমণের মতো ট্রিপের অবস্থা আপডেট করার পাশাপাশি, আপনার গাড়ি যখনই কোনও মধ্যবর্তী গন্তব্যে পৌঁছাবে তখন আপনাকে নিম্নলিখিতগুলিও আপডেট করতে হবে:
-
intermediateDestinationIndex -
intermediateDestinationsVersion
এটি করার জন্য, TripStatus গণনা থেকে নিম্নলিখিত মানগুলি ব্যবহার করুন।
-
ENROUTE_TO_PICKUP -
ARRIVED_AT_PICKUP -
ENROUTE_TO_INTERMEDIATE_DESTINATION -
ARRIVED_AT_INTERMEDIATE_DESTINATION -
ENROUTE_TO_DROPOFF -
COMPLETE
মধ্যবর্তী গন্তব্যস্থল সহ ভ্রমণের উদাহরণ
নিম্নলিখিতটি দেখানো হয়েছে কিভাবে একটি বহু-গন্তব্যস্থল ভ্রমণ তৈরি করা যা তার পিকআপ পয়েন্ট পেরিয়ে গেছে এবং এখন তার প্রথম মধ্যবর্তী গন্তব্যের দিকে যাচ্ছে।
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "multi-destination-trip-A";
String tripName = "providers/" + PROJECT_ID + "/trips/" + TRIP_ID;
// Get the trip object from either the Fleet Engine or storage.
Trip trip = …;
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// The trip settings to be updated.
Trip trip = Trip.newBuilder()
// Trip status cannot return to a previous state once it has passed.
.setTripStatus(TripStatus.ENROUTE_TO_INTERMEDIATE_DESTINATION)
// Enroute to the first intermediate destination.
.setIntermediateDestinationIndex(0)
// You must provide an intermediate_destinations_version to ensure that you
// have the same intermediate destinations list as the Fleet Engine.
.setIntermediateDestinationsVersion(
trip.getIntermediateDestinationsVersion())
.build();
// The trip update request.
UpdateTripRequest updateTripRequest = UpdateTripRequest.newBuilder()
.setName(tripName)
.setTrip(trip)
.setUpdateMask(
FieldMask.newBuilder()
.addPaths("trip_status")
.addPaths("intermediate_destination_index")
// intermediate_destinations_version must not be in the update mask.
.build())
.build();
// Error handling.
try {
Trip updatedTrip =
tripService.updateTrip(updateTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND: // The trip doesn't exist.
break;
case FAILED_PRECONDITION: // Either the trip status is invalid, or the
// intermediate_destinations_version doesn't
// match Fleet Engine's.
break;
case PERMISSION_DENIED:
break;
}
return;
}