আকার

প্ল্যাটফর্ম নির্বাচন করুন: অ্যান্ড্রয়েড আইওএস জাভাস্ক্রিপ্ট

একটি কঠিন লাল পলিলাইন সহ মানচিত্র

অ্যান্ড্রয়েডের জন্য Google মানচিত্র API আপনার অ্যাপ্লিকেশনের জন্য কাস্টমাইজ করার জন্য আপনার মানচিত্রের আকারগুলি যোগ করার কিছু সহজ উপায় অফার করে৷

  • একটি Polyline হল সংযুক্ত লাইন সেগমেন্টগুলির একটি সিরিজ যা আপনি যেকোন আকৃতি তৈরি করতে পারেন এবং মানচিত্রে পাথ এবং রুটগুলি চিহ্নিত করতে ব্যবহার করা যেতে পারে।
  • একটি Polygon একটি আবদ্ধ আকৃতি যা মানচিত্রে এলাকা চিহ্নিত করতে ব্যবহার করা যেতে পারে।
  • একটি Circle হল মানচিত্রে আঁকা পৃথিবীর পৃষ্ঠে একটি বৃত্তের ভৌগলিকভাবে সঠিক অভিক্ষেপ।

এই সমস্ত আকারের জন্য, আপনি বেশ কয়েকটি বৈশিষ্ট্য পরিবর্তন করে তাদের চেহারা কাস্টমাইজ করতে পারেন।

কোড নমুনা

এলাকা এবং রুটগুলি উপস্থাপন করতে বহুভুজ এবং পলিলাইন যোগ করার টিউটোরিয়ালটিতে একটি সাধারণ অ্যান্ড্রয়েড অ্যাপের জন্য সমস্ত কোড অন্তর্ভুক্ত রয়েছে।

উপরন্তু, GitHub-এ ApiDemos সংগ্রহস্থলে এমন নমুনা রয়েছে যা আকার এবং তাদের বৈশিষ্ট্যগুলির ব্যবহার প্রদর্শন করে:

  • CircleDemoActivity ( Java / Kotlin ): সার্কেল
  • PolygonDemoActivity ( Java / Kotlin ): বহুভুজ
  • পলিলাইন ডেমো অ্যাক্টিভিটি ( জাভা / কোটলিন ): পলিলাইন

পলিলাইন

Polyline ক্লাস মানচিত্রে সংযুক্ত লাইন অংশগুলির একটি সেট সংজ্ঞায়িত করে। একটি Polyline অবজেক্ট LatLng অবস্থানগুলির একটি সেট নিয়ে গঠিত এবং একটি ক্রমানুসারে সেই অবস্থানগুলিকে সংযুক্ত করে এমন একটি লাইন সেগমেন্ট তৈরি করে।

এই ভিডিওটি ম্যাপে একটি পাথ আঁকতে পলিলাইন ব্যবহার করে আপনার ব্যবহারকারীদের তারা যেখানে যাচ্ছে সেখানে পৌঁছাতে কীভাবে সাহায্য করবেন সে সম্পর্কে ধারণা দেয়৷

একটি পলিলাইন তৈরি করতে, প্রথমে একটি PolylineOptions অবজেক্ট তৈরি করুন এবং এতে পয়েন্ট যোগ করুন। বিন্দু পৃথিবীর পৃষ্ঠের একটি বিন্দু প্রতিনিধিত্ব করে, এবং একটি LatLng বস্তু হিসাবে প্রকাশ করা হয়। আপনি PolylineOptions অবজেক্টে যে ক্রমানুসারে যোগ করেন সেই ক্রম অনুসারে পয়েন্টের মধ্যে লাইন সেগমেন্ট আঁকা হয়।

PolylineOptions অবজেক্টে পয়েন্ট যোগ করতে, PolylineOptions.add() কল করুন। লক্ষ্য করুন যে এই পদ্ধতিটি একটি পরিবর্তনশীল সংখ্যক প্যারামিটার নেয় যাতে আপনি একবারে একাধিক পয়েন্ট যুক্ত করতে সক্ষম হন (পয়েন্টগুলি ইতিমধ্যে একটি তালিকায় থাকলে আপনি PolylineOptions.addAll(Iterable<LatLng>) কল করতে পারেন)।

তারপর আপনি GoogleMap.addPolyline(PolylineOptions) কল করে একটি মানচিত্রে পলিলাইন যোগ করতে পারেন। পদ্ধতিটি একটি Polyline বস্তু প্রদান করে যার সাহায্যে আপনি পরবর্তী সময়ে পলিলাইন পরিবর্তন করতে পারেন।

নিম্নলিখিত কোড স্নিপেট ব্যাখ্যা করে কিভাবে একটি মানচিত্রে একটি আয়তক্ষেত্র যোগ করতে হয়:

কোটলিন

// Instantiates a new Polyline object and adds points to define a rectangle
val polylineOptions = PolylineOptions()
    .add(LatLng(37.35, -122.0))
    .add(LatLng(37.45, -122.0)) // North of the previous point, but at the same longitude
    .add(LatLng(37.45, -122.2)) // Same latitude, and 30km to the west
    .add(LatLng(37.35, -122.2)) // Same longitude, and 16km to the south
    .add(LatLng(37.35, -122.0)) // Closes the polyline.

// Get back the mutable Polyline
val polyline = map.addPolyline(polylineOptions)

      

জাভা

// Instantiates a new Polyline object and adds points to define a rectangle
PolylineOptions polylineOptions = new PolylineOptions()
    .add(new LatLng(37.35, -122.0))
    .add(new LatLng(37.45, -122.0))  // North of the previous point, but at the same longitude
    .add(new LatLng(37.45, -122.2))  // Same latitude, and 30km to the west
    .add(new LatLng(37.35, -122.2))  // Same longitude, and 16km to the south
    .add(new LatLng(37.35, -122.0)); // Closes the polyline.

// Get back the mutable Polyline
Polyline polyline = map.addPolyline(polylineOptions);

      

আয়তক্ষেত্রটি নীচে দেখানো মানচিত্রে প্রদর্শিত হবে:

একটি আয়তক্ষেত্র পলিলাইন সহ মানচিত্র

পলিলাইন যোগ করার পরে এর আকৃতি পরিবর্তন করতে, আপনি Polyline.setPoints() কল করতে পারেন এবং পলিলাইনের জন্য পয়েন্টগুলির একটি নতুন তালিকা প্রদান করতে পারেন।

আপনি পলিলাইনের চেহারাটি মানচিত্রে যোগ করার আগে এবং এটি মানচিত্রে যোগ করার পরে উভয়ই কাস্টমাইজ করতে পারেন। আরও বিশদ বিবরণের জন্য নীচের উপস্থিতি কাস্টমাইজ করার বিভাগটি দেখুন।

পলিলাইন কাস্টমাইজেশন

পলিলাইনের চেহারা কাস্টমাইজ করার বিভিন্ন উপায় রয়েছে:

  • বহুরঙের পলিলাইন পলিলাইন অংশগুলিকে বিভিন্ন রঙে সেট করে।
  • গ্রেডিয়েন্ট পলিলাইন দুটি রঙের গ্রেডিয়েন্ট ব্যবহার করে একটি পলিলাইনকে রঙ করে।
  • পুনরাবৃত্ত বিটম্যাপ ব্যবহার করে স্ট্যাম্পড পলিলাইন স্টাইল একটি পলিলাইন।

পলিলাইন কাস্টমাইজেশন ব্যবহার করতে, আপনাকে অবশ্যই Android এর জন্য Maps SDK-এর 18.1.0 বা তার পরবর্তী সংস্করণ ব্যবহার করতে হবে এবং Android রেন্ডারারের জন্য সর্বশেষ মানচিত্র SDK ব্যবহার করতে হবে

একটি বহুবর্ণের পলিলাইন তৈরি করা হচ্ছে

একটি বহুরঙা পলিলাইন সহ মানচিত্র

আপনি স্প্যান ব্যবহার করতে পারেন পলিলাইনের অংশগুলিকে আলাদাভাবে রঙ করতে, StyleSpan অবজেক্ট তৈরি করে, এবং addSpan() বা addSpans() পদ্ধতি ব্যবহার করে PolylineOptions এ যোগ করে। ডিফল্টরূপে, অ্যারের প্রতিটি আইটেম সংশ্লিষ্ট লাইন সেগমেন্টের রঙ সেট করবে। নিম্নলিখিত উদাহরণ লাল এবং সবুজ অংশগুলির সাথে একটি পলিলাইন তৈরি করতে সেগমেন্টের রঙ সেটিং দেখায়:

কোটলিন

val line = map.addPolyline(
    PolylineOptions()
        .add(LatLng(47.6677146, -122.3470447), LatLng(47.6442757, -122.2814693))
        .addSpan(StyleSpan(Color.RED))
        .addSpan(StyleSpan(Color.GREEN))
)

      

জাভা

Polyline line = map.addPolyline(new PolylineOptions()
        .add(new LatLng(47.6677146,-122.3470447), new LatLng(47.6442757,-122.2814693))
        .addSpan(new StyleSpan(Color.RED))
        .addSpan(new StyleSpan(Color.GREEN)));

      

একটি গ্রেডিয়েন্ট পলিলাইন তৈরি করা হচ্ছে

একটি গ্রেডিয়েন্ট পলিলাইন সহ মানচিত্র

স্ট্রোকের শুরু এবং শেষের রঙগুলি নির্দিষ্ট করতে আপনি দুটি 32-বিট আলফা-লাল-সবুজ-নীল (ARGB) পূর্ণসংখ্যা নির্দিষ্ট করে একটি গ্রেডিয়েন্ট সংজ্ঞায়িত করতে পারেন। PolylineOptions.addSpan() কল করে শেপের অপশন অবজেক্টে এই প্রপার্টি সেট করুন। নিম্নলিখিত উদাহরণে উডল্যান্ড পার্ক চিড়িয়াখানা থেকে কার্কল্যান্ড, WA পর্যন্ত একটি লাল থেকে হলুদ গ্রেডিয়েন্ট পলিলাইন তৈরি করা দেখায়।

কোটলিন

val line = map.addPolyline(
    PolylineOptions()
        .add(LatLng(47.6677146, -122.3470447), LatLng(47.6442757, -122.2814693))
        .addSpan(
            StyleSpan(
                StrokeStyle.gradientBuilder(
                    Color.RED,
                    Color.YELLOW
                ).build()
            )
        )
)

      

জাভা

Polyline line = map.addPolyline(new PolylineOptions()
        .add(new LatLng(47.6677146,-122.3470447), new LatLng(47.6442757,-122.2814693))
        .addSpan(new StyleSpan(StrokeStyle.gradientBuilder(Color.RED, Color.YELLOW).build())));

      

একটি স্ট্যাম্পড পলিলাইন তৈরি করা হচ্ছে

একটি স্ট্যাম্পযুক্ত পলিলাইন সহ মানচিত্র

আপনি একটি পুনরাবৃত্ত বিটম্যাপ টেক্সচারে একটি পলিলাইনের চেহারা সেট করতে পারেন। এটি করার জন্য, TextureStyle এর একটি StampStyle তৈরি করুন, তারপর এখানে দেখানো হিসাবে PolylineOptions.addSpan() কল করে আকৃতির বিকল্প বস্তুতে এই বৈশিষ্ট্যটি সেট করুন:

কোটলিন

val stampStyle =
    TextureStyle.newBuilder(BitmapDescriptorFactory.fromResource(R.drawable.walking_dot)).build()
val span = StyleSpan(StrokeStyle.colorBuilder(Color.RED).stamp(stampStyle).build())
map.addPolyline(
    PolylineOptions()
        .add(LatLng(47.6677146, -122.3470447), LatLng(47.6442757, -122.2814693))
        .addSpan(span)
)

      

জাভা

StampStyle stampStyle =
        TextureStyle.newBuilder(BitmapDescriptorFactory.fromResource(R.drawable.walking_dot)).build();
StyleSpan span = new StyleSpan(StrokeStyle.colorBuilder(Color.RED).stamp(stampStyle).build());
map.addPolyline(new PolylineOptions()
        .add(new LatLng(47.6677146,-122.3470447), new LatLng(47.6442757,-122.2814693))
        .addSpan(span));

      

পলিলাইন ঘটনা

ডিফল্টরূপে, পলিলাইন ক্লিকযোগ্য নয়। আপনি Polyline.setClickable(boolean) কল করে ক্লিকযোগ্যতা সক্ষম এবং নিষ্ক্রিয় করতে পারেন।

ক্লিকযোগ্য পলিলাইনে ক্লিক ইভেন্ট শুনতে একটি OnPolylineClickListener ব্যবহার করুন। মানচিত্রে এই শ্রোতাকে সেট করতে, GoogleMap.setOnPolylineClickListener(OnPolylineClickListener) কল করুন। যখন একজন ব্যবহারকারী পলিলাইনে ক্লিক করেন, আপনি একটি onPolylineClick(Polyline) কলব্যাক পাবেন।

বহুভুজ

Polygon অবজেক্টগুলি Polyline অবজেক্টের অনুরূপ যে তারা একটি ক্রমানুসারে স্থানাঙ্কের একটি সিরিজ নিয়ে গঠিত। যাইহোক, ওপেন-এন্ডেড হওয়ার পরিবর্তে, বহুভুজগুলি অভ্যন্তরীণ ভরাট সহ একটি বদ্ধ লুপের মধ্যে অঞ্চলগুলিকে সংজ্ঞায়িত করার জন্য ডিজাইন করা হয়েছে।

আপনি মানচিত্রে একটি Polygon যোগ করতে পারেন যেভাবে আপনি একটি Polyline যোগ করেন। প্রথমে একটি PolygonOptions অবজেক্ট তৈরি করুন এবং এতে কিছু পয়েন্ট যোগ করুন। এই পয়েন্টগুলি বহুভুজের রূপরেখা তৈরি করবে। তারপরে আপনি GoogleMap.addPolygon(PolygonOptions) কল করে মানচিত্রে বহুভুজ যোগ করুন যা একটি Polygon বস্তু ফিরিয়ে দেবে।

নিম্নলিখিত কোড স্নিপেট একটি মানচিত্রে একটি আয়তক্ষেত্র যোগ করে।

কোটলিন

// Instantiates a new Polygon object and adds points to define a rectangle
val rectOptions = PolygonOptions()
    .add(
        LatLng(37.35, -122.0),
        LatLng(37.45, -122.0),
        LatLng(37.45, -122.2),
        LatLng(37.35, -122.2),
        LatLng(37.35, -122.0)
    )

// Get back the mutable Polygon
val polygon = map.addPolygon(rectOptions)

      

জাভা

// Instantiates a new Polygon object and adds points to define a rectangle
PolygonOptions polygonOptions = new PolygonOptions()
    .add(new LatLng(37.35, -122.0),
        new LatLng(37.45, -122.0),
        new LatLng(37.45, -122.2),
        new LatLng(37.35, -122.2),
        new LatLng(37.35, -122.0));

// Get back the mutable Polygon
Polygon polygon = map.addPolygon(polygonOptions);

      

বহুভুজ যোগ করার পর এর আকৃতি পরিবর্তন করতে, আপনি Polygon.setPoints() কল করতে পারেন এবং বহুভুজের রূপরেখার জন্য বিন্দুগুলির একটি নতুন তালিকা প্রদান করতে পারেন।

আপনি এটিকে মানচিত্রে যোগ করার আগে এবং এটি মানচিত্রে যোগ করার পরে উভয়ই বহুভুজের চেহারাটি কাস্টমাইজ করতে পারেন। আরও বিশদ বিবরণের জন্য নীচের উপস্থিতি কাস্টমাইজ করার বিভাগটি দেখুন।

বহুভুজ স্বয়ংক্রিয় সমাপ্তি

উপরের উদাহরণের বহুভুজটি পাঁচটি স্থানাঙ্ক নিয়ে গঠিত, কিন্তু লক্ষ্য করুন যে প্রথম এবং শেষ স্থানাঙ্কগুলি একই অবস্থান, যা লুপকে সংজ্ঞায়িত করে। অনুশীলনে, তবে, যেহেতু বহুভুজ বদ্ধ অঞ্চলগুলিকে সংজ্ঞায়িত করে, আপনাকে এই শেষ স্থানাঙ্কটি সংজ্ঞায়িত করতে হবে না। যদি শেষ স্থানাঙ্কটি প্রথম থেকে আলাদা হয়, তাহলে API স্বয়ংক্রিয়ভাবে স্থানাঙ্কের ক্রম শেষে প্রথম স্থানাঙ্ক যুক্ত করে বহুভুজটিকে "বন্ধ" করবে।

নীচের দুটি বহুভুজ সমতুল্য, এবং তাদের প্রত্যেকের জন্য polygon.getPoints() কল করলে সমস্ত 4 পয়েন্ট ফিরে আসবে।

কোটলিন

val polygon1 = map.addPolygon(
    PolygonOptions()
        .add(
            LatLng(0.0, 0.0),
            LatLng(0.0, 5.0),
            LatLng(3.0, 5.0),
            LatLng(0.0, 0.0)
        )
        .strokeColor(Color.RED)
        .fillColor(Color.BLUE)
)
val polygon2 = map.addPolygon(
    PolygonOptions()
        .add(
            LatLng(0.0, 0.0),
            LatLng(0.0, 5.0),
            LatLng(3.0, 5.0)
        )
        .strokeColor(Color.RED)
        .fillColor(Color.BLUE)
)

      

জাভা

Polygon polygon1 = map.addPolygon(new PolygonOptions()
    .add(new LatLng(0, 0),
        new LatLng(0, 5),
        new LatLng(3, 5),
        new LatLng(0, 0))
    .strokeColor(Color.RED)
    .fillColor(Color.BLUE));

Polygon polygon2 = map.addPolygon(new PolygonOptions()
    .add(new LatLng(0, 0),
        new LatLng(0, 5),
        new LatLng(3, 5))
    .strokeColor(Color.RED)
    .fillColor(Color.BLUE));

      

একটি ফাঁপা বহুভুজ তৈরি করুন

একটি একক Polygon বস্তুতে একাধিক পাথ একত্রিত করে জটিল আকার তৈরি করা যেতে পারে, যেমন ভরা রিং, বা "ডোনাটস" (যেখানে বহুভুজের অভ্যন্তরে "দ্বীপ" হিসাবে বহুভুজ অংশ দেখা যায়)। জটিল আকারগুলি সর্বদা একাধিক, সরল, পথের সংমিশ্রণ।

একই এলাকায় দুটি পথ সংজ্ঞায়িত করা আবশ্যক। দুটি অঞ্চলের মধ্যে বড়টি ভরাট এলাকাকে সংজ্ঞায়িত করে এবং এটি একটি সাধারণ বহুভুজ যার কোনো অতিরিক্ত বিকল্প নেই। তারপর, addHole() পদ্ধতিতে একটি দ্বিতীয় পথ পাস করুন। যখন দ্বিতীয়, ছোট পথটি বৃহত্তর পথের দ্বারা সম্পূর্ণরূপে আবদ্ধ হয়, তখন মনে হবে যেন বহুভুজের একটি অংশ সরানো হয়েছে। যদি গর্তটি বহুভুজের রূপরেখাকে ছেদ করে, তাহলে বহুভুজটি কোনো ভরাট ছাড়াই রেন্ডার করা হবে।

নীচের স্নিপেটটি একটি ছোট আয়তক্ষেত্রাকার গর্ত সহ একটি একক আয়তক্ষেত্র তৈরি করবে।

কোটলিন

val hole = listOf(
    LatLng(1.0, 1.0),
    LatLng(1.0, 2.0),
    LatLng(2.0, 2.0),
    LatLng(2.0, 1.0),
    LatLng(1.0, 1.0)
)
val hollowPolygon = map.addPolygon(
    PolygonOptions()
        .add(
            LatLng(0.0, 0.0),
            LatLng(0.0, 5.0),
            LatLng(3.0, 5.0),
            LatLng(3.0, 0.0),
            LatLng(0.0, 0.0)
        )
        .addHole(hole)
        .fillColor(Color.BLUE)
)

      

জাভা

List<LatLng> hole = Arrays.asList(new LatLng(1, 1),
    new LatLng(1, 2),
    new LatLng(2, 2),
    new LatLng(2, 1),
    new LatLng(1, 1));
Polygon hollowPolygon = map.addPolygon(new PolygonOptions()
    .add(new LatLng(0, 0),
        new LatLng(0, 5),
        new LatLng(3, 5),
        new LatLng(3, 0),
        new LatLng(0, 0))
    .addHole(hole)
    .fillColor(Color.BLUE));

      

নীচে দেখানো হিসাবে ফাঁপা বহুভুজ মানচিত্রে উপস্থিত হয়:

একটি ফাঁপা আয়তক্ষেত্র পলিলাইন সহ মানচিত্র

বহুভুজ ঘটনা

ডিফল্টরূপে, বহুভুজ ক্লিকযোগ্য নয়। আপনি Polygon.setClickable(boolean) কল করে ক্লিকযোগ্যতা সক্ষম এবং নিষ্ক্রিয় করতে পারেন।

ক্লিকযোগ্য বহুভুজে ক্লিক ইভেন্ট শুনতে একটি OnPolygonClickListener ব্যবহার করুন। মানচিত্রে এই শ্রোতাকে সেট করতে, GoogleMap.setOnPolygonClickListener(OnPolygonClickListener) কল করুন। যখন একজন ব্যবহারকারী বহুভুজটিতে ক্লিক করেন, আপনি একটি onPolygonClick(Polygon) কলব্যাক পাবেন।

চেনাশোনা

একটি বৃত্ত দিয়ে মানচিত্র

একটি জেনেরিক Polygon ক্লাস ছাড়াও, ম্যাপ এপিআই Circle অবজেক্টের জন্য নির্দিষ্ট শ্রেণীও অন্তর্ভুক্ত করে, যাতে তাদের নির্মাণ সহজ হয়।

একটি বৃত্ত তৈরি করতে, আপনাকে অবশ্যই নিম্নলিখিত দুটি বৈশিষ্ট্য উল্লেখ করতে হবে:

  • একটি LatLng হিসাবে center
  • মিটারে radius

তারপরে একটি বৃত্তকে পৃথিবীর পৃষ্ঠের সমস্ত বিন্দুর সেট হিসাবে সংজ্ঞায়িত করা হয় যা প্রদত্ত center থেকে radius মিটার দূরে। ম্যাপ এপিআই দ্বারা ব্যবহৃত মার্কেটর প্রজেকশন কীভাবে সমতল পৃষ্ঠে একটি গোলক রেন্ডার করে, তাই বিষুব রেখার কাছে অবস্থিত হলে এটি মানচিত্রে একটি প্রায় নিখুঁত বৃত্ত হিসাবে উপস্থিত হবে এবং ক্রমবর্ধমানভাবে অ-বৃত্তাকার (স্ক্রীনে) হিসাবে প্রদর্শিত হবে। বৃত্ত বিষুবরেখা থেকে দূরে সরে যায়।

এটি যোগ করার পরে বৃত্তের আকৃতি পরিবর্তন করতে, আপনি Circle.setRadius() বা Circle.setCenter() কল করতে পারেন এবং নতুন মান প্রদান করতে পারেন।

আপনি ম্যাপে যোগ করার আগে এবং ম্যাপে যোগ করার পরে বৃত্তের চেহারা কাস্টমাইজ করতে পারেন। আরও বিশদ বিবরণের জন্য নীচের উপস্থিতি কাস্টমাইজ করার বিভাগটি দেখুন।

নিম্নলিখিত কোড স্নিপেট একটি CircleOptions অবজেক্ট তৈরি করে এবং GoogleMap.addCircle(CircleOptions) কল করে মানচিত্রে একটি বৃত্ত যোগ করে:

কোটলিন

// Instantiates a new CircleOptions object and defines the center and radius
val circleOptions = CircleOptions()
    .center(LatLng(37.4, -122.1))
    .radius(1000.0) // In meters

// Get back the mutable Circle
val circle = map.addCircle(circleOptions)

      

জাভা

// Instantiates a new CircleOptions object and defines the center and radius
CircleOptions circleOptions = new CircleOptions()
    .center(new LatLng(37.4, -122.1))
    .radius(1000); // In meters

// Get back the mutable Circle
Circle circle = map.addCircle(circleOptions);

      

বৃত্তের ঘটনা

ডিফল্টরূপে, চেনাশোনাগুলি ক্লিকযোগ্য নয়৷ আপনি CircleOptions.clickable(boolean) এর সাথে GoogleMap.addCircle() কল করে বা Circle.setClickable(boolean) কল করে ক্লিকযোগ্যতা সক্ষম এবং নিষ্ক্রিয় করতে পারেন।

একটি ক্লিকযোগ্য বৃত্তে ক্লিক ইভেন্টগুলি শুনতে একটি OnCircleClickListener ব্যবহার করুন৷ মানচিত্রে এই শ্রোতাকে সেট করতে, GoogleMap.setOnCircleClickListener(OnCircleClickListener) কল করুন।

যখন একজন ব্যবহারকারী একটি বৃত্তে ক্লিক করেন, আপনি একটি onCircleClick(Circle) কলব্যাক পাবেন, যেমনটি নিম্নলিখিত কোড নমুনায় দেখানো হয়েছে:

কোটলিন

val circle = map.addCircle(
    CircleOptions()
        .center(LatLng(37.4, -122.1))
        .radius(1000.0)
        .strokeWidth(10f)
        .strokeColor(Color.GREEN)
        .fillColor(Color.argb(128, 255, 0, 0))
        .clickable(true)
)
map.setOnCircleClickListener {
    // Flip the r, g and b components of the circle's stroke color.
    val strokeColor = it.strokeColor xor 0x00ffffff
    it.strokeColor = strokeColor
}

      

জাভা

Circle circle = map.addCircle(new CircleOptions()
    .center(new LatLng(37.4, -122.1))
    .radius(1000)
    .strokeWidth(10)
    .strokeColor(Color.GREEN)
    .fillColor(Color.argb(128, 255, 0, 0))
    .clickable(true));

map.setOnCircleClickListener(new GoogleMap.OnCircleClickListener() {
    @Override
    public void onCircleClick(Circle circle) {
        // Flip the r, g and b components of the circle's stroke color.
        int strokeColor = circle.getStrokeColor() ^ 0x00ffffff;
        circle.setStrokeColor(strokeColor);
    }
});

      

চেহারা কাস্টমাইজ করা

ম্যাপে যোগ করার আগে (অপশন অবজেক্টে পছন্দসই সম্পত্তি উল্লেখ করে) অথবা ম্যাপে যোগ করার পরে আপনি আকৃতির চেহারা পরিবর্তন করতে পারেন। গেটারগুলি সমস্ত বৈশিষ্ট্যের জন্যও উন্মুক্ত করা হয় যাতে আপনি সহজেই আকারের বর্তমান অবস্থা অ্যাক্সেস করতে পারেন।

নিম্নলিখিত স্নিপেটটি মেলবোর্ন থেকে পার্থ পর্যন্ত জিওডেসিক সেগমেন্ট সহ একটি ঘন নীল পলিলাইন যোগ করে। নীচের বিভাগগুলি এই বৈশিষ্ট্যগুলিকে আরও বিশদে ব্যাখ্যা করবে।

কোটলিন

val polyline = map.addPolyline(
    PolylineOptions()
        .add(LatLng(-37.81319, 144.96298), LatLng(-31.95285, 115.85734))
        .width(25f)
        .color(Color.BLUE)
        .geodesic(true)
)

      

জাভা

Polyline polyline = map.addPolyline(new PolylineOptions()
    .add(new LatLng(-37.81319, 144.96298), new LatLng(-31.95285, 115.85734))
    .width(25)
    .color(Color.BLUE)
    .geodesic(true));

      

মানচিত্রটি নীচে দেখানো হিসাবে প্রদর্শিত হবে:

মেলবোর্ন থেকে পার্থ পর্যন্ত একটি পলিলাইন সহ মানচিত্র

দ্রষ্টব্য: যদিও এইগুলির বেশিরভাগই বর্ণিত যে কোনও আকারে প্রয়োগ করা যেতে পারে, তবে কিছু বৈশিষ্ট্য নির্দিষ্ট আকারের জন্য অর্থপূর্ণ নাও হতে পারে (যেমন, একটি পলিলাইনের একটি ভরাট রঙ থাকতে পারে না কারণ এটির অভ্যন্তর নেই)।

স্ট্রোক রঙ

স্ট্রোকের রঙ হল একটি 32-বিট আলফা-লাল-সবুজ-নীল (ARGB) পূর্ণসংখ্যা যা আকৃতির স্ট্রোকের অস্বচ্ছতা এবং রঙ নির্দিষ্ট করে। *Options.strokeColor() (অথবা পলিলাইনের ক্ষেত্রে PolylineOptions.color() কল করে আকৃতির অপশন অবজেক্টে এই বৈশিষ্ট্যটি সেট করুন। অনির্দিষ্ট থাকলে, ডিফল্ট স্ট্রোকের রঙ কালো ( Color.BLACK )।

আকৃতিটি মানচিত্রে যোগ করার পরে, একটি পলিলাইনের জন্য getStrokeColor() (বা getColor() ) কল করে স্ট্রোকের রঙ অ্যাক্সেস করা যেতে পারে এবং setColor() for a polyline setStrokeColor() ( setColor() কল করে পরিবর্তন করা যেতে পারে।

রঙ পূরণ করুন

ভরাট রঙ শুধুমাত্র বহুভুজ এবং বৃত্তগুলিতে প্রযোজ্য। এটি পলিলাইনের ক্ষেত্রে প্রযোজ্য নয় কারণ তাদের সংজ্ঞায়িত অভ্যন্তরীণ অংশ নেই। একটি বহুভুজের জন্য, এর গর্তের ভিতরের অঞ্চলগুলি বহুভুজের অভ্যন্তরের অংশ নয় এবং যদি একটি ভরাট রঙ সেট করা হয় তবে সেগুলি রঙিন হবে না।

ভরাট রঙটি একটি 32-বিট আলফা-লাল-সবুজ-নীল (ARGB) পূর্ণসংখ্যা যা আকৃতির অভ্যন্তরের অস্বচ্ছতা এবং রঙ নির্দিষ্ট করে। *Options.fillColor() কল করে আকৃতির অপশন অবজেক্টে এই বৈশিষ্ট্যটি সেট করুন। অনির্দিষ্ট থাকলে, ডিফল্ট স্ট্রোকের রঙ স্বচ্ছ ( Color.TRANSPARENT )।

আকৃতিটি মানচিত্রে যোগ করার পরে, getFillColor() কল করে পূরণের রঙটি অ্যাক্সেস করা যেতে পারে এবং setFillColor() কল করে পরিবর্তন করা যেতে পারে।

স্ট্রোক প্রস্থ

লাইন স্ট্রোকের প্রস্থ, পিক্সেলে ফ্লোট হিসাবে (px)। মানচিত্র জুম করা হলে প্রস্থ স্কেল হয় না (অর্থাৎ, একটি আকৃতির সমস্ত জুম স্তরে একই স্ট্রোক প্রস্থ থাকবে)। একটি পলিলাইনের জন্য *Options.strokeWidth() (বা PolylineOptions.width() কল করে আকৃতির বিকল্প বস্তুতে এই বৈশিষ্ট্যটি সেট করুন। অনির্দিষ্ট থাকলে, ডিফল্ট স্ট্রোক 10 পিক্সেল।

আকৃতিটি মানচিত্রে যোগ করার পরে, একটি পলিলাইনের জন্য getStrokeWidth() (বা getWidth() কল করে স্ট্রোকের প্রস্থ অ্যাক্সেস করা যেতে পারে এবং setWidth() for a polyline setStrokeWidth() ( setWidth() কল করে পরিবর্তন করা যেতে পারে।

স্ট্রোক প্যাটার্ন

ডিফল্ট স্ট্রোক প্যাটার্ন হল পলিলাইন এবং বহুভুজ এবং বৃত্তের রূপরেখার জন্য একটি কঠিন লাইন। আপনি PatternItem বস্তুর একটি কাস্টম স্ট্রোক প্যাটার্ন নির্দিষ্ট করতে পারেন, যেখানে প্রতিটি আইটেম একটি ড্যাশ, একটি বিন্দু বা একটি ফাঁক।

নিম্নলিখিত নমুনাটি একটি পলিলাইনের জন্য একটি ডটের পুনরাবৃত্তি ক্রমানুসারে প্যাটার্ন সেট করে, তারপরে 20 পিক্সেল দৈর্ঘ্যের একটি ব্যবধান, 30 পিক্সেল দৈর্ঘ্যের একটি ড্যাশ এবং আরেকটি 20-পিক্সেল ব্যবধান।

কোটলিন

val pattern = listOf(
    Dot(), Gap(20F), Dash(30F), Gap(20F)
)
polyline.pattern = pattern

      

জাভা

List<PatternItem> pattern = Arrays.asList(
    new Dot(), new Gap(20), new Dash(30), new Gap(20));
polyline.setPattern(pattern);

      

আকৃতির জন্য নির্দিষ্ট প্রথম শীর্ষে প্রথম প্যাটার্ন আইটেম দিয়ে শুরু করে, লাইন বরাবর প্যাটার্ন পুনরাবৃত্তি হয়।

যৌথ প্রকার

পলিলাইন এবং বহুভুজের রূপরেখার জন্য, আপনি ডিফল্ট ফিক্সড মাইটার জয়েন্ট টাইপ প্রতিস্থাপন করতে একটি বেভেল বা গোলাকার JointType নির্দিষ্ট করতে পারেন।

নিম্নলিখিত নমুনা একটি পলিলাইনে একটি বৃত্তাকার জয়েন্ট টাইপ প্রয়োগ করে:

কোটলিন

polyline.jointType = JointType.ROUND

      

জাভা

polyline.setJointType(JointType.ROUND);

      

যুগ্ম প্রকার লাইনের অভ্যন্তরীণ bends প্রভাবিত করে। যদি লাইনে একটি স্ট্রোক প্যাটার্ন থাকে যাতে ড্যাশগুলি অন্তর্ভুক্ত থাকে, তাহলে জয়েন্টের ধরনটিও প্রযোজ্য হয় যখন একটি ড্যাশ একটি জয়েন্টকে স্ট্র্যাডেল করে। যৌথ প্রকারগুলি বিন্দুগুলিকে প্রভাবিত করে না, কারণ তারা সর্বদা বৃত্তাকার হয়।

লাইন ক্যাপ

আপনি একটি পলিলাইনের প্রতিটি প্রান্তের জন্য একটি Cap শৈলী নির্দিষ্ট করতে পারেন। বিকল্পগুলি হল বাট (ডিফল্ট), বর্গাকার, গোলাকার বা একটি কাস্টম বিটম্যাপ। PolylineOptions.startCap এবং PolylineOptions.endCap এ স্টাইল সেট করুন, অথবা উপযুক্ত গেটার এবং সেটার পদ্ধতি ব্যবহার করুন।

নিম্নলিখিত স্নিপেট একটি পলিলাইনের শুরুতে একটি বৃত্তাকার ক্যাপ নির্দিষ্ট করে।

কোটলিন

polyline.startCap = RoundCap()

      

জাভা

polyline.setStartCap(new RoundCap());

      

নিম্নলিখিত স্নিপেট শেষ ক্যাপের জন্য একটি কাস্টম বিটম্যাপ নির্দিষ্ট করে:

কোটলিন

polyline.endCap = CustomCap(BitmapDescriptorFactory.fromResource(R.drawable.arrow), 16F)

      

জাভা

polyline.setEndCap(
    new CustomCap(BitmapDescriptorFactory.fromResource(R.drawable.arrow), 16));

      

আপনি যখন একটি কাস্টম বিটম্যাপ ব্যবহার করেন, তখন আপনাকে পিক্সেলে একটি রেফারেন্স স্ট্রোক প্রস্থ নির্দিষ্ট করতে হবে। API সেই অনুযায়ী বিটম্যাপ স্কেল করে। রেফারেন্স স্ট্রোক প্রস্থ হল স্ট্রোক প্রস্থ যা আপনি ক্যাপের জন্য বিটম্যাপ ইমেজ ডিজাইন করার সময় ইমেজের আসল ডাইমেনশনে ব্যবহার করেছেন। ডিফল্ট রেফারেন্স স্ট্রোক প্রস্থ 10 পিক্সেল। ইঙ্গিত: রেফারেন্স স্ট্রোকের প্রস্থ নির্ধারণ করতে, একটি ইমেজ এডিটরে 100% জুম করে আপনার বিটম্যাপ ইমেজ খুলুন এবং ছবির সাপেক্ষে লাইন স্ট্রোকের কাঙ্খিত প্রস্থ প্লট করুন।

আপনি যদি বিটম্যাপ তৈরি করতে BitmapDescriptorFactory.fromResource() ব্যবহার করেন, তাহলে নিশ্চিত করুন যে আপনি একটি ঘনত্ব-স্বাধীন সম্পদ ( nodpi ) ব্যবহার করেন।

জিওডেসিক সেগমেন্ট

জিওডেসিক সেটিং শুধুমাত্র পলিলাইন এবং বহুভুজের ক্ষেত্রে প্রযোজ্য। এটি চেনাশোনাগুলির ক্ষেত্রে প্রযোজ্য নয় কারণ সেগুলিকে বিভাগগুলির একটি সংগ্রহ হিসাবে সংজ্ঞায়িত করা হয়নি৷

জিওডেসিক সেটিং নির্ধারণ করে কিভাবে পলিলাইন/বহুভুজের পরপর শীর্ষবিন্দুগুলির মধ্যে রেখার অংশগুলি আঁকা হয়। জিওডেসিক সেগমেন্টগুলি হল যেগুলি পৃথিবীর পৃষ্ঠ (একটি গোলক) বরাবর সংক্ষিপ্ততম পথ অনুসরণ করে এবং প্রায়শই মার্কেটর প্রজেকশন সহ একটি মানচিত্রে বাঁকা রেখা হিসাবে উপস্থিত হয়। নন-জিওডেসিক সেগমেন্টগুলি মানচিত্রে সরল রেখা হিসাবে আঁকা হয়।

*Options.geodesic() কল করে আকৃতির বিকল্প অবজেক্টে এই বৈশিষ্ট্যটি সেট করুন যেখানে true নির্দেশ করে সেগমেন্টগুলিকে জিওডেসিক হিসাবে আঁকা উচিত এবং false নির্দেশ করে যে বিভাগগুলিকে সরলরেখা হিসাবে আঁকা উচিত। অনির্দিষ্ট থাকলে, ডিফল্ট অ-জিওডেসিক সেগমেন্ট ( false )।

আকৃতিটি মানচিত্রে যোগ করার পরে, জিওডেসিক সেটিংটি isGeodesic() কল করে অ্যাক্সেস করা যেতে পারে এবং setGeodesic() কল করে পরিবর্তন করা যেতে পারে।

জেড-সূচক

z-সূচকটি মানচিত্রের অন্যান্য ওভারলে (অন্যান্য আকার, গ্রাউন্ড ওভারলে এবং টাইল ওভারলে) এর সাপেক্ষে এই আকৃতির স্ট্যাক অর্ডার নির্দিষ্ট করে। একটি উচ্চ z-সূচক সহ একটি ওভারলে নিম্ন z-সূচী সহ ওভারলেগুলির উপরে আঁকা হয়। একই z-সূচক সহ দুটি ওভারলে একটি নির্বিচারে আঁকা হয়।

মনে রাখবেন যে অন্যান্য ওভারলেগুলির z-সূচক নির্বিশেষে মার্কারগুলি সর্বদা অন্যান্য ওভারলেগুলির উপরে আঁকা হয়।

*Options.zIndex() কল করে আকৃতির অপশন অবজেক্টে এই বৈশিষ্ট্যটি সেট করুন। অনির্দিষ্ট হলে, ডিফল্ট z-সূচক 0 হয়। আকৃতিটি মানচিত্রে যোগ করার পরে, getZIndex() কল করে z-index অ্যাক্সেস করা যেতে পারে এবং setZIndex() কল করে পরিবর্তন করা যেতে পারে।

দৃশ্যমানতা

দৃশ্যমানতা নির্দিষ্ট করে যে আকৃতিটি মানচিত্রে আঁকা উচিত, যেখানে true নির্দেশ করে এটি আঁকা উচিত এবং false নির্দেশ করে যে এটি করা উচিত নয়। এটি আপনাকে সাময়িকভাবে মানচিত্রে একটি আকৃতি প্রদর্শন না করার অনুমতি দেয়৷ মানচিত্র থেকে স্থায়ীভাবে আকৃতি মুছে ফেলতে, সেই আকৃতিতে remove() কল করুন।

*Options.visible() কল করে আকৃতির অপশন অবজেক্টে এই বৈশিষ্ট্যটি সেট করুন। অনির্দিষ্ট হলে, ডিফল্ট দৃশ্যমানতা true । আকৃতিটি মানচিত্রে যোগ করার পরে, isVisible() কল করে দৃশ্যমানতা অ্যাক্সেস করা যেতে পারে এবং setVisible() কল করে পরিবর্তন করা যেতে পারে।

একটি আকৃতির সাথে ডেটা সংযুক্ত করুন

আপনি আকারের setTag() পদ্ধতি ব্যবহার করে পলিলাইন, বহুভুজ বা বৃত্তের সাথে একটি নির্বিচারে ডেটা অবজেক্ট সংরক্ষণ করতে পারেন এবং getTag() ব্যবহার করে বস্তুটি পুনরুদ্ধার করতে পারেন। উদাহরণস্বরূপ, একটি পলিলাইনের সাথে একটি ডেটা অবজেক্ট সংরক্ষণ করতে Polyline.setTag() কল করুন এবং ডেটা অবজেক্ট পুনরুদ্ধার করতে Polyline.getTag() এ কল করুন।

নীচের কোডটি নির্দিষ্ট পলিলাইনের জন্য একটি নির্বিচারে ট্যাগ ( A ) সংজ্ঞায়িত করে:

কোটলিন

val polyline = map.addPolyline(
    PolylineOptions()
        .clickable(true)
        .add(
            LatLng(-35.016, 143.321),
            LatLng(-34.747, 145.592),
            LatLng(-34.364, 147.891),
            LatLng(-33.501, 150.217),
            LatLng(-32.306, 149.248),
            LatLng(-32.491, 147.309)
        )
)
polyline.tag = "A"

      

জাভা

Polyline polyline = map.addPolyline((new PolylineOptions())
    .clickable(true)
    .add(new LatLng(-35.016, 143.321),
        new LatLng(-34.747, 145.592),
        new LatLng(-34.364, 147.891),
        new LatLng(-33.501, 150.217),
        new LatLng(-32.306, 149.248),
        new LatLng(-32.491, 147.309)));

polyline.setTag("A");

      

আকৃতি সহ ডেটা সঞ্চয় এবং পুনরুদ্ধার করার জন্য যখন এটি উপযোগী হয় তখন পরিস্থিতিগুলির কিছু উদাহরণ এখানে দেওয়া হল:

  • আপনার অ্যাপ্লিকেশান বিভিন্ন ধরণের আকারের জন্য পূরণ করতে পারে এবং ব্যবহারকারী যখন সেগুলিকে ক্লিক করে তখন আপনি তাদের সাথে ভিন্নভাবে আচরণ করতে চান৷
  • আপনি এমন একটি সিস্টেমের সাথে ইন্টারফেস করতে পারেন যার অনন্য রেকর্ড শনাক্তকারী রয়েছে, যেখানে আকারগুলি সেই সিস্টেমের নির্দিষ্ট রেকর্ডগুলিকে উপস্থাপন করে।
  • আকৃতির ডেটা আকৃতির জন্য z-সূচক নির্ধারণ করতে অগ্রাধিকার নির্দেশ করতে পারে।