Tutorial: Morphing & Sequenced Animations

Crea trasformazioni di forma mesmerizing e animazioni multi-element coreografiche.

20 minuti

Difficolta’ # Avanzato

Cosa creerai

Una sequenza dinamica in cui le forme si trasformano l’un l’altro mentre il testo rivela con tempismo sfalsato.

Shape morphing con testo sfalsato rivelare

Caratteristiche rivestite

  • Shape morfing — Passività tra forme diverse
  • Animazioni registrate — Tempismo sequenziato per più elementi
  • Trasferimenti di colore — Cambiamenti di colore sfumati animati
  • La maschera rivela — Effetti di salviette e iride cinematica
  • Sequenze coreografiche — Danza multi-elementare con un tempo preciso

Parte 1: Morphing forma

Passo 1: Crea la forma sorgente

  1. Crea un cerchio al centro:
    • Raggio: 80
    • Colore: #3b82f6 (blu)
    • Position: (400, 300)
const circle = app.create('circle', {
  x: 400, y: 300,
  radius: 80,
  color: '#3b82f6'
});

Passo 2: Crea la forma di destinazione

  1. Creare una stella (sarà il bersaglio morfo):
    • Punti: 5
    • Raggio: 100
    • Colore: #f59e0b (ambra)
    • Position: (400, 300)
const star = app.create('star', {
  x: 400, y: 300,
  points: 5,
  radius1: 100,
  radius2: 40,
  color: '#f59e0b'
});

Passo 3: Aggiungere la relazione Morph

La relazione morphs_to crea transizioni di forma liscia:

app.addRelation(circle.data.id, star.data.id, 'morphs_to', {
  duration: 1.5,
  easing: 'easeInOut',
  morphColor: true,   // Also transition colors
  morphSize: true     // Also transition size
});

Passo 4: Catena Morfi multipli

Creare una sequenza morfologica: Cerchio → Stella → Triangolo → Cerchio

const shapes = [];

// Circle
shapes.push(app.create('circle', {
  x: 400, y: 300, radius: 80, color: '#3b82f6'
}));

// Star
shapes.push(app.create('star', {
  x: 400, y: 300, points: 5, radius1: 100, radius2: 40,
  color: '#f59e0b', opacity: 0
}));

// Triangle
shapes.push(app.create('triangle', {
  x: 400, y: 300, radius: 90,
  color: '#10b981', opacity: 0
}));

// Hexagon (back to geometric)
shapes.push(app.create('polygon', {
  x: 400, y: 300, sides: 6, radius: 85,
  color: '#8b5cf6', opacity: 0
}));

// Chain morphs with delays
for (let i = 0; i < shapes.length - 1; i++) {
  app.addRelation(shapes[i].data.id, shapes[i + 1].data.id, 'morphs_to', {
    duration: 1.2,
    delay: i * 1.5,  // Stagger start times
    easing: 'easeInOut',
    morphColor: true
  });
}

// Loop back to first shape
app.addRelation(shapes[shapes.length - 1].data.id, shapes[0].data.id, 'morphs_to', {
  duration: 1.2,
  delay: (shapes.length - 1) * 1.5,
  easing: 'easeInOut',
  morphColor: true
});

Parte 2: Rivelare il testo

Passo 5: Creare Collage lettera

const collage = app.letterCollage.create('TRANSFORM', {
  style: 'gradient',
  gradientPalette: 'cyberpunk',
  gradientDirection: 'horizontal',
  fontSize: 64,
  x: 400, y: 500
});

Passo 6: Applicare l’animazione schiacciata

app.letterCollage.applyStaggeredAnimation(collage.collageId, {
  effect: 'fadeSlideUp',
  staggerDelay: 0.06,    // 60ms between letters
  duration: 0.5,
  sequence: 'center',     // Start from center, expand outward
  easing: 'easeOut'
});

Modelli di sequenza

Modello Effetto
linear Da sinistra a destra
reverse Da destra a sinistra
center Centro esterno
random Ordine casuale
wave Tempo delle onde Sine
fibonacci Ritmo naturale

Parte 3: Rivelazione della maschera

Passo 7: Aggiungi il rivelatore drammatico

Rivelare la forma morfificante con un effetto iride:

// Apply animated mask to the shape container
app.applyAnimatedMask(shapes[0], 'iris', {
  startTime: 0,
  duration: 0.8,
  easing: 'easeOut'
});

Fase 8: Wipe Reveal per testo

// Reveal text with horizontal wipe
app.applyAnimatedMask(collage.group, 'wipeLeft', {
  startTime: 0.5,  // Start after shape reveals
  duration: 0.6,
  easing: 'easeInOut'
});

Preimpostazioni di maschera disponibili

Preset Effetto
iris Cerchio che si espande dal centro
wipeLeft Rivelazione orizzontale da sinistra
wipeUp Rivelazione verticale dal basso
star Forma stellare in espansione
heart Forma del cuore in espansione
curtainHorizontal Aperto dal centro
diagonalWipe Rivelazione angolare

Parte 4: Coreografia completa

Script di animazione completa

// === SETUP ===
app.setCanvasSize({ width: 800, height: 600 });
app.setBackgroundColor('#0f172a');

// === MORPHING SHAPES ===
const shapeColors = ['#3b82f6', '#f59e0b', '#10b981', '#8b5cf6'];
const shapeTypes = ['circle', 'star', 'triangle', 'polygon'];

const mainShape = app.create('circle', {
  x: 400, y: 250,
  radius: 80,
  color: shapeColors[0]
});

// Keyframe the shape through color transitions
app.addAnimation(mainShape.data.id, [
  { time: 0, properties: { fillColor: '#3b82f6', scale: 1 } },
  { time: 1.5, properties: { fillColor: '#f59e0b', scale: 1.2 }, easing: 'easeInOut' },
  { time: 3, properties: { fillColor: '#10b981', scale: 0.9 }, easing: 'easeInOut' },
  { time: 4.5, properties: { fillColor: '#8b5cf6', scale: 1.1 }, easing: 'easeInOut' },
  { time: 6, properties: { fillColor: '#3b82f6', scale: 1 }, easing: 'easeInOut' }
]);

// Add rotation for visual interest
app.addAnimation(mainShape.data.id, [
  { time: 0, properties: { rotation: 0 } },
  { time: 6, properties: { rotation: 360 }, easing: 'linear' }
]);

// === IRIS REVEAL FOR SHAPE ===
app.applyAnimatedMask(mainShape, 'iris', {
  startTime: 0,
  duration: 0.6,
  easing: 'easeOut'
});

// === STAGGERED TEXT ===
const title = app.letterCollage.create('TRANSFORM', {
  style: 'tile',
  palette: 'neon',
  fontSize: 56,
  x: 400, y: 480
});

app.letterCollage.applyStaggeredAnimation(title.collageId, {
  effect: 'popIn',
  staggerDelay: 0.05,
  duration: 0.4,
  sequence: 'center',
  easing: 'elastic'
});

// === ORBITING ACCENTS ===
const orbitColors = ['#f472b6', '#34d399', '#fbbf24'];
orbitColors.forEach((color, i) => {
  const dot = app.create('circle', {
    x: 400, y: 250,
    radius: 6,
    color: color
  });

  app.addRelation(dot.data.id, mainShape.data.id, 'orbits', {
    radius: 120 + i * 25,
    speed: 0.4 - i * 0.1,
    phase: i * (Math.PI * 2 / 3)
  });

  // Fade in the orbiting dots
  app.addAnimation(dot.data.id, [
    { time: 0.8 + i * 0.2, properties: { opacity: 0, scale: 0 } },
    { time: 1.2 + i * 0.2, properties: { opacity: 1, scale: 1 }, easing: 'elastic' }
  ]);
});

// === CAMERA MOVEMENT ===
app.addRelation('camera', null, 'camera_animates', {
  duration: 6,
  loop: true,
  keyframes: [
    { time: 0, zoom: 1, center: [400, 300] },
    { time: 1.5, zoom: 1.15, center: [400, 280], easing: 'easeOut' },
    { time: 3, zoom: 1.05, center: [400, 320], easing: 'easeInOut' },
    { time: 4.5, zoom: 1.1, center: [400, 300], easing: 'easeInOut' },
    { time: 6, zoom: 1, center: [400, 300], easing: 'easeOut' }
  ]
});

// === PLAY ===
app.playKeyframeTimeline(6, true);

Impostazioni di esportazione

Per i migliori risultati con animazioni morfificanti:

Impostazione Valore Motivazione
Formato WebM Migliore qualità per gradienti
Tasso di telaio 60 fps Morfidi molli
Durata 6 secondi Ciclo di ciclo completo
Qualità Alto Conservare le transizioni di colore

Pro Suggerimenti

Overlap time — Avviare la prossima animazione 0.1-0.2s prima delle estremità precedenti per il flusso senza soluzione di continuità.

Utilizza colori complementari — I morfidi di forma sembrano migliori quando si passa tra i colori che funzionano bene insieme.

Sequenza del client per l’impatto — Il modello di stagger center attira l’attenzione sul mezzo del testo.

Match rivelare al contenuto — Utilizzare iris per forme circolari, wipeLeft per il testo.


Variazioni

Visualizzazione dati Morph

// Bar chart to pie chart transition
const bars = createBarChart(data);
const pie = createPieChart(data);

app.addRelation(bars.data.id, pie.data.id, 'morphs_to', {
  duration: 2,
  easing: 'easeInOut'
});
// Logo parts appear in sequence
const logoParts = [shape1, shape2, shape3, text];

logoParts.forEach((part, i) => {
  app.addAnimation(part.data.id, [
    { time: i * 0.3, properties: { opacity: 0, scale: 0.5 } },
    { time: i * 0.3 + 0.4, properties: { opacity: 1, scale: 1 }, easing: 'elastic' }
  ]);
});

Prossimo passo