Rotation
Rotation
Часто встречаю rotation, сделанный на flash.
Попробовал сделать на javascript.
Надо ещё надо доделать.
Скажите, пожалуйста, Ваше мнение.
В действии
<script>
window.onload = function(){
function $(id){return document.getElementById(id);}
function int(value){return parseInt(value);}
function sin(value){return Math.sin(value);}
function cos(value){return Math.cos(value);}
var velocity=0.001,
x0=200,y0=200, // центр эллипса
alpha=0,
a=200,
b=100,
img1=$('img1'),
img2=$('img2'),
img3=$('img3'),
img4=$('img4'),
pi=Math.PI;
(function car(){
alpha+=velocity;
img1.style.top=int(x0+b*cos(alpha));
img1.style.left=int(x0+a*sin(alpha));
img2.style.top=int(x0+b*cos(alpha+pi/2));
img2.style.left=int(x0+a*sin(alpha+pi/2));
img3.style.top=int(x0+b*cos(alpha+pi));
img3.style.left=int(x0+a*sin(alpha+pi));
img4.style.top=int(x0+b*cos(alpha+pi*1.5));
img4.style.left=int(x0+a*sin(alpha+pi*1.5));
img1.getElementsByTagName('IMG')[0].style.width=50 + 80*(int(img1.style.top)/300);
img1.getElementsByTagName('IMG')[0].style.height=35 + 55*(int(img1.style.top)/300);
img2.getElementsByTagName('IMG')[0].style.width=50 + 80*(int(img2.style.top)/300);
img2.getElementsByTagName('IMG')[0].style.height=35 + 55*(int(img2.style.top)/300);
img3.getElementsByTagName('IMG')[0].style.width=50 + 80*(int(img3.style.top)/300);
img3.getElementsByTagName('IMG')[0].style.height=35 + 55*(int(img3.style.top)/300);
img4.getElementsByTagName('IMG')[0].style.width=50 + 80*(int(img4.style.top)/300);
img4.getElementsByTagName('IMG')[0].style.height=35 + 55*(int(img4.style.top)/300);
setTimeout(car,10);
})();
img1.style.display='block';
img2.style.display='block';
img3.style.display='block';
img4.style.display='block';
var div_with_cars=$('div_with_cars');
document.onmousemove=function(e){
var width=400,
divx=0,
e=e||event,
x=e.clientX;
//velocity=0.001*();
if(x>=0 && x<=400){
if(x<400/2){
var k,
value=(20/(x/10));
//$('test').innerHTML=value;
if(value<0.7005){k=0;}
else{k=70/(x/20);}
if(k>20){k=20;}
velocity=0.001*k;
}
if(x>400/2){
var k,
value=(20/(x/10));
if(value>0.7){k=0;}
else{k=200/int(x/20);}
if(k>20){k=20;}
velocity=-0.001*k;
}
}
}
}
</script>
<style>
#div_with_cars img{border: 0px;}
</style>
<div id='div_with_cars' style="position:absolute;top:0;left:0;">
<a href='#' id='img1' style="position:absolute;top:200;left:100;display:none;"><img style='width:130;height:90;' src="images/kamaz-1.jpg"/></a>
<a href='#' id='img2' style="position:absolute;top:200;left:500;display:none;"><img style='width:130;height:90;' src="images/kamaz-2.jpg"/></a>
<a href='#' id='img3' style="position:absolute;top:100;left:300;display:none;"><img style='width:130;height:90;' src="images/kamaz-3.jpg"/></a>
<a href='#' id='img4' style="position:absolute;top:300;left:300;display:none;"><img style='width:130;height:90;' src="images/kamaz-4.jpg"/></a>
</div>
<div id='test'></test>
|
Для работы с графикой в спецификации придумали такую злую штуку, как "холст", после чего абсолютно все рисуется куда легче, к тому же, Ваш пример в разных броузерах работает по разному (ИЕ и сафари). Вывод: не надо напрягать сильно мозг, а надо соскакивать на ВебГЛ или, из-за отсутствия оного, на "холст".
Удачи!
Холст, это в смысле вообще без этого эффекта?
WebGL пока ещё работает не везде.
Дело не только в браузере, но даже в операционной системе.
Сколько не пытался, не получается его запустить на XP, хотя говорят на Windows 7 работает.
Изменил некоторые свойства, теперь рамка в IE 6 не отображается.
Теперь во всех браузерах одинаково работает?
Хотя можно ещё привязку ко времени сделать, чтобы скорость везде была одинаковая.
Холст, это всмысле элемент , где предусмотрена работа с графикой и графическими объектами на уровне "расскрашивания" и рисования с помощью базовых математических функций.
P.S. Если разбирался с FileAPI, пожалуйста, помоги: нужно сделать чтение конкретного файла в текстовом режиме + сведения о файле; если быть более конкретным, то как создать экземпляр объекта File (конструктор, аля new File(path, [encoding]) у меня не работает, работает только передача файла из формы)
WebGL у меня на ХР работает... только драйвера ОпенГЛ нужно было обновить...
Заранее благодарен за ответ!
Можно ведь уже во всех браузерах нормальных крутить через CSS3 2D transforms. А в IE есть фильтр Matrix он тоже позволяет крутить. Собвстенно вся задача сводится только к изменению значений этих свойств в обработчиках событий на JS.
Даже не знал, буду пробовать.
Скажите, а какое применение у этой штуки? Или может у меня в Chromium она не так работает? 4 изображения - 4 ссылки? Я не мог по изображению нажать, оно от меня убегало. Только если его в нижнюю точку загнать, то тогда нажимается.
П.С. А подскажите, вот зачем инкапсулировать функцию car, что это даёт?
Если честно, то я тоже в этом особого смысла не нашел.
Но на сайте free-lance бывают такие заказы.
Заказчикам, иногда нравится,чтобы было несколько автомобилей в шапке сайта, которые приближались бы и удалялись.
Также, нравятся слайшоу, хотя я в них тоже особого смысла не нашел, но уже два раза делал, а раз платят надо уметь.
Ещё очень много заказов с картами, надо уметь делать анимированую карту Россию с представительствами в разных регионах.
"Инкапсулировать функцию car" - это вы по запись вида
Ну можно конечно и без неё, просто функция сразу запускается, и не надо её вызывать.
Я бы сделал немного универсальнее.
http://ixth.net/examples/kamaz/
Огромное Вам спасибо, реально лучше.
А то я сидел формулы выводил и сам не понял, как там и что за формулы нужны, просто подбирал...
Постараюсь переписать с учетом Вашего варианта.
В оригинальном примере картинки ещё и масштабируются. То есть, существует перспектива
А я бы не интвалил бы значения.
только конечные которые в стиль уходят.
О том что задавать стиль надо не двумя командами а одной - уже говорить и не буду
Забавные штуки которые не несут большого смысла, НО несут большую нагрузку на комп, у меня около 40% проца (2-х ядерного) съедает.
ИМХО использовать холст, CSS3 - если только возможно.
И на крайний случай использовать подобный код.
Потому как нативность будет работать в разы быстрее, хоть и не универсально, но зато более эффективно.