Skip to content

This prefab adds subtitles support to USharpVideo (or any other video player) in VRChat

License

Notifications You must be signed in to change notification settings

jacklul/USharpVideo-Subtitles

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Subtitles support for USharpVideo

This prefab adds support for SRT subtitles to USharpVideo - it will also work with base video players supported by VRChat (Unity and AVPro).
To check this out in-game visit this test world.

The core of this prefab is based on this code by Haï~.

Features

  • Load subtitles from the pasted text or URL
  • Subtitle synchronization with everyone in the instance
  • Option to use own subtitles locally
  • Rich customization with the ability to save the settings
  • Integration with USharpVideo

Requirements

Installation

Tip

I suggest adding "subtitles" to your world's tags when using this prefab so that people can find worlds with subtitle support more easily.

  1. Import USharpVideo

    • This is required even if you're not planning on using it
  2. Import latest release unitypackage

  3. Drag the Subtitles prefab into your scene

    • when using USharpVideo you can also drag Subtitles prefab into USharpVideo in your scene and reset Subtitles object's transform values
  4. When a window asking you to import TextMeshPro Essentials appears - just do it

  5. Add a reference in the Subtitles object (SubtitleManager script) to:

    • when using USharpVideo (Target Video Player field) - USharpVideoPlayer from the USharpVideo object
    • in any other case (Base Video Player field) - VRCUnityVideoPlayer or VRCAVProVideoPlayer that have to be somewhere in your scene - depends on which one you're using (you can change this dynamically)
  6. Add a reference in the Subtitles/Overlay object (Video Screen field) to the video player's screen object, the overlay will copy the position and rotation of the screen on start

    • if this doesn't work on your world then you will have to manually adjust Subtitles/Overlay object's position and rotation to match the video screen object (while keeping the mentioned earlier field empty)

Upgrading

  1. Delete the prefab from your scene

  2. Import new package

  3. Re-do Installation steps 3. 5. and 6.

Quick API reference

Methods that you might be interested in using when integrating this prefab with other stuff in your world.

SubtitleManager.SetVideoPlayer(BaseVRCVideoPlayer): void

Use this to change the video player reference that the subtitles are synced with

  • Does nothing when using USharpVideo

SubtitleManager.HasSubtitles(): bool

Check whenever subtitles are currently loaded

  • It will return true if subtitles are loaded for the current mode (IsLocal())

SubtitleManager.ProcessInput(string): void

Loads subtitles from the text string globally or locally (depending on IsLocal() value)

  • When using USharpVideo - only the player who can control the video player can do this
  • For other video players - if IsLocked() is true then only the Master can do this
  • To check whenever player is able to execute this - use SubtitleManager.CanControlSubtitles()

SubtitleManager.ProcessURLInput(VRCUrl): void

Loads subtitles from the URL globally or locally (depending on IsLocal() value)

  • When using USharpVideo - only the player who can control the video player can do this
  • For other video players - if IsLocked() is true then only the Master can do this
  • To check whenever player is able to execute this - use SubtitleManager.CanControlSubtitles()

SubtitleManager.ClearSubtitles(): void

Clears the subtitles globally or locally (depending on IsLocal() value)

  • When using USharpVideo - only the player who can control the video player can do this
  • For other video players - if IsLocked() is true then only the Master can do this
  • To check whenever player is able to execute this - use SubtitleManager.CanControlSubtitles()

SubtitleManager.IsLocked(): bool

Whenever the access is locked to Master only

  • When using USharpVideo it shares the same state with it

SubtitleManager.SetLocked(bool): void

Change lock state, must be executed by the Master

  • Does nothing when used with USharpVideo as it shares the same state with it
  • This can fail if the synchronization is ongoing - check if SubtitleManager.IsSynchronized() is true before running it
  • To check whenever player is able to execute this - use SubtitleManager.IsPrivilegedUser(VRCPlayerApi)

SubtitleManager.IsEnabled(): bool

Whenever the subtitles are enabled for the the player

SubtitleManager.SetEnabled(bool): void

Enable or disable the subtitles for the the player

SubtitleManager.IsLocal(): bool

Whenever the player is using local subtitles

SubtitleManager.SetLocal(bool): void

Switch between using global and local subtitles

SubtitleManager.IsSyncedURL(): bool

Check if URL was synced or not, make sure to also check if SubtitleManager.IsSynchronized() is true

  • If this is false and SubtitleManager.IsSynchronized() is true then subtitles from pasted text are used

SubtitleManager.ReloadSyncedURL(): bool

Reload data from synced URL, can be used to retry failed requests

  • This is done locally, anyone can call this

SubtitleManager.SynchronizeSubtitles(): void

Re-synchronizes the subtitles globally, only the person who loaded them can do this (or the master if the synchronization is finished) - this can change when that person leaves the instance or lock state changes - check the SubtitleManager.gameObject owner in this case

  • This can fail if the synchronization is ongoing - check if SubtitleManager.IsSynchronized() is true before running it
  • To check whenever player is able to execute this - use SubtitleManager.CanSynchronizeSubtitles()

SubtitleOverlayHandler.GetCanvasTransform(): Transform

Use this method to get transform values of the overlay's Canvas in case you want to display something on the same screen

SubtitleOverlayHandler.MoveOverlay(GameObject): void

Moves the overlay to the given object's transform values

  • Make sure that the settings popup is not visible at this time as it will stay in the old position until it is re-opened

SubtitleControlHandler.IsSettingsPopupActive(): bool

Check if settings popup is currently open

SubtitleControlHandler.ToggleSettingsPopup(): void

Toggle settings popup, use this to show and hide the popup using separate button

SubtitleControlHandler.ImportSettingsFromString(string): void

Import settings from the given string (the same string which is displayed in the settings window), the format is pretty easy to figure out

About

This prefab adds subtitles support to USharpVideo (or any other video player) in VRChat

Topics

Resources

License

Stars

Watchers

Forks

Languages