Skip to content

Commit

Permalink
feat: add setVolume function to component's ref (#3794)
Browse files Browse the repository at this point in the history
* feat: add setVolume function to component's ref

* Update methods.mdx
  • Loading branch information
seyedmostafahasani authored May 20, 2024
1 parent d4c9be2 commit 3cd7ab6
Show file tree
Hide file tree
Showing 6 changed files with 32 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,13 @@ class VideoManagerModule(reactContext: ReactApplicationContext?) : ReactContextB
}
}

@ReactMethod
fun setVolume(volume: Float, reactTag: Int) {
performOnPlayerView(reactTag) {
it?.setVolumeModifier(volume)
}
}

companion object {
private const val REACT_CLASS = "VideoManager"
}
Expand Down
8 changes: 8 additions & 0 deletions docs/pages/component/methods.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,14 @@ By default iOS seeks within 100 milliseconds of the target position. If you need

tolerance is the max distance in milliseconds from the seconds position that's allowed. Using a more exact tolerance can cause seeks to take longer. If you want to seek exactly, set tolerance to 0.

### `setVolume`

<PlatformsList types={['Android', 'iOS']} />

`setVolume(value): Promise<void>`

This function will change the volume exactly like [volume](../props#volume) property. default value and range are the same then.

### Example Usage

```tsx
Expand Down
2 changes: 2 additions & 0 deletions ios/Video/RCTVideoManager.m
Original file line number Diff line number Diff line change
Expand Up @@ -86,4 +86,6 @@ @interface RCT_EXTERN_MODULE (RCTVideoManager, RCTViewManager)

RCT_EXTERN_METHOD(dismissFullscreenPlayer : (nonnull NSNumber*)reactTag)

RCT_EXTERN_METHOD(setVolume : (nonnull float*)volume reactTag : (nonnull NSNumber*)reactTag)

@end
7 changes: 7 additions & 0 deletions ios/Video/RCTVideoManager.swift
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,13 @@ class RCTVideoManager: RCTViewManager {
})
}

@objc(setVolume:reactTag:)
func setVolume(value: Float, reactTag: NSNumber) {
performOnVideoView(withReactTag: reactTag, callback: { videoView in
videoView?.setVolume(value)
})
}

override class func requiresMainQueueSetup() -> Bool {
return true
}
Expand Down
7 changes: 7 additions & 0 deletions src/Video.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ export interface VideoRef {
restore: boolean,
) => void;
save: (options: object) => Promise<VideoSaveData>;
setVolume: (volume: number) => void;
}

const Video = forwardRef<VideoRef, ReactVideoProps>(
Expand Down Expand Up @@ -289,6 +290,10 @@ const Video = forwardRef<VideoRef, ReactVideoProps>(
[setRestoreUserInterfaceForPIPStopCompletionHandler],
);

const setVolume = useCallback((volume: number) => {
return VideoManager.setVolume(volume, getReactTag(nativeRef));
}, []);

const onVideoLoadStart = useCallback(
(e: NativeSyntheticEvent<OnLoadStartData>) => {
hasPoster && setShowPoster(true);
Expand Down Expand Up @@ -505,6 +510,7 @@ const Video = forwardRef<VideoRef, ReactVideoProps>(
pause,
resume,
restoreUserInterfaceForPictureInPictureStopCompleted,
setVolume,
}),
[
seek,
Expand All @@ -514,6 +520,7 @@ const Video = forwardRef<VideoRef, ReactVideoProps>(
pause,
resume,
restoreUserInterfaceForPictureInPictureStopCompleted,
setVolume,
],
);

Expand Down
1 change: 1 addition & 0 deletions src/specs/VideoNativeComponent.ts
Original file line number Diff line number Diff line change
Expand Up @@ -372,6 +372,7 @@ export interface VideoManagerType {
licenseUrl: string,
reactTag: number,
) => Promise<void>;
setVolume: (volume: number, reactTag: number) => Promise<void>;
}

export interface VideoDecoderPropertiesType {
Expand Down

0 comments on commit 3cd7ab6

Please sign in to comment.