তথ্য জানালা

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

একটি মার্কারের উপরে একটি তথ্য উইন্ডো প্রদর্শিত হচ্ছে।

একটি তথ্য উইন্ডো আপনাকে ব্যবহারকারীর কাছে তথ্য প্রদর্শন করতে দেয় যখন তারা একটি মার্কারে ট্যাপ করে।

একটি তথ্য উইন্ডো ডিভাইসের স্ক্রিনের বিপরীতে আঁকা হয়, এটির সংশ্লিষ্ট মার্কার উপরে কেন্দ্র করে। ডিফল্ট তথ্য উইন্ডোতে শিরোনামটি বোল্ডে থাকে, শিরোনামের নিচে স্নিপেট টেক্সট থাকে।

তথ্য উইন্ডোর বিষয়বস্তু চিহ্নিতকারীর title এবং snippet বৈশিষ্ট্য দ্বারা সংজ্ঞায়িত করা হয়। title এবং snippet বৈশিষ্ট্য উভয়ই ফাঁকা বা nil হলে মার্কারটিতে ক্লিক করা তথ্য উইন্ডো প্রদর্শন করে না।

একটি সময়ে শুধুমাত্র একটি তথ্য উইন্ডো প্রদর্শিত হয়. একজন ব্যবহারকারী অন্য মার্কারে ট্যাপ করলে, বর্তমান উইন্ডোটি লুকানো থাকে এবং নতুন তথ্য উইন্ডো খোলে। ব্যবহারকারী যদি একটি মার্কারে ক্লিক করে যা বর্তমানে একটি তথ্য উইন্ডো দেখাচ্ছে, সেই তথ্য উইন্ডোটি বন্ধ হয়ে যায় এবং পুনরায় খোলে।

অতিরিক্ত পাঠ্য বা ছবি যোগ করতে একটি কাস্টম তথ্য উইন্ডো তৈরি করুন। একটি কাস্টম তথ্য উইন্ডো আপনাকে পপআপের উপস্থিতির সম্পূর্ণ নিয়ন্ত্রণ দেয়৷

একটি তথ্য উইন্ডো যোগ করুন

নিম্নলিখিত স্নিপেটটি তথ্য উইন্ডোর পাঠ্যের জন্য শুধুমাত্র একটি শিরোনাম সহ একটি সাধারণ মার্কার তৈরি করে।

সুইফট

let position = CLLocationCoordinate2D(latitude: 51.5, longitude: -0.127)
let london = GMSMarker(position: position)
london.title = "London"
london.map = mapView
      

উদ্দেশ্য-C

CLLocationCoordinate2D position = CLLocationCoordinate2DMake(51.5, -0.127);
GMSMarker *london = [GMSMarker markerWithPosition:position];
london.title = @"London";
london.map = mapView;
      

snippet সম্পত্তির সাথে, আপনি অতিরিক্ত পাঠ্য যোগ করতে পারেন যা একটি ছোট ফন্টে শিরোনামের নীচে প্রদর্শিত হবে। তথ্য উইন্ডোর প্রস্থের চেয়ে দীর্ঘ স্ট্রিংগুলি স্বয়ংক্রিয়ভাবে বেশ কয়েকটি লাইনে মোড়ানো হয়। খুব দীর্ঘ বার্তাগুলি কাটা হতে পারে৷

সুইফট

london.title = "London"
london.snippet = "Population: 8,174,100"
london.map = mapView
      

উদ্দেশ্য-C

london.title = @"London";
london.snippet = @"Population: 8,174,100";
london.map = mapView;
      

একটি তথ্য উইন্ডো দেখান/লুকান

তথ্য উইন্ডোগুলি মার্কারে ব্যবহারকারীর স্পর্শ ইভেন্টগুলিতে প্রতিক্রিয়া জানাতে ডিজাইন করা হয়েছে৷ আপনি GMSMapView এর selectedMarker বৈশিষ্ট্য সেট করে প্রোগ্রাম্যাটিকভাবে একটি তথ্য উইন্ডো দেখাতে বা লুকাতে পারেন:

  • এটি দেখানোর জন্য চিহ্নিতকারীর নামের সাথে selectedMarker সেট করুন।
  • এটি লুকানোর জন্য selectedMarker nil সেট করুন।

সুইফট

london.title = "London"
london.snippet = "Population: 8,174,100"
london.map = mapView
// Show marker
mapView.selectedMarker = london
// Hide marker
mapView.selectedMarker = nil
      

উদ্দেশ্য-C

london.title = @"London";
london.snippet = @"Population: 8,174,100";
london.map = mapView;
// Show marker
mapView.selectedMarker = london;
// Hide marker
mapView.selectedMarker = nil;
      

স্বয়ংক্রিয়ভাবে রিফ্রেশ করার জন্য একটি তথ্য উইন্ডো সেট করা হচ্ছে

আপনি যদি চান নতুন বৈশিষ্ট্য বা তথ্য উইন্ডোর বিষয়বস্তু পরিবর্তন করার সময় অবিলম্বে প্রদর্শিত হবে, তথ্য উইন্ডো লুকানোর জন্য অপেক্ষা করার পরিবর্তে এবং তারপরে আবার দেখানোর জন্য মার্কারে tracksInfoWindowChanges সেট করুন YES বা true । ডিফল্ট NO বা false

সুইফট

london.tracksInfoWindowChanges = true
      

উদ্দেশ্য-C

london.tracksInfoWindowChanges = YES;
      

tracksInfoWindowChanges বৈশিষ্ট্য কখন সেট করতে হবে তা নির্ধারণ করতে, তথ্য উইন্ডোটি স্বয়ংক্রিয়ভাবে পুনরায় আঁকার সুবিধার বিপরীতে আপনার কার্যক্ষমতা বিবেচনা করা উচিত। যেমন:

  • আপনার যদি একাধিক পরিবর্তন করতে হয়, তাহলে আপনি সম্পত্তিটি YES তে পরিবর্তন করতে পারেন তারপর NO তে ফিরে যেতে পারেন।
  • যখন একটি অ্যানিমেশন চলছে বা বিষয়বস্তুগুলি অ্যাসিঙ্ক্রোনাসভাবে লোড করা হচ্ছে, তখন অ্যাকশনগুলি সম্পূর্ণ না হওয়া পর্যন্ত আপনার সম্পত্তিটি YES সেট করা উচিত।

চিহ্নিতকারীর iconView বৈশিষ্ট্য ব্যবহার করার সময় বিবেচনার জন্য নোটগুলিও পড়ুন।

একটি তথ্য উইন্ডোর অবস্থান পরিবর্তন

একটি তথ্য উইন্ডো ডিভাইসের স্ক্রিনের বিপরীতে আঁকা হয়, এটির সংশ্লিষ্ট মার্কার উপরে কেন্দ্র করে। আপনি infoWindowAnchor বৈশিষ্ট্য সেট করে মার্কার সম্পর্কিত তথ্য উইন্ডোর অবস্থান পরিবর্তন করতে পারেন। এই বৈশিষ্ট্যটি একটি CGPoint গ্রহণ করে, একটি (x,y) অফসেট হিসাবে সংজ্ঞায়িত যেখানে x এবং y উভয়ই 0.0 এবং 1.0 এর মধ্যে থাকে। ডিফল্ট অফসেট হল (0.5, 0.0), অর্থাৎ কেন্দ্রের শীর্ষ। infoWindowAnchor অফসেট সেট করা একটি কাস্টম আইকনের বিপরীতে তথ্য উইন্ডো সারিবদ্ধ করার জন্য দরকারী।

সুইফট

london.infoWindowAnchor = CGPoint(x: 0.5, y: 0.5)
london.icon = UIImage(named: "house")
london.map = mapView
      

উদ্দেশ্য-C

london.infoWindowAnchor = CGPointMake(0.5, 0.5);
london.icon = [UIImage imageNamed:@"house"];
london.map = mapView;
      

তথ্য উইন্ডোতে ইভেন্ট পরিচালনা করা

আপনি নিম্নলিখিত তথ্য উইন্ডো ইভেন্ট শুনতে পারেন:

  • mapView:markerInfoWindow: — যখন একটি মার্কার নির্বাচন হতে চলেছে তখন বলা হয়। মার্কার ব্যবহার করার জন্য ঐচ্ছিকভাবে একটি UIView হিসাবে একটি কাস্টম তথ্য উইন্ডো ফেরত দিতে পারে। আরও তথ্যের জন্য নীচের কাস্টম তথ্য উইন্ডো দেখুন.

  • mapView:markerInfoContents: — কল করা হয় যখন mapView:markerInfoWindow শূন্য প্রদান করে।

  • mapView:didCloseInfoWindowOfMarker: — মার্কারের তথ্য উইন্ডো বন্ধ হলে কল করা হয়।

  • mapView:didLongPressInfoWindowOfMarker: — একটি মার্কারের তথ্য উইন্ডোটি দীর্ঘক্ষণ চাপার পরে কল করা হয়।

ইভেন্টগুলি শুনতে, আপনাকে অবশ্যই GMSMapViewDelegate প্রোটোকল প্রয়োগ করতে হবে৷ GMSMapViewDelegateইভেন্টের নির্দেশিকা এবং পদ্ধতির তালিকা দেখুন।

GitHub নমুনাগুলি অন্তর্ভুক্ত করে যা প্রদর্শন করে কিভাবে তথ্য উইন্ডো ইভেন্টগুলি পরিচালনা করতে হয়:

কাস্টম তথ্য উইন্ডোজ

UIView এর একটি সাবক্লাস তৈরি করে তথ্য উইন্ডোর বিষয়বস্তু কাস্টমাইজ করুন যা কাস্টম তথ্য উইন্ডোর বিন্যাস সংজ্ঞায়িত করে। সেই সাবক্লাসে, দৃশ্যটি সংজ্ঞায়িত করুন যা আপনি চান। উদাহরণস্বরূপ, তথ্য উইন্ডোতে প্রদর্শিত চিত্রগুলি যুক্ত করতে আপনি শিরোনাম এবং স্নিপেট পাঠ্য এবং অন্যান্য ভিউ, যেমন UIImageView দৃষ্টান্ত প্রদর্শন করতে কাস্টম UILabel দৃষ্টান্ত ব্যবহার করতে পারেন।

নিশ্চিত করুন যে আপনার ViewController GMSIndoorDisplayDelegate প্রোটোকল প্রয়োগ করে এবং mapView:markerInfoWindow: ইভেন্টের জন্য একজন শ্রোতাকে সংজ্ঞায়িত করে। এই ইভেন্ট শ্রোতাকে ডাকা হয় যখন একটি মার্কার নির্বাচিত হতে চলেছে, এবং মার্কার দ্বারা ব্যবহৃত কাস্টম তথ্য উইন্ডোটি সংজ্ঞায়িত করতে আপনাকে আপনার কাস্টম UIView ক্লাসের একটি উদাহরণ ফেরত দিতে দেয়৷

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

Info Window Comparison

IOS-এর জন্য Maps SDK-এর সাথে GitHub- এর কোড নমুনাগুলিতে কাস্টম তথ্য উইন্ডোগুলির নমুনা অন্তর্ভুক্ত রয়েছে। উদাহরণস্বরূপ, MarkerInfoWindowViewController.m (Objective-C) বা MarkerInfoWindowViewController.swift (Swift) এর সংজ্ঞা দেখুন।

এই নমুনাগুলি ডাউনলোড এবং চালানোর তথ্যের জন্য কোড নমুনাগুলি দেখুন৷