পালাক্রমে ডেটা ফিড সম্পর্কে বিশদ বিবরণ

একটি টার্ন-বাই-টার্ন ডেটা ফিড মানচিত্র-ভিত্তিক নেভিগেশন নির্দেশিকা জন্য ডিজাইন করা হয়নি এমন ডিভাইসগুলিতে কেবল নেভিগেশন-সংক্রান্ত তথ্য সরবরাহ করে। এটি আপনার সরবরাহ করা উপাদানগুলির সাথে আসন্ন কৌশলগুলি সরবরাহ করে:

  • আইকন (বাম, ডান, ইউ-টার্ন)
  • গোলচত্বরে সংখ্যা ঘুরিয়ে দাও
  • রাস্তার নাম
  • পরবর্তী নেভিগেশন ধাপ বা চূড়ান্ত গন্তব্যে পৌঁছানোর আনুমানিক দূরত্ব এবং সময়

ছোট স্ক্রিনের মতো যেসব ক্ষেত্রে সম্পূর্ণ নেভিগেশন SDK UI উপযুক্ত নয়, সেখানে অভিজ্ঞতা তৈরি করতে আপনি টার্ন-বাই-টার্ন ফিড ব্যবহার করতে পারেন। উদাহরণস্বরূপ, আপনি এটি দুই চাকার যানবাহন চালকদের জন্য ব্যবহার করতে পারেন, যেখানে আপনি কেবলমাত্র নেভিগেশন নির্দেশিকা প্রজেক্ট করতে পারেন যাতে তারা দ্রুত এবং আরও আত্মবিশ্বাসের সাথে তাদের গন্তব্যে পৌঁছাতে পারে এবং ন্যূনতম বিভ্রান্তি ছাড়াই।

প্রয়োজনীয় নেভিগেশন প্রদর্শন উপাদান

একটি মোবাইল স্ক্রিন যা চার্চ স্ট্রিটে ৫০ ফুট দূরে ডান দিকে বাঁক নেওয়ার সময় দেখায়। স্ক্রিনের নীচে, গন্তব্যে পৌঁছাতে বাকি সময় ১৩ মিনিট এবং বাকি দূরত্ব ২.১ মাইল।

প্রতিটি নেভিগেশন ধাপের প্রাথমিক ক্ষেত্র হল পুরো রাস্তার নাম, কৌশল এবং ধাপের মোট দূরত্ব, যা GMSNavigationStepInfo তে উপলব্ধ।

সামগ্রিক ভ্রমণের জন্য, আপনি বর্তমান ধাপ বা গন্তব্যে পৌঁছানোর অবশিষ্ট সময় এবং দূরত্ব প্রদর্শন করতে চাইতে পারেন, যা সবই GMSNavigationNavInfo তে উপলব্ধ। ডানদিকের ছবিটি এই প্রয়োজনীয় নেভিগেশন উপাদানগুলির একটি উদাহরণ দেখায়।

একটি ইভেন্ট লিসেনার সেট আপ করুন

শুধুমাত্র নেভিগেশন ডেটা ব্যবহার করতে, আপনাকে didChangeNavInfo ইভেন্টের জন্য একটি ইভেন্ট লিসেনার প্রয়োগ করতে হবে। ইভেন্ট লিসেনারের মধ্যে, আপনার ব্যবহারকারীদের পালাক্রমে নেভিগেশন প্রদানের জন্য ট্রিপ এবং ধাপের তথ্য অ্যাক্সেস করুন।

ইভেন্ট হ্যান্ডলার বাস্তবায়নের জন্য, মানচিত্রের ভিউ কন্ট্রোলারকে GMSNavigatorListener প্রোটোকল বাস্তবায়ন করতে হবে। iOS এর জন্য Navigation SDK-তে ইভেন্ট পরিচালনা সম্পর্কে বিস্তারিত তথ্যের জন্য, নেভিগেশন ইভেন্টের জন্য Listen দেখুন।

didChangeNavInfo ইভেন্ট পরিচালনা করা

আপনার অ্যাপে টার্ন-বাই-টার্ন সাপোর্ট যোগ করার জন্য didChangeNavInfo ইভেন্টের জন্য একটি লিসেনার তৈরি করুন। ইভেন্ট লিসেনারে, টার্ন-বাই-টার্ন নেভিগেশন নিয়ন্ত্রণ করতে নিম্নলিখিত ক্লাস এবং এনাম ব্যবহার করুন:

  • GMSNavigationNavInfo — নেভিগেশনের অবস্থা সম্পর্কে তথ্য সংজ্ঞায়িত করার জন্য একটি শ্রেণী।

  • GMSNavigationStepInfo — একটি নেভিগেশন রুট ধরে একটি একক পদক্ষেপ সম্পর্কে তথ্য সংজ্ঞায়িত করে এমন শ্রেণী।

  • GMSNavigationNavState — এনাম যা নেভিগেশনের বর্তমান অবস্থা নির্ধারণ করে, যেমন রুট এনারিং, রিরাউটিং, অথবা স্টপড।

  • GMSNavigationDrivingSide — Enum নির্ধারণ করে যে এই ধাপটি ড্রাইভ-অন-ডান নাকি ড্রাইভ-অন-বাম রুটে।

  • GMSNavigationManeuver — Enum, যা নেভিগেশনের কোন পদক্ষেপ নিতে হবে তা নির্ধারণ করে, যেমন বাম দিকে ঘুরুন বা ডান দিকে ঘুরুন।

নিচে didChangeNavInfo ইভেন্টের ইভেন্ট লিসেনারের উদাহরণ দেখানো হল:

সুইফট

  // ViewController.swift
  class SomeViewController: UIViewController {
    ...
    mapView.navigator?.add(self);
    ...
  }

  extension SomeViewController: GMSNavigatorListener {
    func navigator(_ navigator: GMSNavigator,
                   didUpdateNavInfo navInfo: GMSNavigationNavInfo) {

      // Get the current step information
      if navInfo.navState == .enroute {
        if let currentStep = navInfo.currentStep {
          ...
          roadNameLabel.text = currentStep.simpleRoadName
          ...
        }
      }
    }
  }

অবজেক্টিভ-সি

  // ViewController.h
  @interface SomeViewController () <GMSNavigatorListener>

  @end

  // ViewController.m
  @implementation SomeViewController
  // Some initialization code.
  ... {
    ...
    [_mapView.navigator addListener:self];
    ...
  }

  #pragma mark GMSNavigatorListener
  - (void)navigator:(GMSNavigator *)navigator didUpdateNavInfo:(GMSNavigationNavInfo *)navInfo {
    // Get the current step information
    if (navInfo.navState == GMSNavigationNavStateEnroute) {
      GMSNavigationStepInfo *currentStep = navInfo.currentStep;
      if (currentStep) {
        ...
        roadNameLabel.text = currentStep.simpleRoadName;
        ...
      }
    }
    ...
  }

GMSNavigationNavInfo এর navState প্রপার্টি ব্যবহার করে নেভিগেশনের বর্তমান অবস্থা জানতে পারবেন, যা নিম্নলিখিতগুলির মধ্যে একটি:

  • পথে - GMSNavigationNavStateEnroute অবস্থা বলতে বোঝায় যে নির্দেশিত নেভিগেশন সক্রিয় আছে এবং ব্যবহারকারী প্রদত্ত রুটে আছেন। বর্তমান আসন্ন কৌশল পদক্ষেপ সম্পর্কে তথ্য উপলব্ধ।

  • রিরাউটিং - GMSNavigationNavStateRerouting এর অর্থ হল নেভিগেশন চলছে, কিন্তু নেভিগেটর একটি নতুন রুট খুঁজছে। আসন্ন ম্যানুভার ধাপটি উপলব্ধ নয়, কারণ এখনও কোনও নতুন রুট নেই।

  • বন্ধ - GMSNavigationNavStateStopped মানে নেভিগেশন শেষ হয়ে গেছে। উদাহরণস্বরূপ, ব্যবহারকারী যখন অ্যাপে নেভিগেশন থেকে বেরিয়ে আসে তখন নেভিগেশন বন্ধ হয়ে যায়। নমুনা অ্যাপে, একটি GMSNavigationNavStateStopped অবস্থা নেভিগেশন তথ্য প্রদর্শন পরিষ্কার করে যাতে দীর্ঘস্থায়ী পদক্ষেপের নির্দেশাবলী প্রদর্শিত না হয়।

লেন নির্দেশিকা

নেভিগেশন SDK নেভিগেশন টার্ন কার্ডে লেনগুলিকে GMSNavigationLane এবং GMSNavigationLaneDirection ডেটা অবজেক্ট হিসাবে উপস্থাপন করে। একটি GMSNavigationLane অবজেক্ট নেভিগেশনের সময় একটি নির্দিষ্ট লেনকে উপস্থাপন করে এবং এতে GMSNavigationLaneDirection অবজেক্টের একটি তালিকা থাকে যা এই লেন থেকে করা যেতে পারে এমন সমস্ত বাঁক বর্ণনা করে।

একজন চালকের লেনে কোন দিকটি নেওয়া উচিত তা recommended ক্ষেত্রটি ব্যবহার করে চিহ্নিত করা হয়।

লেন নির্দেশিকা উদাহরণ

নিচের স্নিপেটটি পূর্ববর্তী স্ক্রিনশটে প্রদর্শিত লেনের ডেটা উপস্থাপনা চিত্রিত করে।

// Lane 1
GMSNavigationLaneDirections =
  [{/*GMSNavigationLaneShape=*/
GMSNavigationLaneShapeNormalLeft, /*recommended=*/ true}]

// Lane 2
GMSNavigationLaneDirections =
  [{/*GMSNavigationLaneShape=*/
GMSNavigationLaneShapeNormalLeft, /*recommended=*/ true}]

// Lane 3
GMSNavigationLaneDirections =
  [{/*GMSNavigationLaneShape=*/
GMSNavigationLaneShapeStraight, /*recommended=*/ false}]

// Lane 4
GMSNavigationLaneDirections =
  [{/*GMSNavigationLaneShape=*/
GMSNavigationLaneShapeStraight, /*recommended=*/ false},
{/*GMSNavigationLaneShape=*/ GMSNavigationLaneShapeNormalRight, /*recommended=*/ false}]

লেনের নির্দেশিকা চিত্র

নেভিগেশন SDK GMSNavigationStepInfo দ্বারা প্রদত্ত প্রতিটি নেভিগেশন ধাপের জন্য লেন চিত্র তৈরির সমর্থন করে। এই আইকনগুলি CarPlay এর চিত্র আকার নির্ধারণ নির্দেশিকা অনুসারে উপযুক্ত।

সুইফট

let currentStepInfo = navInfo.currentStep

let options = GMSNavigationStepImageOptions()
options.maneuverImageSize = .square96
options.screenMetrics = UIScreen.mainScreen

let maneuverImage = currentStepinfo.maneuverImage(options: options)
      

অবজেক্টিভ-সি

GMSNavigationStepInfo *stepInfo = navInfo.currentStep;

GMSNavigationStepImageOptions *options = [[GMSNavigationStepImageOptions alloc] init];
options.maneuverImageSize = GMSNavigationManeuverImageSizeSquare96;
options.screenMetrics = UIScreen.mainScreen;

UIImage* maneuverImage = [stepInfo maneuverImageWithOptions:options];
      

কৌশলের জন্য আইকন তৈরি করা

একটি কৌশলের জন্য একটি আইকন

GMSNavigationManeuver enum নেভিগেট করার সময় ঘটতে পারে এমন প্রতিটি সম্ভাব্য কৌশলকে সংজ্ঞায়িত করে এবং আপনি GMSNavigationStepInfo এর maneuver বৈশিষ্ট্য থেকে একটি নির্দিষ্ট পদক্ষেপের জন্য কৌশলটি পেতে পারেন।

আপনাকে ম্যানুভার আইকন তৈরি করতে হবে এবং তাদের সাথে সম্পর্কিত ম্যানুভারের সাথে পেয়ার করতে হবে। কিছু ম্যানুভারের জন্য, আপনি একটি আইকনের সাথে এক-এক ম্যাপিং সেট আপ করতে পারেন, যেমন GMSNavigationManeuverDestinationLeft এবং GMSNavigationManeuverDestinationRight । তবে, যেহেতু কিছু ম্যানুভার অন্যান্য ম্যানুভারের সাথে বৈশিষ্ট্য ভাগ করে নেয়, তাই আপনি একটি আইকনে একাধিক ম্যানুভার ম্যাপ করতে চাইতে পারেন। উদাহরণস্বরূপ GMSNavigationManeuverTurnLeft এবং GMSNavigationManeuverOnRampLeft উভয়ই বাম টার্ন আইকনে ম্যাপ করতে পারে।

কিছু কৌশলে অতিরিক্ত "ঘড়ির কাঁটার দিকে" বা "ঘড়ির কাঁটার বিপরীতে" লেবেল থাকে, যা SDK একটি দেশের ড্রাইভিং সাইডের উপর ভিত্তি করে নির্ধারণ করে। উদাহরণস্বরূপ, যেসব দেশে রাস্তার বাম দিকে গাড়ি চালানো হয়, সেখানে ড্রাইভাররা ঘড়ির কাঁটার দিকে একটি রাউন্ডঅবাউট বা ইউ-টার্ন নেয়, যেখানে রাস্তার ডান দিকের দেশগুলি ঘড়ির কাঁটার বিপরীত দিকে যায়। নেভিগেশন SDK সনাক্ত করে যে কোনও কৌশল বাম দিকের ট্র্যাফিকের মধ্যে ঘটে কিনা এবং উপযুক্ত কৌশলটি আউটপুট করে। অতএব, আপনার কৌশল আইকনটি ঘড়ির কাঁটার দিকের বিপরীতে এবং ঘড়ির কাঁটার বিপরীতে কৌশলের জন্য আলাদা হতে পারে।

বিভিন্ন কৌশলের জন্য উদাহরণ আইকন দেখতে প্রসারিত করুন

নমুনা আইকন পালাক্রমে কৌশল
DEPART
UNKNOWN
STRAIGHT
ON_RAMP_UNSPECIFIED
OFF_RAMP_UNSPECIFIED
NAME_CHANGE
TURN_RIGHT
ON_RAMP_RIGHT
TURN_LEFT
ON_RAMP_LEFT
TURN_SLIGHT_RIGHT
ON_RAMP_SLIGHT_RIGHT
OFF_RAMP_SLIGHT_RIGHT
TURN_SLIGHT_LEFT
ON_RAMP_SLIGHT_LEFT
OFF_RAMP_SLIGHT_LEFT
TURN_SHARP_RIGHT
ON_RAMP_SHARP_RIGHT
OFF_RAMP_SHARP_RIGHT
TURN_SHARP_LEFT
ON_RAMP_SHARP_LEFT
OFF_RAMP_SHARP_LEFT
TURN_U_TURN_COUNTERCLOCKWISE
ON_RAMP_U_TURN_COUNTERCLOCKWISE
OFF_RAMP_U_TURN_COUNTERCLOCKWISE
TURN_U_TURN_CLOCKWISE
ON_RAMP_U_TURN_CLOCKWISE
OFF_RAMP_U_TURN_CLOCKWISE
ROUNDABOUT_SHARP_RIGHT_COUNTERCLOCKWISE
ROUNDABOUT_SHARP_RIGHT_CLOCKWISE
ROUNDABOUT_RIGHT_COUNTERCLOCKWISE
ROUNDABOUT_RIGHT_CLOCKWISE
ROUNDABOUT_SLIGHT_RIGHT_COUNTERCLOCKWISE
ROUNDABOUT_SLIGHT_RIGHT_CLOCKWISE
ROUNDABOUT_STRAIGHT_COUNTERCLOCKWISE
ROUNDABOUT_STRAIGHT_CLOCKWISE
ROUNDABOUT_SLIGHT_LEFT_COUNTERCLOCKWISE
ROUNDABOUT_SLIGHT_LEFT_CLOCKWISE
ROUNDABOUT_LEFT_COUNTERCLOCKWISE
ROUNDABOUT_LEFT_CLOCKWISE
ROUNDABOUT_SHARP_LEFT_COUNTERCLOCKWISE
ROUNDABOUT_SHARP_LEFT_CLOCKWISE
ROUNDABOUT_U_TURN_COUNTERCLOCKWISE
ROUNDABOUT_U_TURN_CLOCKWISE
ROUNDABOUT_COUNTERCLOCKWISE
ROUNDABOUT_CLOCKWISE
ROUNDABOUT_EXIT_COUNTERCLOCKWISE
ROUNDABOUT_EXIT_CLOCKWISE
MERGE_RIGHT
OFF_RAMP_RIGHT
MERGE_LEFT
OFF_RAMP_LEFT
FORK_RIGHT
TURN_KEEP_RIGHT
ON_RAMP_KEEP_RIGHT
OFF_RAMP_KEEP_RIGHT
FORK_LEFT
TURN_KEEP_LEFT
ON_RAMP_KEEP_LEFT
OFF_RAMP_KEEP_LEFT
MERGE_UNSPECIFIED
DESTINATION
DESTINATION_RIGHT
DESTINATION_LEFT
FERRY_BOAT
FERRY_TRAIN

তৈরি আইকন ব্যবহার করুন

নেভিগেশন SDK একটি নির্দিষ্ট GMSNavigationStepInfo এর জন্য ম্যানুভার আইকন তৈরি সমর্থন করে। এই আইকনগুলি CarPlay ইমেজ সাইজিং নির্দেশিকা অনুসারে কাজ করে।

সুইফট

let currentStepInfo = navInfo.currentStep

let options = GMSNavigationStepImageOptions()
options.maneuverImageSize = .square96
options.screenMetrics = UIScreen.mainScreen

let maneuverImage = currentStepinfo.maneuverImage(options: options)
      

অবজেক্টিভ-সি

GMSNavigationStepInfo *stepInfo = navInfo.currentStep;

GMSNavigationStepImageOptions *options = [[GMSNavigationStepImageOptions alloc] init];
options.maneuverImageSize = GMSNavigationManeuverImageSizeSquare96;
options.screenMetrics = UIScreen.mainScreen;

UIImage* maneuverImage = [stepInfo maneuverImageWithOptions:options];