On this page
useUserMedia
Category | Sensors |
---|---|
Export Size | 569 B |
Last Changed | 2 weeks ago |
Related | useDevicesList useDisplayMedia usePermission |
Reactive mediaDevices.getUserMedia
streaming.
Usage
import { useUserMedia } from '@vueuse/core'
const { stream, start } = useUserMedia()
start()
const video = document.getElementById('video')
watchEffect(() => {
// preview on a video element
video.srcObject = stream.value
})
Devices
import { useDevicesList, useUserMedia } from '@vueuse/core'
const {
videoInputs: cameras,
audioInputs: microphones,
} = useDevicesList({
requestPermissions: true,
})
const currentCamera = computed(() => cameras.value[0]?.deviceId)
const currentMicrophone = computed(() => microphones.value[0]?.deviceId)
const { stream } = useUserMedia({
constraints: {
video: { deviceId: currentCamera },
audio: { deviceId: currentMicrophone, }
}
})
Type Declarations
export interface UseUserMediaOptions extends ConfigurableNavigator {
/**
* If the stream is enabled
* @default false
*/
enabled?: MaybeRef<boolean>
/**
* Recreate stream when deviceIds or constraints changed
*
* @default true
*/
autoSwitch?: MaybeRef<boolean>
/**
* MediaStreamConstraints to be applied to the requested MediaStream
* If provided, the constraints will override videoDeviceId and audioDeviceId
*
* @default {}
*/
constraints?: MaybeRef<MediaStreamConstraints>
}
/**
* Reactive `mediaDevices.getUserMedia` streaming
*
* @see https://vueuse.org/useUserMedia
* @param options
*/
export declare function useUserMedia(options?: UseUserMediaOptions): {
isSupported: ComputedRef<boolean>
stream: Ref<MediaStream | undefined>
start: () => Promise<MediaStream | undefined>
stop: () => void
restart: () => Promise<MediaStream | undefined>
constraints: Ref<
| MediaStreamConstraints
| {
audio?:
| boolean
| {
advanced?:
| {
aspectRatio?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
autoGainControl?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
channelCount?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
deviceId?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
displaySurface?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
echoCancellation?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
facingMode?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
frameRate?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
groupId?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
height?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
noiseSuppression?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
sampleRate?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
sampleSize?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
width?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
}[]
| undefined
aspectRatio?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
autoGainControl?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
channelCount?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
deviceId?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
displaySurface?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
echoCancellation?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
facingMode?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
frameRate?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
groupId?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
height?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
noiseSuppression?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
sampleRate?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
sampleSize?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
width?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
}
| undefined
peerIdentity?: string | undefined
preferCurrentTab?: boolean | undefined
video?:
| boolean
| {
advanced?:
| {
aspectRatio?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
autoGainControl?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
channelCount?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
deviceId?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
displaySurface?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
echoCancellation?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
facingMode?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
frameRate?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
groupId?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
height?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
noiseSuppression?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
sampleRate?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
sampleSize?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
width?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
}[]
| undefined
aspectRatio?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
autoGainControl?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
channelCount?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
deviceId?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
displaySurface?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
echoCancellation?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
facingMode?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
frameRate?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
groupId?:
| string
| string[]
| {
exact?: string | string[] | undefined
ideal?: string | string[] | undefined
}
| undefined
height?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
noiseSuppression?:
| boolean
| {
exact?: boolean | undefined
ideal?: boolean | undefined
}
| undefined
sampleRate?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
sampleSize?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
width?:
| number
| {
exact?: number | undefined
ideal?: number | undefined
max?: number | undefined
min?: number | undefined
}
| undefined
}
| undefined
}
| undefined
>
enabled: Ref<boolean>
autoSwitch: Ref<boolean>
}
export type UseUserMediaReturn = ReturnType<typeof useUserMedia>
Source
© 2019-present Anthony Fu
Licensed under the MIT License.
https://vueuse.org/core/useUserMedia/