vdr-plugin-softhddevice-drm-gles 1.6.4-d0291bb
cSoftHdDevice Class Reference

Output Device Implementation. More...

#include <softhddevice.h>

Public Member Functions

 cSoftHdDevice (cSoftHdConfig *)
 Create the device.
 
virtual ~cSoftHdDevice (void)
 Destroy the device.
 
virtual cString DeviceName (void) const
 
virtual bool HasDecoder (void) const
 Tells whether this device has an MPEG decoder.
 
virtual cSpuDecoderGetSpuDecoder (void)
 Get the device SPU decoder.
 
virtual bool CanReplay (void) const
 Return true if this device can currently start a replay session.
 
virtual bool SetPlayMode (ePlayMode)
 Sets the device into the given play mode.
 
virtual int PlayVideo (const uchar *, int)
 Play a video packet of the main videostream.
 
virtual int PlayAudio (const uchar *, int, uchar)
 Play an audio packet.
 
virtual int64_t GetSTC (void)
 Gets the current System Time Counter, which can be used to synchronize audio, video and subtitles.
 
virtual cRect CanScaleVideo (const cRect &, int taCenter)
 Ask the output, if it can scale video.
 
virtual void ScaleVideo (const cRect &=cRect::Null)
 Scale the currently shown video.
 
virtual void TrickSpeed (int, bool)
 Sets the device into a mode where replay is done slower.
 
virtual void Clear (void)
 Clears all video and audio data from the device.
 
virtual void Play (void)
 Sets the device into play mode (after a previous trick mode, or pause)
 
virtual void Freeze (void)
 Puts the device into "freeze frame" mode.
 
virtual void StillPicture (const uchar *, int)
 Display the given I-frame as a still picture.
 
virtual bool Poll (cPoller &, int=0)
 Return true if the device itself or any of the file handles in poller is ready for further action.
 
virtual bool Flush (int=0)
 Flush the device output buffers.
 
virtual ucharGrabImage (int &, bool, int, int, int)
 Grabs the currently visible screen image.
 
virtual void SetVideoDisplayFormat (eVideoDisplayFormat)
 Sets the video display format.
 
virtual void SetVideoFormat (bool)
 Set the video format.
 
virtual void GetVideoSize (int &, int &, double &)
 Get the video size.
 
virtual void GetOsdSize (int &, int &, double &)
 Returns the width, height and aspect ratio the OSD.
 
virtual void SetAudioTrackDevice (eTrackType)
 
virtual int GetAudioChannelDevice (void)
 
virtual void SetAudioChannelDevice (int)
 
virtual void SetVolumeDevice (int)
 Sets the audio volume on this device (Volume = 0...255).
 
virtual void SetDigitalAudioDevice (bool)
 
const charCommandLineHelp (void)
 Return command line help string.
 
int ProcessArgs (int, char *[])
 Process the command line arguments.
 
bool Initialize (void)
 Initialize the device.
 
int Start (void)
 Called by VDR when the plugin is started.
 
void Stop (void)
 Called by VDR when the plugin is stopped.
 
cSoftHdConfigConfig (void)
 
cVideoStreamVideoStream (void)
 
cVideoRenderRender (void)
 
cSoftHdAudioAudio (void)
 
void SetDisableDeint (void)
 Disables deinterlacer (called from setup menu or conf)
 
void SetDecoderNeedsIFrame (void)
 Forces the h264 decoder to wait for an I-Frame to start.
 
void SetParseH264Dimensions (void)
 Parse the h264 stream width and height before starting the decoder.
 
void SetDecoderFallbackToSw (bool)
 Force the decoder to fallback to software if the hardware decoder fails after the configured amount of packets were sent and no frame was received.
 
void SetEnableHdr (bool)
 Enable HDR display mode.
 
int MaxSizeGPUImageCache (void)
 Get the maximum GPU image cache size.
 
int OglOsdIsDisabled (void)
 Is the OpenGL/ES osd disabled?
 
void SetDisableOglOsd (void)
 Disables OpenGL/ES Osd (called from setup menu or conf)
 
void SetEnableOglOsd (void)
 Enables OpenGL/ES Osd.
 
void OsdClose (void)
 Close the OSD.
 
void OsdDrawARGB (int, int, int, int, int, const uint8_t *, int, int)
 Draw an OSD pixmap.
 
void SetScreenSize (int, int, double)
 Set the screen size.
 
int GetVideoAudioDelayMs (void)
 
int GetMinBufferFillLevelThresholdMs (void)
 
void SetPassthroughMask (int)
 Set the passthrough mask (called from setup menu or conf)
 
void ResetChannelId (void)
 Reset the channel ID (restarts audio)
 
void GetStats (int *, int *, int *)
 Get statistics from the renderer.
 
std::chrono::steady_clock::time_point GetChannelSwitchStartTime (void)
 
std::chrono::steady_clock::time_point GetChannelSwitchFirstPacketTime (void)
 
void SetAudioCodec (enum AVCodecID, AVCodecParameters *, AVRational)
 Open an audio codec.
 
void SetVideoCodec (enum AVCodecID, AVCodecParameters *, AVRational)
 Open a video codec.
 
int PlayAudioPkts (AVPacket *)
 Play an audio packet.
 
int PlayVideoPkts (AVPacket *)
 Play a video packet.
 
void Detach (void)
 Detach the device.
 
void Attach (void)
 Attach the device again.
 
bool IsDetached (void) const
 Returns true, if the device is detached.
 
void ResetOsdProvider (void)
 
bool IsOsdProviderSet (void) const
 
bool IsBufferingThresholdReached (void)
 Check if the buffering threshold has been reached.
 
bool IsVideoOnlyPlayback (void)
 
bool PipIsEnabled (void)
 Returns true, if pip is currently enabled.
 
void PipEnable (void)
 
void PipDisable (void)
 
void PipToggle (void)
 
void PipChannelChange (int)
 
void PipChannelSwap (bool)
 
void PipSwapPosition (void)
 
void PipSetSize (void)
 
void SetRenderPipSize (void)
 Wrapper functions for cVideoRender and cPipHandler.
 
void SetRenderPipActive (bool)
 
int PlayPipVideo (const uchar *, int)
 Play a video packet of the pip videostream.
 
void SetDrmCanDisplayPip (bool canDisplay)
 
bool UsePip (void)
 
void ResetPipStream (void)
 Resets pip stream and render pipeline.
 
void ToggleRenderPipPosition (void)
 

Protected Member Functions

virtual void MakePrimaryDevice (bool)
 Informs a device that it will be the primary device.
 
virtual void ChannelSwitch (const cDevice *, int, bool)
 Monitor a channel switch triggered by VDR (cStatus::ChannelSwitch())
 

Private Member Functions

int PlayVideoInternal (cVideoStream *, cReassemblyBufferVideo *, const uchar *, int, bool)
 Play a video packet.
 
void FlushAudio (void)
 Clear all audio data from the decoder and ringbuffer.
 
void OnEventReceived (const Event &)
 Event handler for playback state transitions.
 
void HandleStillPicture (const uchar *data, int size)
 The still picture data received from VDR can contain multiple PES packets.
 
int64_t GetFirstAudioPtsMsToPlay ()
 Calculate the first audio PTS that should be played during synchronized playback.
 
int64_t GetFirstVideoPtsMsToPlay ()
 
int GetBufferFillLevelThresholdMs ()
 Returns the buffer fill level threshold in milliseconds.
 
void SetState (State)
 Sets the device into the given state.
 
void OnEnteringState (State)
 Actions to be performed when entering a state.
 
void OnLeavingState (State)
 Actions to be performed when leaving a state.
 

Private Attributes

std::atomic< Statem_state = DETACHED
 current plugin state, normal plugin start sets detached state
 
std::mutex m_eventMutex
 mutex to protect event queue
 
bool m_needsMakePrimary = false
 
cDvbSpuDecoderm_pSpuDecoder
 pointer to spu decoder
 
cSoftHdConfigm_pConfig
 pointer to cSoftHdConfig object
 
cVideoRenderm_pRender
 pointer to cVideoRender object
 
cVideoStreamm_pVideoStream
 pointer to main video stream
 
cSoftHdAudiom_pAudio
 pointer to cSoftHdAudio object
 
cAudioDecoderm_pAudioDecoder = nullptr
 pointer to cAudioDecoder object
 
cSoftOsdProviderm_pOsdProvider = nullptr
 pointer to cSoftOsdProvider object
 
cHardwareDevicem_pHardwareDevice
 pointer to hardware device description
 
cReassemblyBufferVideo m_videoReassemblyBuffer
 video pes reassembly buffer
 
cReassemblyBufferAudio m_audioReassemblyBuffer
 audio pes reassembly buffer
 
cJitterTracker m_audioJitterTracker {"audio"}
 audio jitter tracker
 
cJitterTracker m_videoJitterTracker {"video"}
 video jitter tracker
 
std::chrono::steady_clock::time_point m_channelSwitchStartTime
 timestamp, when VDR triggered a channel switch
 
std::chrono::steady_clock::time_point m_dataReceivedTime
 timestamp, when the first audio or video data after a channel switch arrives in Play*()
 
std::atomic< PlaybackModem_playbackMode = NONE
 current playback mode
 
int m_audioChannelID = -1
 current audio channel ID
 
cSoftHdGrabm_pGrab
 pointer to grabber object
 
cVideoStreamm_pPipStream
 pointer to pip video stream
 
cReassemblyBufferVideo m_pipReassemblyBuffer
 pip pes reassembly buffer
 
cPipHandlerm_pPipHandler = nullptr
 pointer to pip handler
 
std::mutex m_mutex
 mutex to lock the state machine
 
std::mutex m_sizeMutex
 mutex to lock screen size (which is accessed by different threads)
 
std::atomic< boolm_receivedAudio = false
 flag if audio packets have been received
 
std::atomic< boolm_receivedVideo = false
 flag if video packets have been received
 
bool m_pipUseAlt
 use alternative pip position
 
bool m_drmCanDisplayPip = true
 true, if the drm device is able to display a pip video
 
bool m_disablePip = false
 true, if pip was disabled by the user
 
int m_volume = 0
 track the volume in the device (for attach)
 
int m_screenWidth
 
int m_screenHeight
 
double m_screenRefreshRateHz
 
bool m_forceDetached = false
 start the plugin in detached state
 

Static Private Attributes

static constexpr int MIN_BUFFER_FILL_LEVEL_THRESHOLD_MS = 450
 min buffering threshold in ms
 

Detailed Description

Output Device Implementation.

Definition at line 116 of file softhddevice.h.

Constructor & Destructor Documentation

◆ cSoftHdDevice()

cSoftHdDevice::cSoftHdDevice ( cSoftHdConfig config)

Create the device.

Initializes some member variables

Parameters
configpointer to cSoftHdConfig class

Definition at line 53 of file softhddevice.cpp.

References m_channelSwitchStartTime, and m_dataReceivedTime.

◆ ~cSoftHdDevice()

cSoftHdDevice::~cSoftHdDevice ( void  )
virtual

Destroy the device.

Only deletes spu decoder, which was created in constructor

Definition at line 69 of file softhddevice.cpp.

References LOGDEBUG, m_pHardwareDevice, and m_pSpuDecoder.

Member Function Documentation

◆ Attach()

void cSoftHdDevice::Attach ( void  )

Attach the device again.

Kind of a plugin restart. Inits and starts all necessary resources. Only valid after a detach.

Definition at line 1790 of file softhddevice.cpp.

References m_forceDetached, m_needsMakePrimary, MakePrimaryDevice(), and OnEventReceived().

Referenced by cSoftHdMenu::HandleHotKey(), and cPluginSoftHdDevice::SVDRPCommand().

◆ Audio()

cSoftHdAudio * cSoftHdDevice::Audio ( void  )
inline

Definition at line 184 of file softhddevice.h.

References m_pAudio.

◆ CanReplay()

bool cSoftHdDevice::CanReplay ( void  ) const
virtual

Return true if this device can currently start a replay session.

Definition at line 181 of file softhddevice.cpp.

References IsDetached(), and LOGDEBUG.

◆ CanScaleVideo()

cRect cSoftHdDevice::CanScaleVideo ( const cRect ,
int  taCenter 
)
virtual

Ask the output, if it can scale video.

Parameters
rectrequested video window rectangle
Returns
the real rectangle or cRect::NULL if invalid

Definition at line 1428 of file softhddevice.cpp.

◆ ChannelSwitch()

void cSoftHdDevice::ChannelSwitch ( const cDevice *  device,
int  channelNum,
bool  liveView 
)
protectedvirtual

Monitor a channel switch triggered by VDR (cStatus::ChannelSwitch())

Save the timestamp when a channel switch is initiated (channelNum == 0) for later time measurement.

Definition at line 139 of file softhddevice.cpp.

References m_channelSwitchStartTime.

◆ Clear()

◆ CommandLineHelp()

const char * cSoftHdDevice::CommandLineHelp ( void  )

Return command line help string.

Definition at line 1456 of file softhddevice.cpp.

Referenced by cPluginSoftHdDevice::CommandLineHelp().

◆ Config()

cSoftHdConfig * cSoftHdDevice::Config ( void  )
inline

Definition at line 181 of file softhddevice.h.

References m_pConfig.

◆ Detach()

void cSoftHdDevice::Detach ( void  )

Detach the device.

Clears audio and video, stops all threads and releases drm/alsa. A detached state can only be exited (restarted) with an AttachEvent.

Definition at line 1769 of file softhddevice.cpp.

References LOGDEBUG, m_needsMakePrimary, MakePrimaryDevice(), and OnEventReceived().

Referenced by cSoftHdMenu::HandleHotKey(), cSoftHdMenu::ProcessKey(), and cPluginSoftHdDevice::SVDRPCommand().

◆ DeviceName()

virtual cString cSoftHdDevice::DeviceName ( void  ) const
inlinevirtual

Definition at line 129 of file softhddevice.h.

◆ Flush()

bool cSoftHdDevice::Flush ( int  timeoutMs = 0)
virtual

Flush the device output buffers.

Parameters
timeoutMstimeout in ms to become ready

Definition at line 894 of file softhddevice.cpp.

References cVideoStream::GetAvPacketsFilled(), IsDetached(), LOGDEBUG, and m_pVideoStream.

◆ FlushAudio()

void cSoftHdDevice::FlushAudio ( void  )
private

Clear all audio data from the decoder and ringbuffer.

Definition at line 110 of file softhddevice.cpp.

References cSoftHdAudio::FlushBuffers(), cAudioDecoder::FlushBuffers(), LOGDEBUG, m_audioReassemblyBuffer, m_pAudio, m_pAudioDecoder, and cReassemblyBuffer::Reset().

Referenced by Clear(), and OnEnteringState().

◆ Freeze()

void cSoftHdDevice::Freeze ( void  )
virtual

Puts the device into "freeze frame" mode.

Definition at line 803 of file softhddevice.cpp.

References LOGDEBUG, and OnEventReceived().

Referenced by cSoftHdControl::ProcessKey().

◆ GetAudioChannelDevice()

int cSoftHdDevice::GetAudioChannelDevice ( void  )
virtual

Definition at line 1140 of file softhddevice.cpp.

◆ GetBufferFillLevelThresholdMs()

int cSoftHdDevice::GetBufferFillLevelThresholdMs ( )
private

Returns the buffer fill level threshold in milliseconds.

Combines the minimum threshold with the user-configured additional buffer length.

Definition at line 1281 of file softhddevice.cpp.

References cSoftHdConfig::ConfigAdditionalBufferLengthMs, m_pConfig, and MIN_BUFFER_FILL_LEVEL_THRESHOLD_MS.

Referenced by IsBufferingThresholdReached().

◆ GetChannelSwitchFirstPacketTime()

std::chrono::steady_clock::time_point cSoftHdDevice::GetChannelSwitchFirstPacketTime ( void  )
inline

Definition at line 212 of file softhddevice.h.

References m_dataReceivedTime.

Referenced by cVideoRender::DisplayFrame().

◆ GetChannelSwitchStartTime()

std::chrono::steady_clock::time_point cSoftHdDevice::GetChannelSwitchStartTime ( void  )
inline

Definition at line 211 of file softhddevice.h.

References m_channelSwitchStartTime.

Referenced by cVideoRender::DisplayFrame().

◆ GetFirstAudioPtsMsToPlay()

int64_t cSoftHdDevice::GetFirstAudioPtsMsToPlay ( )
private

Calculate the first audio PTS that should be played during synchronized playback.

This method determines the starting audio presentation timestamp when transitioning from BUFFERING to PLAY state. It synchronizes audio with video by taking the maximum of both output PTSes, then adjusts for user-configured audio/video delay.

Returns
the first audio PTS in milliseconds that should be played
Note
Positive ConfigVideoAudioDelayMs means audio is intentionally delayed (video ahead)
Negative ConfigVideoAudioDelayMs means video is intentionally delayed (audio ahead)

Definition at line 1364 of file softhddevice.cpp.

References cSoftHdConfig::ConfigVideoAudioDelayMs, cSoftHdAudio::GetOutputPtsMs(), cVideoRender::GetOutputPtsMs(), m_pAudio, m_pConfig, and m_pRender.

Referenced by IsBufferingThresholdReached(), and OnEventReceived().

◆ GetFirstVideoPtsMsToPlay()

◆ GetMinBufferFillLevelThresholdMs()

int cSoftHdDevice::GetMinBufferFillLevelThresholdMs ( void  )
inline

Definition at line 205 of file softhddevice.h.

References MIN_BUFFER_FILL_LEVEL_THRESHOLD_MS.

Referenced by cMenuSetupSoft::Create().

◆ GetOsdSize()

void cSoftHdDevice::GetOsdSize ( int width,
int height,
double aspectRatio 
)
virtual

Returns the width, height and aspect ratio the OSD.

Parameters
[out]widthosd width
[out]heightosd height
[out]aspectRatioosd aspect ratio
Todo:
: Called every second, for nothing (no OSD displayed)?

Definition at line 976 of file softhddevice.cpp.

References IsDetached(), m_screenHeight, m_screenWidth, and m_sizeMutex.

Referenced by cOglOsd::cOglOsd(), cSoftOsd::Flush(), and GrabImage().

◆ GetSpuDecoder()

cSpuDecoder * cSoftHdDevice::GetSpuDecoder ( void  )
virtual

Get the device SPU decoder.

Returns
a pointer to the device's SPU decoder (or NULL, if this device doesn't have an SPU decoder)

Definition at line 157 of file softhddevice.cpp.

References LOGDEBUG, and m_pSpuDecoder.

◆ GetStats()

void cSoftHdDevice::GetStats ( int duped,
int dropped,
int counter 
)

Get statistics from the renderer.

Parameters
[out]dupedduped frames
[out]droppeddropped frames
[out]countnumber of total rendered frames

Definition at line 1682 of file softhddevice.cpp.

References cVideoRender::GetStats(), and m_pRender.

Referenced by cMenuSetupSoft::Create().

◆ GetSTC()

int64_t cSoftHdDevice::GetSTC ( void  )
virtual

Gets the current System Time Counter, which can be used to synchronize audio, video and subtitles.

Definition at line 653 of file softhddevice.cpp.

References AUDIO_AND_VIDEO, AUDIO_ONLY, AV_NOPTS_VALUE, cSoftHdAudio::GetHardwareOutputPtsTimebaseUnits(), cVideoRender::GetVideoClock(), IsDetached(), m_pAudio, m_playbackMode, m_pRender, NONE, and VIDEO_ONLY.

◆ GetVideoAudioDelayMs()

int cSoftHdDevice::GetVideoAudioDelayMs ( void  )
inline

◆ GetVideoSize()

void cSoftHdDevice::GetVideoSize ( int width,
int height,
double aspectRatio 
)
virtual

Get the video size.

Return the width, height and aspect ratio of the currently displayed video material

Parameters
[out]widthvideo width
[out]heightvideo height
[out]aspectRatiovideo aspect ratio
Note
the video_aspect is used to scale the subtitle.

Definition at line 953 of file softhddevice.cpp.

References cVideoStream::GetVideoSize(), IsDetached(), and m_pVideoStream.

◆ GrabImage()

uchar * cSoftHdDevice::GrabImage ( int size,
bool  jpeg,
int  quality,
int  width,
int  height 
)
virtual

Grabs the currently visible screen image.

Parameters
sizesize of the returned data
jpegflag true, create JPEG data
qualityJPEG quality
widthnumber of horizontal pixels in the frame
heightnumber of vertical pixels in the frame

Definition at line 1396 of file softhddevice.cpp.

References cSoftHdGrab::Active(), GetOsdSize(), cSoftHdGrab::Image(), IsDetached(), L_GRAB, LOGDEBUG2, LOGWARNING, m_pGrab, cSoftHdGrab::Size(), and cSoftHdGrab::Start().

◆ HandleStillPicture()

void cSoftHdDevice::HandleStillPicture ( const uchar data,
int  size 
)
private

The still picture data received from VDR can contain multiple PES packets.

This sends each PES packet's raw data separately to PlayVideo(), and does a flush to display the frame immediately.

Parameters
datapes data of one or more frames
sizelength of data area

Definition at line 836 of file softhddevice.cpp.

References cVideoStream::Flush(), LOGWARNING, m_pRender, m_pVideoStream, m_videoReassemblyBuffer, PlayVideoInternal(), cReassemblyBufferVideo::PopAvPacket(), cVideoStream::PushAvPacket(), cVideoStream::ResetInputPts(), cVideoStream::SetDeinterlacerDeactivated(), cVideoRender::SetPlaybackPaused(), and cVideoRender::SetStillpicture().

Referenced by OnEventReceived().

◆ HasDecoder()

bool cSoftHdDevice::HasDecoder ( void  ) const
virtual

Tells whether this device has an MPEG decoder.

Definition at line 169 of file softhddevice.cpp.

References IsDetached().

◆ Initialize()

bool cSoftHdDevice::Initialize ( void  )

Initialize the device.

Definition at line 79 of file softhddevice.cpp.

References LOGDEBUG, and m_pHardwareDevice.

Referenced by cPluginSoftHdDevice::Initialize().

◆ IsBufferingThresholdReached()

bool cSoftHdDevice::IsBufferingThresholdReached ( void  )

Check if the buffering threshold has been reached.

During the BUFFERING state, this method determines when sufficient audio/video data has been buffered to start playback.

ThresholdReached (Sync-Ability) is signalled 1) in audio only mode: -> PlayAudio() was called -> audio input has a valid pts -> enough audio data is buffered 2) in video only mode: -> PlayVideo() was called -> video input has a valid pts -> enough video data is buffered (which implies "a video frame reached the renderer") 3) in audio/video mode: -> audio input has a valid pts -> video input has a valid pts -> video and audio has enough data buffered (calculated from the first output pts to play) -> the render output buffer queue is completely filled once (which implies "a video frame reached the renderer")

Return values
trueif playback should start (audio or video only or buffering threshold reached)
falseif playback should not start
Note
In order to signal ThresholdReached, both (audio and video) need to have a valid pts in audio + video mode!

Definition at line 1311 of file softhddevice.cpp.

References AV_NOPTS_VALUE, BUFFERING, GetBufferFillLevelThresholdMs(), GetFirstAudioPtsMsToPlay(), GetFirstVideoPtsMsToPlay(), cSoftHdAudio::GetInputPtsMs(), cVideoStream::GetInputPtsMs(), cSoftHdAudio::GetOutputPtsMs(), cVideoRender::GetOutputPtsMs(), cSoftHdAudio::HasInputPts(), cVideoStream::HasInputPts(), cVideoRender::IsOutputBufferFull(), L_AV_SYNC, LOGDEBUG, LOGDEBUG2, m_pAudio, m_pRender, m_pVideoStream, m_receivedAudio, m_receivedVideo, m_state, and Timestamp2String().

Referenced by cVideoRender::DisplayFrame(), and PlayAudio().

◆ IsDetached()

bool cSoftHdDevice::IsDetached ( void  ) const

◆ IsOsdProviderSet()

bool cSoftHdDevice::IsOsdProviderSet ( void  ) const
inline

Definition at line 225 of file softhddevice.h.

References m_pOsdProvider.

Referenced by cSoftOsdProvider::~cSoftOsdProvider().

◆ IsVideoOnlyPlayback()

bool cSoftHdDevice::IsVideoOnlyPlayback ( void  )
inline

Definition at line 228 of file softhddevice.h.

References m_playbackMode, and VIDEO_ONLY.

Referenced by cVideoRender::DisplayFrame().

◆ MakePrimaryDevice()

void cSoftHdDevice::MakePrimaryDevice ( bool  on)
protectedvirtual

Informs a device that it will be the primary device.

Parameters
onflag if becoming or loosing primary

Definition at line 123 of file softhddevice.cpp.

References LOGDEBUG, and m_pOsdProvider.

Referenced by Attach(), and Detach().

◆ MaxSizeGPUImageCache()

int cSoftHdDevice::MaxSizeGPUImageCache ( void  )

Get the maximum GPU image cache size.

Definition at line 1579 of file softhddevice.cpp.

References cSoftHdConfig::ConfigMaxSizeGPUImageCache, and m_pConfig.

Referenced by cSoftOsdProvider::StartOpenGlThread().

◆ OglOsdIsDisabled()

int cSoftHdDevice::OglOsdIsDisabled ( void  )

◆ OnEnteringState()

◆ OnEventReceived()

void cSoftHdDevice::OnEventReceived ( const Event event)
privatevirtual

Event handler for playback state transitions.

Processes events (Play, Pause, Stop, TrickSpeed, StillPicture) and performs the appropriate state transitions based on the current state. The method halts both display and decoding threads before processing the event and resumes them afterwards to ensure thread-safe state transitions.

Parameters
eventThe event to process (variant type containing specific event data)

Implements IEventReceiver.

Definition at line 200 of file softhddevice.cpp.

References AUDIO_AND_VIDEO, AUDIO_ONLY, BUFFERING, cSoftHdConfig::ConfigVideoAudioDelayMs, DETACHED, cSoftHdAudio::DropSamplesOlderThanPtsMs(), EventToString(), GetFirstAudioPtsMsToPlay(), GetFirstVideoPtsMsToPlay(), cSoftHdAudio::GetOutputPtsMs(), cVideoRender::GetOutputPtsMs(), cVideoRender::Halt(), cVideoStream::Halt(), cPipHandler::HandleEvent(), HandleStillPicture(), cSoftHdAudio::HasInputPts(), cVideoStream::HasInputPts(), cSoftHdAudio::LazyInit(), cSoftOsdProvider::LockOpenGlThread(), LOGDEBUG, LOGFATAL, LOGWARNING, m_forceDetached, m_mutex, m_pAudio, m_pConfig, m_playbackMode, m_pOsdProvider, m_pPipHandler, m_pRender, m_pVideoStream, m_state, m_volume, NONE, PIPSTOP, PLAY, cVideoStream::ResetFilterThreadNeededCheck(), cVideoRender::ResetFrameCounter(), cSoftHdAudio::ResetHwDelayBaseline(), cVideoRender::Resume(), cVideoStream::Resume(), cVideoRender::SchedulePlaybackStartAtPtsMs(), cVideoRender::ScheduleResyncAtPtsMs(), cVideoRender::ScheduleVideoPlaybackPauseAt(), cSoftHdAudio::SetHwDelayBaseline(), cSoftHdAudio::SetPaused(), cVideoRender::SetPlaybackPaused(), cVideoRender::SetScheduleAudioResume(), SetState(), cVideoRender::SetStillpicture(), cVideoRender::SetTrickSpeed(), cSoftHdAudio::SetVolume(), StateToString(), STOP, TRICK_SPEED, cSoftOsdProvider::UnlockOpenGlThread(), and VIDEO_ONLY.

Referenced by Attach(), Detach(), Freeze(), Play(), PlayAudio(), SetPlayMode(), Start(), StillPicture(), Stop(), and TrickSpeed().

◆ OnLeavingState()

◆ OsdClose()

void cSoftHdDevice::OsdClose ( void  )

◆ OsdDrawARGB()

void cSoftHdDevice::OsdDrawARGB ( int  xi,
int  yi,
int  height,
int  width,
int  pitch,
const uint8_t argb,
int  x,
int  y 
)

Draw an OSD pixmap.

Parameters
xix-coordinate in argb image
yiy-coordinate in argb image
heightheight in pixel in argb image
widthwidth in pixel in argb image
pitchpitch of argb image
argb32bit ARGB image data
xx-coordinate on screen of argb image
yy-coordinate on screen of argb image

Definition at line 1566 of file softhddevice.cpp.

References IsDetached(), m_pRender, and cVideoRender::OsdDrawARGB().

Referenced by cOglCmdCopyBufferToOutputFb::Execute(), and cSoftOsd::Flush().

◆ PipChannelChange()

void cSoftHdDevice::PipChannelChange ( int  dir)

◆ PipChannelSwap()

void cSoftHdDevice::PipChannelSwap ( bool  closePip)

◆ PipDisable()

void cSoftHdDevice::PipDisable ( void  )

Definition at line 1848 of file softhddevice.cpp.

References cPipHandler::Disable(), and m_pPipHandler.

Referenced by cPluginSoftHdDevice::SVDRPCommand().

◆ PipEnable()

void cSoftHdDevice::PipEnable ( void  )

Definition at line 1847 of file softhddevice.cpp.

References cPipHandler::Enable(), and m_pPipHandler.

Referenced by cPluginSoftHdDevice::SVDRPCommand().

◆ PipIsEnabled()

bool cSoftHdDevice::PipIsEnabled ( void  )

Returns true, if pip is currently enabled.

Definition at line 1836 of file softhddevice.cpp.

References cPipHandler::IsEnabled(), m_mutex, and m_pPipHandler.

Referenced by cPluginSoftHdDevice::SVDRPCommand().

◆ PipSetSize()

void cSoftHdDevice::PipSetSize ( void  )

Definition at line 1853 of file softhddevice.cpp.

References m_pPipHandler, and cPipHandler::SetSize().

Referenced by cMenuSetupSoft::Store().

◆ PipSwapPosition()

void cSoftHdDevice::PipSwapPosition ( void  )

◆ PipToggle()

void cSoftHdDevice::PipToggle ( void  )

Definition at line 1849 of file softhddevice.cpp.

References m_pPipHandler, and cPipHandler::Toggle().

Referenced by cSoftHdMenu::HandleHotKey(), and cSoftHdMenu::ProcessKey().

◆ Play()

void cSoftHdDevice::Play ( void  )
virtual

Sets the device into play mode (after a previous trick mode, or pause)

This is called by VDR via DevicePlay() in the Play() and Goto() call

Definition at line 793 of file softhddevice.cpp.

References OnEventReceived().

Referenced by cSoftHdControl::ProcessKey().

◆ PlayAudio()

◆ PlayAudioPkts()

int cSoftHdDevice::PlayAudioPkts ( AVPacket pkt)

Play an audio packet.

Parameters
pktAVPacket to play
Return values
0packet could not be player, free audio buffer too small
1packet was sent to be decoded

Definition at line 1728 of file softhddevice.cpp.

References cAudioDecoder::Decode(), cSoftHdAudio::IsBufferFull(), cSoftHdAudio::LazyInit(), m_pAudio, and m_pAudioDecoder.

Referenced by cSoftHdPlayer::Play().

◆ PlayPipVideo()

int cSoftHdDevice::PlayPipVideo ( const uchar data,
int  size 
)

Play a video packet of the pip videostream.

Parameters
dataA complete PES packet with optionally fragmented payload
sizethe length of the PES packet including header

The caller must ensure, that PlayPipVideo() is not called in detached state. (CanReplay() and HasDecoder() return false in this state and we are not the primary device.)

Definition at line 1205 of file softhddevice.cpp.

References cVideoStream::IsInputBufferFull(), m_pipReassemblyBuffer, m_pPipStream, and PlayVideoInternal().

Referenced by cPipReceiver::PlayTs().

◆ PlayVideo()

int cSoftHdDevice::PlayVideo ( const uchar data,
int  size 
)
virtual

Play a video packet of the main videostream.

This is the main function, which is called by VDR to play video data

Parameters
dataA complete PES packet with optionally fragmented payload
sizethe length of the PES packet including header

This is called directly from VDR

The caller must ensure, that PlayVideo() is not called in detached state. (CanReplay() and HasDecoder() return false in this state and we are not the primary device.)

Definition at line 1175 of file softhddevice.cpp.

References IsDetached(), LOGDEBUG, m_channelSwitchStartTime, m_dataReceivedTime, m_pVideoStream, m_receivedAudio, m_receivedVideo, m_videoReassemblyBuffer, and PlayVideoInternal().

◆ PlayVideoInternal()

int cSoftHdDevice::PlayVideoInternal ( cVideoStream stream,
cReassemblyBufferVideo buffer,
const uchar data,
int  size,
bool  trackJitter 
)
private

Play a video packet.

Parameters
streamvideo stream to play to
bufferreassembly buffer for this stream
dataA complete PES packet with optionally fragmented payload
sizethe length of the PES packet including header
trackJitterwhether to track jitter for this packet

Definition at line 1228 of file softhddevice.cpp.

References cReassemblyBuffer::GetCodec(), cJitterTracker::GetLongTermMaxJitterMs(), cJitterTracker::GetShortTermMaxJitterMs(), cReassemblyBufferVideo::HasLeadingZero(), cReassemblyBuffer::IsEmpty(), m_pConfig, m_videoJitterTracker, cJitterTracker::PacketReceived(), cReassemblyBufferVideo::ParseCodecHeader(), cReassemblyBufferVideo::PopAvPacket(), PrintStreamData(), cReassemblyBuffer::Push(), cReassemblyBuffer::Reset(), cSoftHdConfig::StatMaxLongTermVideoJitterMs, and cSoftHdConfig::StatMaxShortTermVideoJitterMs.

Referenced by HandleStillPicture(), PlayPipVideo(), and PlayVideo().

◆ PlayVideoPkts()

int cSoftHdDevice::PlayVideoPkts ( AVPacket pkt)

Play a video packet.

Parameters
pktAVPacket to play
Return values
0packet could not be player, free audio buffer too small
1packet was sent to be decoded

Definition at line 1747 of file softhddevice.cpp.

References cVideoStream::GetAvPacketsFilled(), cVideoStream::GetVideoPacketMax(), cSoftHdAudio::LazyInit(), m_pAudio, m_pVideoStream, and cVideoStream::PushAvPacket().

Referenced by cSoftHdPlayer::Play().

◆ Poll()

bool cSoftHdDevice::Poll ( cPoller ,
int  = 0 
)
virtual

Return true if the device itself or any of the file handles in poller is ready for further action.

If TimeoutMs is not zero, the device will wait up to the given number of milliseconds before returning in case it can't accept any data.

Parameters
pollerfile handles (unused)
timeoutMstimeout in ms to become ready
Return values
trueif ready
falseif busy

Definition at line 875 of file softhddevice.cpp.

References cSoftHdAudio::IsBufferFull(), IsDetached(), cVideoStream::IsInputBufferFull(), m_pAudio, and m_pVideoStream.

◆ ProcessArgs()

int cSoftHdDevice::ProcessArgs ( int  argc,
char argv[] 
)

◆ Render()

cVideoRender * cSoftHdDevice::Render ( void  )
inline

Definition at line 183 of file softhddevice.h.

References m_pRender.

◆ ResetChannelId()

void cSoftHdDevice::ResetChannelId ( void  )

Reset the channel ID (restarts audio)

Definition at line 1669 of file softhddevice.cpp.

References LOGDEBUG, and m_audioChannelID.

Referenced by cMenuSetupSoft::Store().

◆ ResetOsdProvider()

void cSoftHdDevice::ResetOsdProvider ( void  )
inline

Definition at line 224 of file softhddevice.h.

References m_pOsdProvider.

Referenced by cSoftOsdProvider::~cSoftOsdProvider().

◆ ResetPipStream()

◆ ScaleVideo()

void cSoftHdDevice::ScaleVideo ( const cRect rect = cRect::Null)
virtual

Scale the currently shown video.

Parameters
xvideo window x coordinate OSD relative
yvideo window x coordinate OSD relative
widthvideo window width OSD relative
heightvideo window height OSD relative

Definition at line 1441 of file softhddevice.cpp.

References IsDetached(), L_OSD, LOGDEBUG2, m_pRender, and cVideoRender::SetVideoOutputPosition().

◆ SetAudioChannelDevice()

void cSoftHdDevice::SetAudioChannelDevice ( int  )
virtual

Definition at line 1134 of file softhddevice.cpp.

◆ SetAudioCodec()

void cSoftHdDevice::SetAudioCodec ( enum AVCodecID  codecId,
AVCodecParameters par,
AVRational  timebase 
)

Open an audio codec.

Parameters
codecIdaudio codec id
paraudio codec parameters
timebasetimebase

Definition at line 1703 of file softhddevice.cpp.

References m_pAudioDecoder, and cAudioDecoder::Open().

Referenced by cSoftHdPlayer::Play().

◆ SetAudioTrackDevice()

void cSoftHdDevice::SetAudioTrackDevice ( eTrackType  )
virtual

Definition at line 1124 of file softhddevice.cpp.

◆ SetDecoderFallbackToSw()

void cSoftHdDevice::SetDecoderFallbackToSw ( bool  enable)

Force the decoder to fallback to software if the hardware decoder fails after the configured amount of packets were sent and no frame was received.

Definition at line 1645 of file softhddevice.cpp.

References cSoftHdConfig::ConfigDecoderFallbackToSwNumPkts, m_pConfig, m_pVideoStream, and cVideoStream::SetDecoderFallbackToSwNumPkts().

Referenced by cMenuSetupSoft::Store().

◆ SetDecoderNeedsIFrame()

void cSoftHdDevice::SetDecoderNeedsIFrame ( void  )

Forces the h264 decoder to wait for an I-Frame to start.

Definition at line 1626 of file softhddevice.cpp.

References cSoftHdConfig::ConfigDecoderNeedsIFrame, m_pConfig, m_pVideoStream, and cVideoStream::SetStartDecodingWithIFrame().

Referenced by cMenuSetupSoft::Store().

◆ SetDigitalAudioDevice()

void cSoftHdDevice::SetDigitalAudioDevice ( bool  )
virtual

Definition at line 1129 of file softhddevice.cpp.

◆ SetDisableDeint()

void cSoftHdDevice::SetDisableDeint ( void  )

Disables deinterlacer (called from setup menu or conf)

Definition at line 1617 of file softhddevice.cpp.

References cSoftHdConfig::ConfigDisableDeint, cVideoStream::DisableDeint(), m_pConfig, and m_pVideoStream.

Referenced by cMenuSetupSoft::Store().

◆ SetDisableOglOsd()

void cSoftHdDevice::SetDisableOglOsd ( void  )

Disables OpenGL/ES Osd (called from setup menu or conf)

Definition at line 1595 of file softhddevice.cpp.

References cSoftHdConfig::ConfigDisableOglOsd, cVideoRender::DisableOglOsd(), m_pConfig, and m_pRender.

Referenced by cSoftOsdProvider::CreateOsd(), and ProcessArgs().

◆ SetDrmCanDisplayPip()

void cSoftHdDevice::SetDrmCanDisplayPip ( bool  canDisplay)
inline

Definition at line 244 of file softhddevice.h.

References m_drmCanDisplayPip.

Referenced by cVideoRender::Init().

◆ SetEnableHdr()

void cSoftHdDevice::SetEnableHdr ( bool  enable)

Enable HDR display mode.

Definition at line 1856 of file softhddevice.cpp.

References m_pRender, and cVideoRender::SetEnableHdr().

Referenced by cMenuSetupSoft::Store().

◆ SetEnableOglOsd()

void cSoftHdDevice::SetEnableOglOsd ( void  )

Enables OpenGL/ES Osd.

Definition at line 1605 of file softhddevice.cpp.

References cSoftHdConfig::ConfigDisableOglOsd, cVideoRender::EnableOglOsd(), m_pConfig, and m_pRender.

◆ SetParseH264Dimensions()

void cSoftHdDevice::SetParseH264Dimensions ( void  )

Parse the h264 stream width and height before starting the decoder.

Definition at line 1635 of file softhddevice.cpp.

References cSoftHdConfig::ConfigParseH264Dimensions, m_pConfig, m_pVideoStream, and cVideoStream::SetParseH264Dimensions().

Referenced by cMenuSetupSoft::Store().

◆ SetPassthroughMask()

void cSoftHdDevice::SetPassthroughMask ( int  mask)

Set the passthrough mask (called from setup menu or conf)

Definition at line 1659 of file softhddevice.cpp.

References m_pAudio, m_pAudioDecoder, cSoftHdAudio::SetPassthroughMask(), and cAudioDecoder::SetPassthroughMask().

Referenced by cMenuSetupSoft::Store().

◆ SetPlayMode()

bool cSoftHdDevice::SetPlayMode ( ePlayMode  play_mode)
virtual

Sets the device into the given play mode.

Parameters
play_modenew play mode (Audio/Video/External...)

Definition at line 626 of file softhddevice.cpp.

References LOGDEBUG, LOGERROR, and OnEventReceived().

◆ SetRenderPipActive()

void cSoftHdDevice::SetRenderPipActive ( bool  active)

Definition at line 1846 of file softhddevice.cpp.

References m_pRender, and cVideoRender::SetPipActive().

Referenced by cPipHandler::HandleEnable().

◆ SetRenderPipSize()

void cSoftHdDevice::SetRenderPipSize ( void  )

Wrapper functions for cVideoRender and cPipHandler.

Definition at line 1845 of file softhddevice.cpp.

References m_pipUseAlt, m_pRender, and cVideoRender::SetPipSize().

Referenced by cPipHandler::HandleEvent().

◆ SetScreenSize()

void cSoftHdDevice::SetScreenSize ( int  width,
int  height,
double  refreshRateHz 
)

Set the screen size.

Parameters
widthscreen width
heightscreen height
refreshRateHzscreen refresh rate in Hz

Definition at line 998 of file softhddevice.cpp.

References m_screenHeight, m_screenRefreshRateHz, m_screenWidth, and m_sizeMutex.

Referenced by cVideoRender::SetScreenSize().

◆ SetState()

void cSoftHdDevice::SetState ( State  newState)
private

Sets the device into the given state.

Parameters
newStatenew state

Definition at line 609 of file softhddevice.cpp.

References LOGDEBUG, m_state, OnEnteringState(), OnLeavingState(), and StateToString().

Referenced by Clear(), and OnEventReceived().

◆ SetVideoCodec()

void cSoftHdDevice::SetVideoCodec ( enum AVCodecID  codecId,
AVCodecParameters par,
AVRational  timebase 
)

Open a video codec.

Parameters
codecIdvideo codec id
parvideo codec parameters
timebasetimebase

Definition at line 1715 of file softhddevice.cpp.

References m_pVideoStream, and cVideoStream::Open().

Referenced by cSoftHdPlayer::Play().

◆ SetVideoDisplayFormat()

void cSoftHdDevice::SetVideoDisplayFormat ( eVideoDisplayFormat  videoDisplayFormat)
virtual

Sets the video display format.

Parameters
videoDisplayFormatvideo display format Set it to the given one (only useful if this device has an MPEG decoder).

Definition at line 916 of file softhddevice.cpp.

References LOGDEBUG.

Referenced by SetVideoFormat().

◆ SetVideoFormat()

void cSoftHdDevice::SetVideoFormat ( bool  videoFormat16_9)
virtual

Set the video format.

Sets the output video format to either 16:9 or 4:3 (only useful if this device has an MPEG decoder).

Should call SetVideoDisplayFormat

Parameters
videoFormat16_9flag true 16:9.

Definition at line 933 of file softhddevice.cpp.

References LOGDEBUG, and SetVideoDisplayFormat().

◆ SetVolumeDevice()

void cSoftHdDevice::SetVolumeDevice ( int  volume)
virtual

Sets the audio volume on this device (Volume = 0...255).

Parameters
volumedevice volume

Definition at line 1151 of file softhddevice.cpp.

References IsDetached(), LOGDEBUG, m_pAudio, m_volume, and cSoftHdAudio::SetVolume().

◆ Start()

int cSoftHdDevice::Start ( void  )

Called by VDR when the plugin is started.

Definition at line 90 of file softhddevice.cpp.

References LOGDEBUG, and OnEventReceived().

Referenced by cPluginSoftHdDevice::Start().

◆ StillPicture()

void cSoftHdDevice::StillPicture ( const uchar data,
int  size 
)
virtual

Display the given I-frame as a still picture.

Parameters
datapes or ts data of a frame
lengthlength of data area

Definition at line 817 of file softhddevice.cpp.

References LOGDEBUG, and OnEventReceived().

◆ Stop()

void cSoftHdDevice::Stop ( void  )

Called by VDR when the plugin is stopped.

Definition at line 101 of file softhddevice.cpp.

References LOGDEBUG, and OnEventReceived().

Referenced by cPluginSoftHdDevice::Stop().

◆ ToggleRenderPipPosition()

void cSoftHdDevice::ToggleRenderPipPosition ( void  )
inline

Definition at line 247 of file softhddevice.h.

References m_pipUseAlt.

Referenced by cPipHandler::HandleEvent().

◆ TrickSpeed()

void cSoftHdDevice::TrickSpeed ( int  speed,
bool  forward 
)
virtual

Sets the device into a mode where replay is done slower.

Every single frame shall then be displayed the given number of times. Forward is true if replay is done in the normal (forward) direction, false if it is done reverse. The cDvbPlayer uses the following values for the various speeds: 1x 2x 3x Fast Forward 6 3 1 Fast Reverse 6 3 1 Slow Forward 8 4 2 Slow Reverse 63 48 24

Definition at line 683 of file softhddevice.cpp.

References LOGDEBUG, and OnEventReceived().

◆ UsePip()

◆ VideoStream()

cVideoStream * cSoftHdDevice::VideoStream ( void  )
inline

Definition at line 182 of file softhddevice.h.

References m_pVideoStream.

Referenced by cVideoRender::DisplayFrame(), and cVideoRender::LogDroppedDuped().

Member Data Documentation

◆ m_audioChannelID

int cSoftHdDevice::m_audioChannelID = -1
private

current audio channel ID

Definition at line 271 of file softhddevice.h.

Referenced by PlayAudio(), and ResetChannelId().

◆ m_audioJitterTracker

cJitterTracker cSoftHdDevice::m_audioJitterTracker {"audio"}
private

audio jitter tracker

Definition at line 265 of file softhddevice.h.

Referenced by OnEnteringState(), and PlayAudio().

◆ m_audioReassemblyBuffer

cReassemblyBufferAudio cSoftHdDevice::m_audioReassemblyBuffer
private

audio pes reassembly buffer

Definition at line 264 of file softhddevice.h.

Referenced by FlushAudio(), and PlayAudio().

◆ m_channelSwitchStartTime

std::chrono::steady_clock::time_point cSoftHdDevice::m_channelSwitchStartTime
private

timestamp, when VDR triggered a channel switch

Definition at line 267 of file softhddevice.h.

Referenced by ChannelSwitch(), cSoftHdDevice(), GetChannelSwitchStartTime(), PlayAudio(), and PlayVideo().

◆ m_dataReceivedTime

std::chrono::steady_clock::time_point cSoftHdDevice::m_dataReceivedTime
private

timestamp, when the first audio or video data after a channel switch arrives in Play*()

Definition at line 268 of file softhddevice.h.

Referenced by cSoftHdDevice(), GetChannelSwitchFirstPacketTime(), PlayAudio(), and PlayVideo().

◆ m_disablePip

bool cSoftHdDevice::m_disablePip = false
private

true, if pip was disabled by the user

Definition at line 283 of file softhddevice.h.

Referenced by ProcessArgs(), and UsePip().

◆ m_drmCanDisplayPip

bool cSoftHdDevice::m_drmCanDisplayPip = true
private

true, if the drm device is able to display a pip video

Definition at line 282 of file softhddevice.h.

Referenced by SetDrmCanDisplayPip(), and UsePip().

◆ m_eventMutex

std::mutex cSoftHdDevice::m_eventMutex
private

mutex to protect event queue

Definition at line 253 of file softhddevice.h.

◆ m_forceDetached

bool cSoftHdDevice::m_forceDetached = false
private

start the plugin in detached state

Definition at line 290 of file softhddevice.h.

Referenced by Attach(), OnEventReceived(), and ProcessArgs().

◆ m_mutex

std::mutex cSoftHdDevice::m_mutex
mutableprivate

mutex to lock the state machine

Definition at line 277 of file softhddevice.h.

Referenced by IsDetached(), OnEventReceived(), and PipIsEnabled().

◆ m_needsMakePrimary

bool cSoftHdDevice::m_needsMakePrimary = false
private

Definition at line 254 of file softhddevice.h.

Referenced by Attach(), and Detach().

◆ m_pAudio

◆ m_pAudioDecoder

cAudioDecoder* cSoftHdDevice::m_pAudioDecoder = nullptr
private

◆ m_pConfig

◆ m_pGrab

cSoftHdGrab* cSoftHdDevice::m_pGrab
private

pointer to grabber object

Definition at line 272 of file softhddevice.h.

Referenced by GrabImage(), OnEnteringState(), and OnLeavingState().

◆ m_pHardwareDevice

cHardwareDevice* cSoftHdDevice::m_pHardwareDevice
private

pointer to hardware device description

Definition at line 262 of file softhddevice.h.

Referenced by Initialize(), OnLeavingState(), and ~cSoftHdDevice().

◆ m_pipReassemblyBuffer

cReassemblyBufferVideo cSoftHdDevice::m_pipReassemblyBuffer
private

pip pes reassembly buffer

Definition at line 275 of file softhddevice.h.

Referenced by PlayPipVideo(), and ResetPipStream().

◆ m_pipUseAlt

bool cSoftHdDevice::m_pipUseAlt
private

use alternative pip position

Definition at line 281 of file softhddevice.h.

Referenced by SetRenderPipSize(), and ToggleRenderPipPosition().

◆ m_playbackMode

std::atomic<PlaybackMode> cSoftHdDevice::m_playbackMode = NONE
private

current playback mode

Definition at line 270 of file softhddevice.h.

Referenced by Clear(), GetSTC(), IsVideoOnlyPlayback(), OnEnteringState(), and OnEventReceived().

◆ m_pOsdProvider

cSoftOsdProvider* cSoftHdDevice::m_pOsdProvider = nullptr
private

◆ m_pPipHandler

cPipHandler* cSoftHdDevice::m_pPipHandler = nullptr
private

◆ m_pPipStream

cVideoStream* cSoftHdDevice::m_pPipStream
private

pointer to pip video stream

Definition at line 274 of file softhddevice.h.

Referenced by OnEnteringState(), OnLeavingState(), PlayPipVideo(), and ResetPipStream().

◆ m_pRender

◆ m_pSpuDecoder

cDvbSpuDecoder* cSoftHdDevice::m_pSpuDecoder
private

pointer to spu decoder

Definition at line 255 of file softhddevice.h.

Referenced by GetSpuDecoder(), and ~cSoftHdDevice().

◆ m_pVideoStream

◆ m_receivedAudio

std::atomic<bool> cSoftHdDevice::m_receivedAudio = false
private

flag if audio packets have been received

Definition at line 279 of file softhddevice.h.

Referenced by IsBufferingThresholdReached(), OnLeavingState(), PlayAudio(), and PlayVideo().

◆ m_receivedVideo

std::atomic<bool> cSoftHdDevice::m_receivedVideo = false
private

flag if video packets have been received

Definition at line 280 of file softhddevice.h.

Referenced by IsBufferingThresholdReached(), OnLeavingState(), PlayAudio(), and PlayVideo().

◆ m_screenHeight

int cSoftHdDevice::m_screenHeight
private

Definition at line 287 of file softhddevice.h.

Referenced by GetOsdSize(), and SetScreenSize().

◆ m_screenRefreshRateHz

double cSoftHdDevice::m_screenRefreshRateHz
private

Definition at line 288 of file softhddevice.h.

Referenced by SetScreenSize().

◆ m_screenWidth

int cSoftHdDevice::m_screenWidth
private

Definition at line 286 of file softhddevice.h.

Referenced by GetOsdSize(), and SetScreenSize().

◆ m_sizeMutex

std::mutex cSoftHdDevice::m_sizeMutex
private

mutex to lock screen size (which is accessed by different threads)

Definition at line 278 of file softhddevice.h.

Referenced by GetOsdSize(), and SetScreenSize().

◆ m_state

std::atomic<State> cSoftHdDevice::m_state = DETACHED
private

current plugin state, normal plugin start sets detached state

Definition at line 252 of file softhddevice.h.

Referenced by IsBufferingThresholdReached(), IsDetached(), OnEventReceived(), and SetState().

◆ m_videoJitterTracker

cJitterTracker cSoftHdDevice::m_videoJitterTracker {"video"}
private

video jitter tracker

Definition at line 266 of file softhddevice.h.

Referenced by OnEnteringState(), and PlayVideoInternal().

◆ m_videoReassemblyBuffer

cReassemblyBufferVideo cSoftHdDevice::m_videoReassemblyBuffer
private

video pes reassembly buffer

Definition at line 263 of file softhddevice.h.

Referenced by Clear(), HandleStillPicture(), OnEnteringState(), and PlayVideo().

◆ m_volume

int cSoftHdDevice::m_volume = 0
private

track the volume in the device (for attach)

Definition at line 284 of file softhddevice.h.

Referenced by OnEventReceived(), and SetVolumeDevice().

◆ MIN_BUFFER_FILL_LEVEL_THRESHOLD_MS

constexpr int cSoftHdDevice::MIN_BUFFER_FILL_LEVEL_THRESHOLD_MS = 450
staticconstexprprivate

min buffering threshold in ms

Definition at line 250 of file softhddevice.h.

Referenced by GetBufferFillLevelThresholdMs(), and GetMinBufferFillLevelThresholdMs().


The documentation for this class was generated from the following files: