Я создаю небольшой инструмент для иллюстрации преимуществ поляризационных линз. По сути, пользователь перетаскивает линзы (путь Raphael.js) на ослепительную сцену (CSS-фон контейнера DIV) и «видит сквозь» линзы. Вот код js:
var rsr = Raphael("playmask", 720,540);
// Lens path
var path_f = rsr.path("M0,73.293c0.024-39.605,17.289-53.697,35.302-61.34C53.315,4.312,99.052-0.012,119.011,0 c38.56,0.021,43.239,11.164,43.229,29.9c-0.002,3.45-0.76,28.632-16.349,58.949c-10.332,20.092-28.434,60.424-76.452,60.396 C29.821,149.223-0.022,112.898,0,73.293 M200.594,29.922c0.011-18.734,4.699-29.871,43.262-29.851 c19.96,0.013,65.691,4.39,83.695,12.052c18.005,7.662,35.254,21.772,35.231,61.379c-0.023,39.606-29.909,75.896-69.526,75.872 c-48.02-0.027-66.076-40.377-76.384-60.484C201.32,58.557,200.594,33.373,200.594,29.922");
path_f.attr({"stroke-width":2, fill:'url(img/polarized.jpg)'} );
var move = function(dx,dy){
this.translate( dx-this.ox, dy-this.oy );
this.ox = dx;
this.oy = dy;
},
start = function(){
this.ox = 0;
this.oy = 0;
},
end = function(){
};
path_f.drag(move,start,end);
У #playmask
div есть этот CSS (только «неполяризованное» фоновое изображение и размер):
#playmask{
height:540px;
width:720px;
background: url(img/unpolarized.jpg);
}
То, с чем я застрял, это:
- Chrome / Firefox, как всегда, играют хорошо: форма линз отображается, и изображение заливки выглядит «фиксированным» при перетаскивании линз (см. Первое изображение);
- IE версии 7,8,9 работают, но (удивительно!) Они не ведут себя одинаково: изображение заливки «приклеивается» к форме линзы (см. Второе прилагаемое изображение).
Что я спрашиваю здесь: могу ли я заставить IE9 / 8/7 вести себя аналогичным образом, то есть сохранять фиксированное изображение заливки при перетаскивании линз? Если да, то как?
Скриншот Firefox:
Скриншот IE9:
Редактировать Используя Modernizr для обнаружения функций браузера, я заметил, что это странное поведение, похоже, связано с "no-smil" функцией IE.
Я обнаружил странное поведение IE9 ... фон не "прилипает", но если я перетаскиваю маску вокруг, выбираю какой-нибудь текст и нажимаю правую кнопку мыши, он обновляет "поляризованный" фон до правильная позиция !!
Редактировать 2 (21 мая 2012 г.) Решения пока нет :(, если быть более точным, оно никак не связано с функцией "no-smil" ; , правильный способ воспроизвести ошибку в IE9 - перетащить стекло, выделить текст на остальной части страницы и перевернуть всплывающий значок ускорителя (синий со стрелкой в нем). "обновляется" в правильном положении.
Важное редактирование 3 (28 августа 2012 г.)
Вы можете найти все это в этом jsfiddle (http://jsfiddle.net/q4rXm/17/)