Я пытаюсь воспроизвести с помощью angular (6) анимированное дерево с листами, движущимися в рандомизированных пространствах, таких как видимые здесь
РЕДАКТИРОВАТЬ, Решено с угловыми анимациями и обратным вызовом, когдазаканчивается анимация, которая изменяет состояние.
Шаблон:
<span *ngFor="let leaf of animatedLeafs"
[ngStyle] = "{
'height.px': leaf.height,
'width.px': leaf.height
}"
[@animateLeaf] = "{
value: statusState,
params: {
top: leaf.top,
left: leaf.left,
angle: leaf.angle,
topDir: leaf.topDir,
leftDir: leaf.leftDir,
angleDir: leaf.angleDir
}}"
(@animateLeaf.done)="loopAnimation($event)"
class="leaf-icon">
</span>
анимации компонентов:
animations: [
trigger('animateLeaf', [
state('start-state', style({
transform: `translate3d({{left}}px, {{top}}px, 0) rotate({{angle}}deg)`
}), {params: {height: 0, left: 0, top: 0, angle: 0}}),
state('loop-state', style({
transform: `translate3d({{leftDir}}px, {{topDir}}px, 0) rotate({{angleDir}}deg)`
}), {params: {height: 0, leftDir: 0, topDir: 0, angleDir: 0}}),
transition('loop-state=>start-state', animate('3s ease-in-out')),
transition('start-state=>loop-state', animate('3s ease-in-out'))
])
]
А в классе:
export class AnimatedTreeComponent implements OnInit {
statusState = 'start-state';
constructor() {
}
loopAnimation(event) {
console.log(event.toState);
this.statusState = event.toState === "loop-state" ? "start-state" : "loop-state"
}
ngOnInit() {
this.createLeafs()
this.statusState = 'loop-state'
}
Надеюсь, это поможет некоторым:)