Оптимизируйте свои подборки
Сохраняйте и классифицируйте контент в соответствии со своими настройками.
Вы можете сделать маркеры более доступными, включив обработку событий щелчков, добавив описательный текст для программ чтения с экрана и изменив масштаб маркера.
Если маркер кликабельный, он может реагировать на ввод с клавиатуры и мыши.
Текст, указанный в параметре заголовка, читается программами чтения с экрана и будет отображаться, когда пользователь наводит указатель мыши на маркер.
Увеличение размера маркеров снижает точность, необходимую для взаимодействия с ними на всех устройствах, особенно на устройствах с сенсорным экраном, и улучшает доступность. Маркеры по умолчанию соответствуют минимальному стандарту размера WCAG AA , но разработчикам, стремящимся соответствовать целевому стандарту размера WCAG AAA, следует увеличить размер маркера.
Ознакомьтесь с основными настройками маркера , чтобы узнать, как изменить масштаб маркера, добавить текст заголовка и многое другое.
В следующем примере показана карта с пятью кликабельными фокусируемыми маркерами, содержащими текст заголовка и установленными на масштаб 1,5x:
JavaScript
asyncfunctioninitMap(){const{Map3DElement,Marker3DInteractiveElement,PopoverElement}=awaitgoogle.maps.importLibrary("maps3d");const{PinElement}=awaitgoogle.maps.importLibrary("marker");constmap=newMap3DElement({center:{lat:34.8405,lng:-111.7909,altitude:1322.70},range:13279.50,tilt:67.44,heading:0.01,mode:'SATELLITE'});// Set LatLng and title text for the markers. The first marker (Boynton Pass)// receives the initial focus when tab is pressed. Use arrow keys to move// between markers; press tab again to cycle through the map controls.consttourStops=[{position:{lat:34.8791806,lng:-111.8265049},title:"Boynton Pass",},{position:{lat:34.8559195,lng:-111.7988186},title:"Airport Mesa",},{position:{lat:34.832149,lng:-111.7695277},title:"Chapel of the Holy Cross",},{position:{lat:34.823736,lng:-111.8001857},title:"Red Rock Crossing",},{position:{lat:34.800326,lng:-111.7665047},title:"Bell Rock",},];tourStops.forEach(({position,title},i)=>{constpin=newPinElement({glyph:`${i+1}`,scale:1.5,glyphColor:"#FFFFFF"});constpopover=newPopoverElement();constcontent=`${i+1}. ${title}`;constheader=document.createElement('span');// Include the label for screen readers.header.ariaLabel=`This is marker ${i+1}. ${title}`;header.slot='header';popover.append(header);popover.append(content);constinteractiveMarker=newMarker3DInteractiveElement({// Include a title, used for accessibility text for use by screen readers.title,position,gmpPopoverTargetElement:popover});interactiveMarker.append(pin);map.append(interactiveMarker);map.append(popover);});document.body.append(map);}initMap();
/* * Always set the map height explicitly to define the size of the div element * that contains the map. */html,map{height:100%;}body{height:100%;margin:0;padding:0;}
Используйте клавишу Tab, чтобы сфокусироваться на первом маркере; если на одной карте имеется несколько маркеров, используйте клавиши со стрелками для переключения между маркерами.
Если маркер кликабельный, нажмите клавишу Enter, чтобы сделать щелчок. Если у маркера есть информационное окно, вы можете открыть его, щелкнув мышью, нажав клавишу Enter или пробел. После закрытия информационного окна фокус вернётся к соответствующему маркеру.
Нажмите клавишу Tab еще раз, чтобы продолжить перемещение по остальным элементам управления картой.
Для улучшения доступности:
Задайте описательный текст для маркера с помощью параметра Marker3DInteractiveElement.title .
Добавьте содержимое в слот headerPopoverElement .
Увеличьте масштаб маркера с помощью свойства PinElement.scale .
[null,null,["Последнее обновление: 2025-08-26 UTC."],[],[],null,["\u003cbr /\u003e\n\n| This product or feature is in Preview (pre-GA). Pre-GA products and features might have limited support, and changes to pre-GA products and features might not be compatible with other pre-GA versions. Pre-GA Offerings are covered by the [Google\n| Maps Platform Service Specific Terms](https://cloud.google.com/maps-platform/terms/maps-service-terms). For more information, see the [launch stage\n| descriptions](/maps/launch-stages).\n\n\u003cbr /\u003e\n\nYou can make markers more accessible by enabling click event handling, adding\ndescriptive text for screen readers, and adjusting the marker scale.\n\n- When a marker is clickable, it can respond to keyboard and mouse input.\n- Text specified in the title option is readable by screen readers, and will display when a user holds the mouse pointer over the marker.\n- Increasing the size of markers reduces the precision required to interact with it across all devices --- especially touchscreen devices --- and improves accessibility. Default markers meet the [WCAG AA minimum\n size](https://www.w3.org/WAI/WCAG22/Understanding/target-size-minimum.html) standard but for developers aiming to comply with the [WCAG AAA\n target](https://www.w3.org/WAI/WCAG21/Understanding/target-size.html) size standard the marker size should be increased.\n\nSee [basic marker\ncustomization](/maps/documentation/javascript/3d/marker-customization) to learn\nhow to change marker scale, add title text, and more.\n\nThe following example shows a map with five clickable, focusable markers that\ninclude title text, and have been set to 1.5x scale:\n\n\nJavaScript \n\n```javascript\nasync function initMap() {\n const { Map3DElement, Marker3DInteractiveElement, PopoverElement } = await google.maps.importLibrary(\"maps3d\");\n const { PinElement } = await google.maps.importLibrary(\"marker\");\n const map = new Map3DElement({\n center: { lat: 34.8405, lng: -111.7909, altitude: 1322.70 }, range: 13279.50, tilt: 67.44, heading: 0.01,\n mode: 'SATELLITE'\n });\n // Set LatLng and title text for the markers. The first marker (Boynton Pass)\n // receives the initial focus when tab is pressed. Use arrow keys to move\n // between markers; press tab again to cycle through the map controls.\n const tourStops = [\n {\n position: { lat: 34.8791806, lng: -111.8265049 },\n title: \"Boynton Pass\",\n },\n {\n position: { lat: 34.8559195, lng: -111.7988186 },\n title: \"Airport Mesa\",\n },\n {\n position: { lat: 34.832149, lng: -111.7695277 },\n title: \"Chapel of the Holy Cross\",\n },\n {\n position: { lat: 34.823736, lng: -111.8001857 },\n title: \"Red Rock Crossing\",\n },\n {\n position: { lat: 34.800326, lng: -111.7665047 },\n title: \"Bell Rock\",\n },\n ];\n tourStops.forEach(({ position, title }, i) =\u003e {\n const pin = new PinElement({\n glyph: `${i + 1}`,\n scale: 1.5,\n glyphColor: \"#FFFFFF\"\n });\n const popover = new PopoverElement();\n const content = `${i + 1}. ${title}`;\n const header = document.createElement('span');\n // Include the label for screen readers.\n header.ariaLabel = `This is marker ${i + 1}. ${title}`;\n header.slot = 'header';\n popover.append(header);\n popover.append(content);\n const interactiveMarker = new Marker3DInteractiveElement({\n // Include a title, used for accessibility text for use by screen readers.\n title,\n position,\n gmpPopoverTargetElement: popover\n });\n interactiveMarker.append(pin);\n map.append(interactiveMarker);\n map.append(popover);\n });\n document.body.append(map);\n}\ninitMap();https://github.com/googlemaps-samples/js-api-samples/blob/5f4e6decfaf59cd69918bbf4e6338de03a63a5ba/dist/samples/3d-accessibility-features/docs/index.js#L9-L67\n```\n| **Note:** The JavaScript is compiled from the TypeScript snippet.\n\nCSS \n\n```css\n/* * Always set the map height explicitly to define the size of the div element\n * that contains the map. \n */\nhtml,\nmap {\n height: 100%;\n}\nbody {\n height: 100%;\n margin: 0;\n padding: 0;\n}https://github.com/googlemaps-samples/js-api-samples/blob/5f4e6decfaf59cd69918bbf4e6338de03a63a5ba/dist/samples/3d-accessibility-features/docs/style.css#L7-L18\n```\n\nHTML \n\n```html\n\u003chtml\u003e\n \u003chead\u003e\n \u003ctitle\u003eMap\u003c/title\u003e\n\n \u003clink rel=\"stylesheet\" type=\"text/css\" href=\"./style.css\" /\u003e\n \u003cscript type=\"module\" src=\"./index.js\"\u003e\u003c/script\u003e\n \u003c/head\u003e\n \u003cbody\u003e\n \u003cdiv id=\"map\"\u003e\u003c/div\u003e\n\n \u003c!-- prettier-ignore --\u003e\n \u003cscript\u003e(g=\u003e{var h,a,k,p=\"The Google Maps JavaScript API\",c=\"google\",l=\"importLibrary\",q=\"__ib__\",m=document,b=window;b=b[c]||(b[c]={});var d=b.maps||(b.maps={}),r=new Set,e=new URLSearchParams,u=()=\u003eh||(h=new Promise(async(f,n)=\u003e{await (a=m.createElement(\"script\"));e.set(\"libraries\",[...r]+\"\");for(k in g)e.set(k.replace(/[A-Z]/g,t=\u003e\"_\"+t[0].toLowerCase()),g[k]);e.set(\"callback\",c+\".maps.\"+q);a.src=`https://maps.${c}apis.com/maps/api/js?`+e;d[q]=f;a.onerror=()=\u003eh=n(Error(p+\" could not load.\"));a.nonce=m.querySelector(\"script[nonce]\")?.nonce||\"\";m.head.append(a)}));d[l]?console.warn(p+\" only loads once. Ignoring:\",g):d[l]=(f,...n)=\u003er.add(f)&&u().then(()=\u003ed[l](f,...n))})\n ({key: \"AIzaSyA6myHzS10YXdcazAFalmXvDkrYCp5cLc8\", v: \"beta\",});\u003c/script\u003e\n \u003c/body\u003e\n\u003c/html\u003ehttps://github.com/googlemaps-samples/js-api-samples/blob/5f4e6decfaf59cd69918bbf4e6338de03a63a5ba/dist/samples/3d-accessibility-features/docs/index.html#L8-L22\n```\n\nTry Sample \n[JSFiddle.net](https://jsfiddle.net/gh/get/library/pure/googlemaps-samples/js-api-samples/tree/main/dist/samples/3d-accessibility-features/jsfiddle)\n\n\u003cbr /\u003e\n\nTo navigate markers using the keyboard:\n\n1. Use the tab key to focus on the first marker; if there are multiple markers on the same map, use the arrow keys to cycle through the markers.\n2. If the marker is clickable, press the enter key to \"click\". If a marker has an info window, you can open it by clicking, or by pressing the enter key or space bar. When the info window closes, focus will return to the associated marker.\n3. Press tab again to continue moving through the rest of the map controls.\n\nTo enhance accessibility:\n\n- Set descriptive text for a marker using `Marker3DInteractiveElement.title` option.\n- Add content to the `header` slot of `PopoverElement`.\n- Increase marker scale using the `PinElement.scale` property."]]