Domyślne okno InfoWindow Map Google dla znacznika mapy jest bardzo okrągłe. Jak utworzyć niestandardowe okno InfoWindow z kwadratowymi narożnikami?
javascript
html
css
google-maps
SarahBeale
źródło
źródło
Odpowiedzi:
EDYCJA Po krótkich poszukiwaniach wydaje się, że jest to najlepsza opcja:
https://github.com/googlemaps/js-info-bubble/blob/gh-pages/examples/example.html
Możesz zobaczyć dostosowaną wersję tego InfoBubble, z której korzystałem w Dive Seven, witrynie internetowej do rejestrowania nurkowań online . To wygląda tak:
Istnieje kilka przykładów tutaj . Jednak na pewno nie wyglądają tak ładnie, jak przykład na twoim zrzucie ekranu.
źródło
Możesz zmodyfikować całe okno InfoWindow, używając samego jquery ...
Tutaj element <p> będzie działał jako punkt zaczepienia do właściwego okna InfoWindow. Gdy domready odpali, element stanie się aktywny i dostępny za pomocą javascript / jquery, na przykład
$('#hook').parent().parent().parent().parent()
.Poniższy kod ustawia tylko 2-pikselowe obramowanie wokół okna InfoWindow.
Możesz zrobić wszystko, na przykład ustawić nową klasę CSS lub po prostu dodać nowy element.
Baw się elementami, aby uzyskać to, czego potrzebujesz ...
źródło
InfoBox uważam za idealny do zaawansowanej stylizacji.
Uwzględnij http://code.google.com/p/google-maps-utility-library-v3/source/browse/trunk/infobox/src/infobox.js na swojej stronie
źródło
Stylizacja okna infowindow jest dość prosta dzięki javascriptowi waniliowemu. Pisząc to, wykorzystałem część informacji z tego wątku. Uwzględniłem też ewentualne problemy z wcześniejszymi wersjami tj. (Chociaż nie testowałem tego z nimi).
Kod tworzy okno informacyjne jak zwykle (nie ma potrzeby stosowania wtyczek, niestandardowych nakładek ani ogromnego kodu), używając elementu div z identyfikatorem do przechowywania zawartości. Daje to punkt zaczepienia w systemie, którego możemy użyć do uzyskania odpowiednich elementów do manipulacji za pomocą prostego zewnętrznego arkusza stylów.
Jest kilka dodatkowych elementów (które nie są bezwzględnie potrzebne), które obsługują takie rzeczy, jak umieszczanie haka w div z obrazem zamykającego okna informacyjnego.
Ostatnia pętla ukrywa wszystkie części strzałki wskaźnika. Sam tego potrzebowałem, ponieważ chciałem mieć przejrzystość w oknie informacyjnym, a strzała przeszkadzała. Oczywiście za pomocą haka zmiana kodu w celu zastąpienia obrazu strzałki wybranym plikiem png również powinna być dość prosta.
Jeśli chcesz zmienić to na jquery (nie mam pojęcia, dlaczego to zrobiłeś), powinno to być dość proste.
Zwykle nie jestem programistą javascript, więc wszelkie przemyślenia, komentarze, krytyka mile widziane :)
źródło
Poniższy fragment kodu może ci w tym pomóc.
Oto artykuł < Jak zlokalizować wiele adresów na mapach Google z doskonałym powiększeniem >, który pomógł mi to osiągnąć. Możesz polecić działający link JS Fiddle i pełny przykład.
źródło
Nie jestem pewien, jak FWIX.com to robi konkretnie, ale założę się, że używają niestandardowych nakładek .
źródło
Możesz użyć poniższego kodu, aby usunąć domyślne okno inforwindow stylu. Po użyciu kodu HTML do inforwindow:
źródło
Oto czyste rozwiązanie CSS oparte na aktualnym przykładzie okienkowym w Google:
https://developers.google.com/maps/documentation/javascript/examples/infowindow-simple
To szybkie rozwiązanie, które sprawdzi się w przypadku małych okienek informacyjnych. Nie zapomnij głosować wyżej, jeśli to pomaga: P
źródło
Możesz nawet dołączyć własną klasę css do wyskakującego kontenera / kanwy lub w dowolny sposób. Obecne mapy Google w wersji 3.7 mają wyskakujące okienka w stylu elementu canvas, który poprzedza w kodzie kontener typu pop-up. Tak więc w googlemaps 3.7 możesz przejść do procesu renderowania przez zdarzenie domready w wyskakującym okienku w następujący sposób:
Element.previousElementSibling nie występuje w IE8 - więc jeśli chcesz, aby to działało, postępuj zgodnie z tym .
sprawdź najnowszą referencję InfoWindow dotyczącą wydarzeń i nie tylko.
W niektórych przypadkach jest to najbardziej czyste.
źródło
Myślę, że najlepszą odpowiedzią, jaką wymyśliłem, jest tutaj: https://codepen.io/sentrathis96/pen/yJPZGx
Nie mogę wziąć za to kredytu, rozwidliłem to od innego użytkownika codepen, aby naprawić zależność map Google, aby faktycznie załadować
Zanotuj wezwanie do:
źródło