Descrição
Use a API chrome.tabCapture para interagir com streams de mídia de guias.
Permissões
tabCaptureConceitos e uso
A API chrome.tabCapture permite acessar um MediaStream que contém vídeo e áudio da guia atual. Ele só pode ser chamado depois que o usuário invoca uma extensão, por exemplo,
clicando no botão de ação da extensão. Isso é semelhante ao comportamento da permissão
"activeTab".
Preservar áudio do sistema
Quando um MediaStream é obtido para uma guia, o áudio dela não é mais reproduzido para o usuário. Isso é semelhante ao comportamento da função getDisplayMedia() quando a flag suppressLocalAudioPlayback é definida como "true".
Para continuar reproduzindo áudio para o usuário, use o seguinte:
const output = new AudioContext();
const source = output.createMediaStreamSource(stream);
source.connect(output.destination);
Isso cria um novo AudioContext e conecta o áudio do MediaStream da guia ao destino
padrão.
IDs de stream
Chamar chrome.tabCapture.getMediaStreamId() vai retornar um ID de stream. Para acessar um MediaStream posteriormente usando o ID, use o seguinte:
navigator.mediaDevices.getUserMedia({
  audio: {
    mandatory: {
      chromeMediaSource: "tab",
      chromeMediaSourceId: id,
    },
  },
  video: {
    mandatory: {
      chromeMediaSource: "tab",
      chromeMediaSourceId: id,
    },
  },
});
Restrições de uso
Depois de chamar getMediaStreamId(), há restrições sobre onde o
ID de stream retornado pode ser usado:
- Se consumerTabIdfor especificado, o ID poderá ser usado por uma chamadagetUserMedia()em qualquer frame na guia especificada que tenha a mesma origem de segurança.
- Quando isso não é especificado, a partir do Chrome 116, o ID pode ser usado em qualquer frame com a mesma origem de segurança no mesmo processo de renderização do caller. Isso significa que um ID de fluxo obtido em um service worker pode ser usado em um documento offscreen.
Antes do Chrome 116, quando um consumerTabId não era especificado, o ID do fluxo era restrito à origem de segurança, ao processo de renderização e ao frame de renderização do caller.
Saiba mais
Para saber mais sobre como usar a API chrome.tabCapture, consulte
Gravação de áudio e captura de tela. Isso demonstra como usar a
tabCapture e APIs relacionadas para resolver vários casos de uso comuns.
Tipos
CaptureInfo
Propriedades
- 
    tela cheiabooleano Se um elemento na guia capturada está no modo de tela cheia. 
- 
    statusO novo status de captura da guia. 
- 
    tabIdnúmero O ID da guia cujo status foi alterado. 
CaptureOptions
Propriedades
- 
    áudiobooleano opcional 
- 
    audioConstraintsMediaStreamConstraint opcional 
- 
    vídeobooleano opcional 
- 
    videoConstraintsMediaStreamConstraint opcional 
GetMediaStreamOptions
Propriedades
- 
    consumerTabIdnumber optional ID opcional da guia que vai invocar getUserMedia()posteriormente para consumir o fluxo. Se não for especificado, o stream resultante poderá ser usado apenas pela extensão de chamada. O fluxo só pode ser usado por frames na guia especificada cuja origem de segurança corresponda à origem da guia do consumidor. A origem da guia precisa ser segura, por exemplo, HTTPS.
- 
    targetTabIdnumber optional ID opcional da guia que será capturada. Se não for especificado, a guia ativa atual será selecionada. Somente as guias em que a extensão recebeu a permissão activeTabpodem ser usadas como guia de destino.
MediaStreamConstraint
Propriedades
- 
    obrigatórioobjeto 
- 
    opcionalobjeto opcional 
TabCaptureState
Enumeração
"pending" 
 
"ativo" 
 
"stopped" 
 
"error" 
 
Métodos
capture()
chrome.tabCapture.capture(
options: CaptureOptions,
callback: function,
): void
Captura a área visível da guia ativa no momento. A captura só pode ser iniciada na guia ativa no momento depois que a extensão for invocada, de maneira semelhante ao funcionamento da activeTab. A captura é mantida nas navegações de página na guia e para quando a guia é fechada ou o fluxo de mídia é fechado pela extensão.
Parâmetros
- 
    opçõesConfigura o fluxo de mídia retornado. 
- 
    callbackfunção O parâmetro callbacktem esta aparência:(stream: LocalMediaStream) => void - 
    streamLocalMediaStream 
 
- 
    
getCapturedTabs()
chrome.tabCapture.getCapturedTabs(): Promise<CaptureInfo[]>
Retorna uma lista de guias que solicitaram captura ou estão sendo capturadas, ou seja, status != stopped e status != error. Isso permite que as extensões informem ao usuário que há uma captura de guia em andamento que impediria uma nova captura de guia (ou para evitar solicitações redundantes para a mesma guia).
Retorna
- 
            Promise<CaptureInfo[]> Chrome 116 ou mais recente
getMediaStreamId()
chrome.tabCapture.getMediaStreamId(
options?: GetMediaStreamOptions,
): Promise<string>
Cria um ID de fluxo para capturar a guia de destino. Semelhante ao método chrome.tabCapture.capture(), mas retorna um ID de stream de mídia, em vez de um stream de mídia, para a guia do consumidor.
Parâmetros
- 
    opçõesGetMediaStreamOptions opcional 
Retorna
- 
            Promise<string> Chrome 116 ou mais recente
Eventos
onStatusChanged
chrome.tabCapture.onStatusChanged.addListener(
callback: function,
)
Evento disparado quando o status de captura de uma guia muda. Isso permite que os autores de extensões acompanhem o status de captura das guias para manter elementos da interface, como ações de página, sincronizados.
Parâmetros
- 
    callbackfunção O parâmetro callbacktem esta aparência:(info: CaptureInfo) => void - 
    informações
 
-