- ভূমিকা
- একটি তথ্য উইন্ডো যোগ করুন
- একটি তথ্য উইন্ডো খুলুন
- একটি তথ্য উইন্ডো বন্ধ করুন
- একটি তথ্য উইন্ডো সরান
ভূমিকা
একটি InfoWindow
একটি নির্দিষ্ট অবস্থানে মানচিত্রের উপরে একটি পপআপ উইন্ডোতে সামগ্রী (সাধারণত পাঠ্য বা ছবি) প্রদর্শন করে। তথ্য উইন্ডোতে একটি বিষয়বস্তু এলাকা এবং একটি টেপার স্টেম আছে। কান্ডের অগ্রভাগ মানচিত্রে একটি নির্দিষ্ট স্থানে সংযুক্ত থাকে। তথ্য উইন্ডো স্ক্রিন রিডারের জন্য একটি ডায়ালগ হিসাবে উপস্থিত হয়।
সাধারণত আপনি একটি মার্কারের সাথে একটি তথ্য উইন্ডো সংযুক্ত করবেন, তবে আপনি একটি নির্দিষ্ট অক্ষাংশ/দ্রাঘিমাংশের সাথে একটি তথ্য উইন্ডো সংযুক্ত করতে পারেন, যেমনটি নীচে একটি তথ্য উইন্ডো যুক্ত করার বিভাগে বর্ণিত হয়েছে৷
বিস্তৃতভাবে বলতে গেলে, তথ্য উইন্ডোগুলি হল এক ধরনের ওভারলে। অন্যান্য ধরনের ওভারলে সম্পর্কে তথ্যের জন্য, মানচিত্রে অঙ্কন দেখুন।
একটি তথ্য উইন্ডো যোগ করুন
InfoWindow
কনস্ট্রাক্টর একটি InfoWindowOptions
অবজেক্ট আক্ষরিক নেয়, যা তথ্য উইন্ডো প্রদর্শনের জন্য প্রাথমিক পরামিতিগুলি নির্দিষ্ট করে।
InfoWindowOptions
অবজেক্ট লিটারেলে নিম্নলিখিত ক্ষেত্রগুলি রয়েছে:
- তথ্য উইন্ডোতে প্রদর্শনের জন্য
content
পাঠ্যের একটি স্ট্রিং বা একটি DOM নোড থাকে। -
pixelOffset
ইনফো উইন্ডোর ডগা থেকে সেই অবস্থান পর্যন্ত একটি অফসেট ধারণ করে যেখানে ইনফো উইন্ডো নোঙর করা হয়। অনুশীলনে, আপনাকে এই ক্ষেত্রটি নির্দিষ্ট করতে হবে না। আপনি ডিফল্ট মান এটি ছেড়ে যেতে পারেন. -
position
LatLng
রয়েছে যেখানে এই তথ্য উইন্ডোটি নোঙর করা হয়েছে। দ্রষ্টব্য: একটিInfoWindow
হয় একটিMarker
বস্তুর সাথে সংযুক্ত করা যেতে পারে (যে ক্ষেত্রে এটির অবস্থান চিহ্নিতকারীর অবস্থানের উপর ভিত্তি করে) অথবা একটি নির্দিষ্টLatLng
এ মানচিত্রে নিজেই। একটিLatLng
পুনরুদ্ধার করার একটি উপায় হল জিওকোডিং পরিষেবা ব্যবহার করা। একটি মার্কারে একটি তথ্য উইন্ডো খুললে স্বয়ংক্রিয়ভাবেposition
আপডেট হবে। -
maxWidth
পিক্সেলে তথ্য উইন্ডোর সর্বাধিক প্রস্থ নির্দিষ্ট করে। ডিফল্টরূপে, একটি তথ্য উইন্ডো তার সামগ্রীর সাথে মানানসই করার জন্য প্রসারিত হয় এবং তথ্য উইন্ডো মানচিত্রটি পূরণ করলে পাঠ্য স্বয়ংক্রিয়ভাবে মোড়ানো হয়। আপনি একটিmaxWidth
যোগ করলে তথ্য উইন্ডোটি নির্দিষ্ট প্রস্থ কার্যকর করতে স্বয়ংক্রিয়ভাবে মোড়ানো হবে। যদি এটি সর্বাধিক প্রস্থে পৌঁছায় এবং স্ক্রিনে উল্লম্ব রুম থাকে, তথ্য উইন্ডোটি উল্লম্বভাবে প্রসারিত হতে পারে।
InfoWindow
এর বিষয়বস্তুতে পাঠ্যের একটি স্ট্রিং, HTML এর একটি স্নিপেট বা একটি DOM উপাদান থাকতে পারে। বিষয়বস্তু সেট করতে, হয় InfoWindowOptions
এর মধ্যে এটি নির্দিষ্ট করুন অথবা InfoWindow
এ স্পষ্টভাবে setContent()
কল করুন।
আপনি যদি বিষয়বস্তুকে স্পষ্টভাবে আকার দিতে চান তবে আপনি এটিকে একটি <div>
উপাদানে রাখতে পারেন এবং CSS এর সাথে <div>
স্টাইল করতে পারেন। আপনি স্ক্রলিং সক্রিয় করতে CSS ব্যবহার করতে পারেন। মনে রাখবেন যে আপনি যদি স্ক্রলিং সক্ষম না করেন এবং বিষয়বস্তু তথ্য উইন্ডোতে উপলব্ধ স্থান ছাড়িয়ে যায়, তাহলে বিষয়বস্তু তথ্য উইন্ডো থেকে ছিটকে যেতে পারে।
একটি তথ্য উইন্ডো খুলুন
আপনি যখন একটি তথ্য উইন্ডো তৈরি করেন, এটি মানচিত্রে স্বয়ংক্রিয়ভাবে প্রদর্শিত হয় না। তথ্য উইন্ডোটি দৃশ্যমান করতে, আপনাকে অবশ্যই InfoWindow
এ open()
পদ্ধতিতে কল করতে হবে, নিম্নলিখিত বিকল্পগুলি নির্দিষ্ট করে একটি InfoWindowOpenOptions
অবজেক্টকে আক্ষরিকভাবে পাস করতে হবে:
-
map
মানচিত্র বা রাস্তার দৃশ্য প্যানোরামা নির্দিষ্ট করে যার উপর খুলতে হবে৷ -
anchor
একটি অ্যাঙ্কর পয়েন্ট রয়েছে (উদাহরণস্বরূপ একটিMarker
)। যদিanchor
বিকল্পটিnull
বা অনির্ধারিত হয়, তথ্য উইন্ডোটি তারposition
বৈশিষ্ট্যে খুলবে।
টাইপস্ক্রিপ্ট
// This example displays a marker at the center of Australia. // When the user clicks the marker, an info window opens. function initMap(): void { const uluru = { lat: -25.363, lng: 131.044 }; const map = new google.maps.Map( document.getElementById("map") as HTMLElement, { zoom: 4, center: uluru, } ); const contentString = '<div id="content">' + '<div id="siteNotice">' + "</div>" + '<h1 id="firstHeading" class="firstHeading">Uluru</h1>' + '<div id="bodyContent">' + "<p><b>Uluru</b>, also referred to as <b>Ayers Rock</b>, is a large " + "sandstone rock formation in the southern part of the " + "Northern Territory, central Australia. It lies 335 km (208 mi) " + "south west of the nearest large town, Alice Springs; 450 km " + "(280 mi) by road. Kata Tjuta and Uluru are the two major " + "features of the Uluru - Kata Tjuta National Park. Uluru is " + "sacred to the Pitjantjatjara and Yankunytjatjara, the " + "Aboriginal people of the area. It has many springs, waterholes, " + "rock caves and ancient paintings. Uluru is listed as a World " + "Heritage Site.</p>" + '<p>Attribution: Uluru, <a href="https://en.wikipedia.org/w/index.php?title=Uluru&oldid=297882194">' + "https://en.wikipedia.org/w/index.php?title=Uluru</a> " + "(last visited June 22, 2009).</p>" + "</div>" + "</div>"; const infowindow = new google.maps.InfoWindow({ content: contentString, ariaLabel: "Uluru", }); const marker = new google.maps.Marker({ position: uluru, map, title: "Uluru (Ayers Rock)", }); marker.addListener("click", () => { infowindow.open({ anchor: marker, map, }); }); } declare global { interface Window { initMap: () => void; } } window.initMap = initMap;
জাভাস্ক্রিপ্ট
// This example displays a marker at the center of Australia. // When the user clicks the marker, an info window opens. function initMap() { const uluru = { lat: -25.363, lng: 131.044 }; const map = new google.maps.Map(document.getElementById("map"), { zoom: 4, center: uluru, }); const contentString = '<div id="content">' + '<div id="siteNotice">' + "</div>" + '<h1 id="firstHeading" class="firstHeading">Uluru</h1>' + '<div id="bodyContent">' + "<p><b>Uluru</b>, also referred to as <b>Ayers Rock</b>, is a large " + "sandstone rock formation in the southern part of the " + "Northern Territory, central Australia. It lies 335 km (208 mi) " + "south west of the nearest large town, Alice Springs; 450 km " + "(280 mi) by road. Kata Tjuta and Uluru are the two major " + "features of the Uluru - Kata Tjuta National Park. Uluru is " + "sacred to the Pitjantjatjara and Yankunytjatjara, the " + "Aboriginal people of the area. It has many springs, waterholes, " + "rock caves and ancient paintings. Uluru is listed as a World " + "Heritage Site.</p>" + '<p>Attribution: Uluru, <a href="https://en.wikipedia.org/w/index.php?title=Uluru&oldid=297882194">' + "https://en.wikipedia.org/w/index.php?title=Uluru</a> " + "(last visited June 22, 2009).</p>" + "</div>" + "</div>"; const infowindow = new google.maps.InfoWindow({ content: contentString, ariaLabel: "Uluru", }); const marker = new google.maps.Marker({ position: uluru, map, title: "Uluru (Ayers Rock)", }); marker.addListener("click", () => { infowindow.open({ anchor: marker, map, }); }); } window.initMap = initMap;
নমুনা চেষ্টা করুন
নিম্নলিখিত উদাহরণটি একটি তথ্য উইন্ডোর maxWidth
নির্ধারণ করে: উদাহরণ দেখুন ।
একটি তথ্য উইন্ডোতে ফোকাস সেট করুন
একটি তথ্য উইন্ডোতে ফোকাস সেট করতে, এটির focus()
পদ্ধতিতে কল করুন। ফোকাস সেট করার আগে একটি visible
ইভেন্ট সহ এই পদ্ধতিটি ব্যবহার করার কথা বিবেচনা করুন। একটি অদৃশ্যমান তথ্য উইন্ডোতে এই পদ্ধতিতে কল করা কোন প্রভাব ফেলবে না। একটি তথ্য উইন্ডো দৃশ্যমান করতে open()
কল করুন।
একটি তথ্য উইন্ডো বন্ধ করুন
ডিফল্টরূপে, ব্যবহারকারী ক্লোজ কন্ট্রোল (তথ্য উইন্ডোর উপরের ডানদিকে একটি ক্রস) ক্লিক না করা পর্যন্ত বা ESC কী টিপে না পর্যন্ত একটি তথ্য উইন্ডো খোলা থাকে। এছাড়াও আপনি close()
পদ্ধতিতে কল করে তথ্য উইন্ডোটি স্পষ্টভাবে বন্ধ করতে পারেন।
যখন একটি তথ্য উইন্ডো বন্ধ থাকে, তখন ফোকাস সেই উপাদানে ফিরে যায় যেটি তথ্য উইন্ডো খোলার আগে ফোকাসে ছিল। যদি সেই উপাদানটি অনুপলব্ধ হয়, তাহলে ফোকাসটি মানচিত্রে ফিরিয়ে আনা হয়। এই আচরণটি ওভাররাইড করতে, আপনি closeclick
ইভেন্টটি শুনতে পারেন এবং নিম্নলিখিত উদাহরণে দেখানো হিসাবে ম্যানুয়ালি ফোকাস পরিচালনা করতে পারেন:
infoWindow.addListener('closeclick', ()=>{ // Handle focus manually. });
একটি তথ্য উইন্ডো সরান
একটি তথ্য উইন্ডোর অবস্থান পরিবর্তন করার কয়েকটি উপায় আছে:
- কল
setPosition()
তথ্য উইন্ডোতে, অথবা -
InfoWindow.open()
পদ্ধতি ব্যবহার করে একটি নতুন মার্কারে তথ্য উইন্ডো সংযুক্ত করুন। দ্রষ্টব্য: যদি আপনি একটি মার্কার পাস না করেopen()
কল করেন, তাহলেInfoWindow
InfoWindowOptions
অবজেক্টের আক্ষরিক মাধ্যমে নির্মাণের সময় নির্দিষ্ট অবস্থানটি ব্যবহার করবে।
কাস্টমাইজেশন
InfoWindow
ক্লাস কাস্টমাইজেশন অফার করে না। পরিবর্তে, একটি সম্পূর্ণ কাস্টমাইজড পপআপ কীভাবে তৈরি করা যায় তা দেখতে কাস্টমাইজড পপআপ উদাহরণটি দেখুন৷