06.11.2016, 11:54
|
|
Профессор
|
|
Регистрация: 11.07.2016
Сообщений: 300
|
|
rotate в jQuery
Добрый день уважаемые, подскажите пожалуйста как написать правильный алгоритм для анимации вращения данного примера.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
<style type="text/css">
#field {
position: relative;
width: 400px;
height: 400px;
margin-left: 10%;
margin-top: 10%;
/*background-color: yellow;*/
border: 5px solid black;
}
.block {
position: relative;
width: 10px;
height: 220px;
background-color: rgba(255, 0, 0, 0.5);
}
#first,
#second,
#third,
#fourth,
#fifth{
position: absolute;
top: 15%;
left: 50%;
transform-origin: center 320px;
}
</style>
</head>
<body>
<div id="field">
<div id="first" class="animate">
<div class="block">1</div>
</div>
<div id="second">
<div class="block">2</div>
</div>
<div id="third">
<div class="block">3</div>
</div>
<div id="fourth">
<div class="block">4</div>
</div>
<div id="fifth">
<div class="block">5</div>
</div>
</div>
<input id="button" type="button" value="Push me!">
<script type="text/javascript">
window.onload = function () {
console.log('VSE GOOD');
var i,
$field = $('#field'),
block = $('.block'),
allBlockes =$('#field > div'),
len = allBlockes.length,
but = $('#button');
but.on('click', allBlockes, function() {
function AnimateRotate(el, d){
$({deg: 0}).animate({deg: d}, {
step: function(now, fx){
el.css({
transform: "rotate(" + now + "deg)"
});
}
});
}
for (i=1; i<len; i++){
if (i%2 == 0){
var el1 = allBlockes.eq(i);
*!* AnimateRotate(el1, i*(-15)); */!*
} else {
var el2 = allBlockes.eq(i);
*!* AnimateRotate(el2, i*(15)); */!*
}
}
})
};
</script>
</body>
</html>
На выходе я хочу что б у меня все "парные" блоки вращались вправо на 15град. а не парные в лево на 15град. Тоесть так #first=0град #second = 15град #third = -15град #fourth = 30град #fifth=-30град.
Подскажете, пожалуйста как правильно цикл переделать ?
|
|
06.11.2016, 12:47
|
|
Профессор
|
|
Регистрация: 18.05.2011
Сообщений: 1,207
|
|
Black_Star,
Как вариант...
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
<style type="text/css">
#field {
position: relative;
width: 400px;
height: 400px;
margin-left: 10%;
margin-top: 10%;
/*background-color: yellow;*/
border: 5px solid black;
}
.block {
position: relative;
width: 10px;
height: 220px;
background-color: rgba(255, 0, 0, 0.5);
}
#first,
#second,
#third,
#fourth,
#fifth{
position: absolute;
top: 15%;
left: 50%;
transform-origin: center 320px;
}
</style>
</head>
<body>
<div id="field">
<div id="first" class="animate">
<div class="block">1</div>
</div>
<div id="second">
<div class="block">2</div>
</div>
<div id="third">
<div class="block">3</div>
</div>
<div id="fourth">
<div class="block">4</div>
</div>
<div id="fifth">
<div class="block">5</div>
</div>
</div>
<input id="button" type="button" value="Push me!">
<script type="text/javascript">
window.onload = function () {
console.log('VSE GOOD');
var i,
$field = $('#field'),
block = $('.block'),
allBlockes =$('#field > div'),
len = allBlockes.length,
but = $('#button');
but.on('click', allBlockes, function() {
function AnimateRotate(el, d){
$({deg: 0}).animate({deg: d}, {
step: function(now, fx){
el.css({
transform: "rotate(" + now + "deg)"
});
}
});
}
var left = -15,
right = 15;
for (i=1; i<len; i++){
if (i%2 == 0){
var el1 = allBlockes.eq(i);
AnimateRotate(el1, left);
left *= 2;
} else {
var el2 = allBlockes.eq(i);
AnimateRotate(el2, right);
right *= 2;
}
}
})
};
</script>
</body>
</html>
|
|
06.11.2016, 14:18
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,126
|
|
Сообщение от Black_Star
|
написать правильный
|
правильно это css, и смена класса у родителя на js
|
|
06.11.2016, 14:53
|
|
Профессор
|
|
Регистрация: 11.07.2016
Сообщений: 300
|
|
destus, спасибо.
рони, да так тоже можно было. Можно дажен на чистом CSS, но это не наш стиль
|
|
06.11.2016, 15:31
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,126
|
|
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
<style type="text/css">
#field {
position: relative;
width: 400px;
height: 400px;
margin-left: 10%;
margin-top: 10%;
/*background-color: yellow;*/
border: 5px solid black;
}
.block {
position: relative;
width: 10px;
height: 220px;
background-color: rgba(255, 0, 0, 0.5);
}
#first,
#second,
#third,
#fourth,
#fifth{
position: absolute;
top: 15%;
left: 50%;
transform-origin: center 320px;
}
</style>
</head>
<body>
<div id="field">
<div id="first" class="animate">
<div class="block">1</div>
</div>
<div id="second">
<div class="block">2</div>
</div>
<div id="third">
<div class="block">3</div>
</div>
<div id="fourth">
<div class="block">4</div>
</div>
<div id="fifth">
<div class="block">5</div>
</div>
</div>
<input id="button" type="button" value="Push me!">
<script>
window.onload = function() {
console.log("VSE GOOD");
var $field = $("#field"),
block = $(".block"),
allBlockes = $("#field > div"),
len = allBlockes.length,
but = $("#button");
but.on("click", allBlockes, function() {
function AnimateRotate(el, d) {
$({
deg: 0
}).animate({
deg: d
}, {
step: function(now, fx) {
el.css({
transform: "rotate(" + now + "deg)"
})
}
})
}
var left = i = 0;
for (; i < len; i++) {
var el = allBlockes.eq(i);
if (i % 2) left += 15;
left = -left;
AnimateRotate(el, left)
}
})
};
</script>
</body>
</html>
Последний раз редактировалось рони, 06.11.2016 в 16:19.
|
|
06.11.2016, 16:06
|
|
Профессор
|
|
Регистрация: 11.07.2016
Сообщений: 300
|
|
Ещё раз спасибо, рони.
К сожалению совет, destus, оказался с подвохом)
Если продолжать нажимать button градусы у дивов будут продолжать умножаться =)
|
|
06.11.2016, 16:19
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,126
|
|
Сообщение от Black_Star
|
оказался с подвохом
|
var i далековато, перенесите в клик.
|
|
06.11.2016, 17:04
|
|
Профессор
|
|
Регистрация: 18.05.2011
Сообщений: 1,207
|
|
Black_Star,
Да, не обратил внимание где у вас в коде i была обьявлена. Решается как сказал рони)
|
|
|
|