Держите детей внутри родительского контейнера
Я пытаюсь добавить немного анимации к плагину облака тегов. Но я застрял с одной проблемой. Как я могу сохранить дочерние элементы (теги) внутри родительского контейнера? Я хочу убедиться, что позиции анимации никогда не пересекаются с одним из краев контейнера.
URL-адрес Codepen: http://codepen.io/anon/pen/vgLdWV Я специально прокомментировал "переполнение: скрытое"; так что вы можете видеть, что метки летят за пределы контейнера.
function getRandom (max, min) {
return Math.floor(Math.random() * (1 + max - min) + min);
}
var words = [
{text: "performance", weight: getRandom(2, 8)},
{text: "education", weight: getRandom(2, 8)},
{text: "employee", weight: getRandom(2, 8)},
{text: "people", weight: getRandom(2, 8)},
{text: "future", weight: getRandom(2, 8)},
{text: "success", weight: getRandom(2, 8)},
{text: "talent", weight: getRandom(2, 8)},
{text: "career", weight: getRandom(2, 8)},
{text: "strategy evaluate", weight: getRandom(2, 8)},
{text: "training & development", weight: getRandom(2, 8)},
{text: "learn", weight: getRandom(2, 8)},
{text: "activities", weight: getRandom(2, 8)}
];
$('#keywords').jQCloud(words, {
shape: 'elliptic',
removeOverflowing: false,
afterCloudRender: function () {
var box = $(this);
var width = box.width();
var height = box.height();
var chute = $('span', box);
chute.each(function () {
foo($(this));
});
function foo($el) {
var $top = (Math.random() * (height - $el.height() - $el.position().top)) | 0;
var $left = (Math.random() * (width - $el.width() - $el.position().left)) | 0;
var time = Math.random() * (1200 - 400) + 400 | 0;
new TimelineLite({
onComplete: function () {
foo($el);
}
})
.to($el, time/100, {
y: $top * (Math.round(Math.random()) * 2 - 1),
x: $left * (Math.round(Math.random()) * 2 - 1),
z: getRandom(-200, 200) * (Math.round(Math.random()) * 2 - 1),
transformPerspective: 800,
force3D: true,
ease: SlowMo.ease.config(0.3, 0.7, false)
}, 'one')
.to($el, time/200, {
opacity: 1,
ease: SlowMo.ease.config(0.3, 0.7, false)
}, 'one')
.to($el, time/200, {
opacity: 0,
ease: SlowMo.ease.config(0.3, 0.7, false)
}, time/200, 'one')
.set($el, {
y: $top * (Math.round(Math.random()) * 2 - 1),
x: $left * (Math.round(Math.random()) * 2 - 1),
force3D: true
});
}
}
});
1 ответ
Если кому интересно, вот мое решение сейчас
$('#tagscloud').jQCloud(words, {
// shape: 'elliptic',
removeOverflowing: false,
afterCloudRender: function () {
var $box = $(this),
$boxWidth = $box.width(),
$boxHeight = $box.height();
//
$('span', $box).each(function () {
tagsMovement($(this));
});
//
function tagsMovement (el) {
var topY = $(el).position().top,
bottomY = $boxHeight - $(el).height() - $(el).position().top,
$top = topY >= bottomY ? -getRandom(15, topY) : getRandom(15, bottomY),
leftX = $(el).position().left,
rightX = $boxWidth - $(el).width() - $(el).position().left,
$left = leftX >= rightX ? -getRandom(15, leftX) : getRandom(15, rightX),
time = Math.random() * (1200 - 400) + 400 | 0;
// var $top = (Math.random() * (height - $(el).height() - $(el).position().top)) | 0;
// var $left = (Math.random() * (width - $(el).width() - $(el).position().left)) | 0;
new TimelineLite({
onComplete: function () {
tagsMovement($(el));
}
})
.to($(el), time/75, {
y: $top,
x: $left,
z: getRandom(-300, 300),
transformPerspective: 800,
force3D: true,
ease: Sine.easeInOut
}, 'one')
.to($(el), time/150, {
opacity: 1,
ease: Sine.easeInOut
}, 'one')
.to($(el), time/150, {
opacity: 0,
ease: Sine.easeInOut
}, time/150, 'one')
.set($(el), {
top: topY + $top,
left: leftX + $left,
y: 0,
x: 0,
force3D: true
});
}
}
});