Я собирался опубликовать это, затем я понял это. Но я все равно выложу это для всех, кому это нужно. Извлеченный урок заключается в использовании .ico-файлов для пользовательских изображений маркеров, если вы хотите, чтобы они работали в IE. (Как примечание, это все еще не работает правильно в Safari, но это другая проблема.)
У меня уже давно есть проблема, когда маркеры API Карт Google V3, созданные с использованием пользовательских изображений, не отображаются в IE или Safari. Он отлично работает в любом другом браузере, который я тестировал, но большая часть нашей пользовательской базы все еще работает на IE, поэтому мне нужно исправить это.
Это, очевидно, известная проблема (по крайней мере, для Google), как указано в этой теме поддержки Google:
http://www.google.com/support/forum/p/maps/thread?tid=26db8fd040386548&hl=en
Мне интересно, сталкивался ли кто-нибудь еще с этой проблемой или знает, как ее обойти?
Вот js из простой тестовой страницы, которую я создал, которая демонстрирует эту ошибку:
var map;
var latLng = new google.maps.LatLng(41.342, -84.932);
$(function() {
var myOptions = {
zoom: 17,
center: latLng,
mapTypeId: google.maps.MapTypeId.HYBRID
};
map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
var newMarker = new google.maps.Marker({
map: map,
position: latLng,
icon: 'images/active_point.png'
});
});
Исправление: я преобразовал изображение в active_point.ico, и это прекрасно работало для IE. По какой-то причине IE не нравится мой .png.
После еще нескольких исследований выяснилось, что Safari должен рассматриваться как особый случай, поскольку он, похоже, не работает с маркерными изображениями .ico ИЛИ .png. Я получил только .jpgs на работу, что раздражает, потому что они не поддерживают альфа-канал.