Skip to main content
A sincronização de letras alinha o texto da letra ao áudio para que as palavras sejam destacadas no momento certo. Use client.projects.syncLyrics(...) para executar novamente a sincronização em qualquer projeto com letras atualizadas, um modelo diferente ou um novo idioma.

client.projects.syncLyrics(projectId, body, options?)

Inicie uma nova operação de sincronização de letras.
const operation = await client.projects.syncLyrics("prj_abc123", {
  lyricsSource: {
    type: "align",
    lyrics: "First line\nSecond line\n...",
    syncModel: "audioshake-alignment",
  },
});

const { project } = await client.projects.wait(operation);
console.log(project.alignments);

Fonte de letras

Passe um objeto lyricsSource no corpo da requisição:
Deixe o modelo transcrever as letras a partir do áudio.
{
  lyricsSource: {
    type: "transcribe",
    syncModel: "audioshake-transcription",
    language: "en",
  },
}

Modelos de sincronização

Modelos de alinhamento (use com align quando você tiver letras precisas):
  • audioshake-alignment
  • musicai-alignment
  • musicai-alignment-subword
Modelos de transcrição (use com transcribe):
  • audioshake-transcription
  • musicai-transcription
  • wav2vec2
  • whisper
Consulte a Referência de modelos de sincronização para orientações.

Exemplo de ponta a ponta

import { YoukaClient } from "@youka/sdk";
import { readFile } from "node:fs/promises";

const client = new YoukaClient({ apiKey: process.env.YOUKA_API_KEY! });

async function reAlignLyrics(projectId: string) {
  const lyrics = await readFile("./lyrics.txt", "utf8");

  const operation = await client.projects.syncLyrics(projectId, {
    lyricsSource: {
      type: "align",
      lyrics,
      syncModel: "audioshake-alignment",
      language: "en",
    },
  });

  const { project } = await client.projects.wait(operation);
  console.log("Updated lyrics with", project.lyrics?.length, "lines");
}

Próximos passos