/************************************************************************************
Depthkit Unity SDK License v1
Copyright 2016-2024 Simile Inc dba Scatter. All Rights reserved.
Licensed under the the Simile Inc dba Scatter ("Scatter")
Software Development Kit License Agreement (the "License");
you may not use this SDK except in compliance with the License,
which is provided at the time of installation or download,
or which otherwise accompanies this software in either electronic or hard copy form.
You may obtain a copy of the License at http://www.depthkit.tv/license-agreement-v1
Unless required by applicable law or agreed to in writing,
the SDK distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and limitations under the License.
************************************************************************************/
using UnityEngine;
using System.Collections;
namespace Depthkit
{
///
/// The base class that any Depthkit player implementation will derrive from
///
/// This class provides methods that are implemented in child classes to allow
/// a way for clip to generically interact with a given player backend.
[RequireComponent(typeof(Depthkit.Clip))]
[ExecuteInEditMode]
public abstract class ClipPlayer : MonoBehaviour
{
public bool videoLoaded { get; protected set; }
[HideInInspector]
public Depthkit.PlayerEvents events = new Depthkit.PlayerEvents();
///
/// creates the appropriate player
///
public abstract void CreatePlayer();
///
/// returns player created status
///
public abstract bool IsPlayerCreated();
///
/// returns true if the video player has a video configured and is ready to play
///
public abstract bool IsPlayerSetup();
///
/// Load the implemented player video.
///
public abstract IEnumerator Load();
///
/// Method to dispatch the video loader to start
public abstract void StartVideoLoad();
///
/// Load a video and then play through the implemented player.
public abstract IEnumerator LoadAndPlay();
///
/// Sets the video from a path. Assumed absolute file path.
public abstract void SetVideoPath(string path);
///
/// Get the absolute path to the video.
public abstract string GetVideoPath();
///
/// Callback for metadata updated on the clip.
public abstract void OnMetadataUpdated(Depthkit.Metadata metadata);
///
/// Play through the implemented player. Worth using in combination with VideoLoaded to ensure playback will start when called.
public abstract void Play();
///
/// Pause through the implemented player.
public abstract void Pause();
///
/// Stop playback through the player.
public abstract void Stop();
///
/// Remove the player components from this GameObject.
public abstract void RemoveComponents();
///
/// Return the texture for Depthkit to use by Renderers
public abstract Texture GetTexture();
///
/// Returns if texture generated is flipped
public abstract bool IsTextureFlipped();
///
/// Returns if shader needs to gamma correct depth value on this texture
public abstract GammaCorrection GammaCorrectDepth();
/// Returns if shader needs to gamma correct color value on this shader
public abstract GammaCorrection GammaCorrectColor();
///
/// Return the type name of player being used
public abstract string GetPlayerTypeName();
///
/// Return the pretty name of player being used
public static string GetPlayerPrettyName(){ return "Must Provide this function"; }
///
/// Check if video is playing right now or not
public abstract bool IsPlaying();
///
/// Get the current playback time of the video in seconds.
public abstract double GetCurrentTime();
///
/// Get the current playback frame of the video.
public abstract int GetCurrentFrame();
///
/// Get duration of video in seconds
public abstract double GetDuration();
///
/// Seek to a time point in the video in seconds
public abstract void Seek(float toTimeSeconds);
public abstract uint GetVideoWidth();
public abstract uint GetVideoHeight();
public abstract bool SupportsPosterFrame();
}
}