openMSX
Classes | Public Types | Public Member Functions | List of all members
openmsx::LaserdiscPlayer Class Referencefinal

#include <LaserdiscPlayer.hh>

Inheritance diagram for openmsx::LaserdiscPlayer:
Inheritance graph
[legend]
Collaboration diagram for openmsx::LaserdiscPlayer:
Collaboration graph
[legend]

Public Types

enum  RemoteState {
  REMOTE_IDLE, REMOTE_HEADER_PULSE, NEC_HEADER_SPACE, NEC_BITS_PULSE,
  NEC_BITS_SPACE
}
 
enum  PlayerState {
  PLAYER_STOPPED, PLAYER_PLAYING, PLAYER_MULTISPEED, PLAYER_PAUSED,
  PLAYER_STILL
}
 
enum  SeekState { SEEK_NONE, SEEK_CHAPTER, SEEK_FRAME, SEEK_WAIT }
 
enum  StereoMode { LEFT, RIGHT, STEREO }
 
enum  RemoteProtocol { IR_NONE, IR_NEC }
 
- Public Types inherited from openmsx::ResampledSoundDevice
enum  ResampleType { RESAMPLE_HQ, RESAMPLE_LQ, RESAMPLE_BLIP }
 

Public Member Functions

 LaserdiscPlayer (const HardwareConfig &hwConf, PioneerLDControl &ldcontrol)
 
 ~LaserdiscPlayer ()
 
int16_t readSample (EmuTime::param time)
 
void setMuting (bool left, bool right, EmuTime::param time)
 
bool extAck (EmuTime::param) const
 
void extControl (bool bit, EmuTime::param time)
 
const RawFramegetRawFrame () const
 
template<typename Archive >
void serialize (Archive &ar, unsigned version)
 
MSXMotherBoardgetMotherBoard ()
 
- Public Member Functions inherited from openmsx::ResampledSoundDevice
bool generateInput (float *buffer, unsigned num)
 Note: To enable various optimizations (like SSE), this method is allowed to generate up to 3 extra sample. More...
 
- Public Member Functions inherited from openmsx::SoundDevice
const std::string & getName () const
 Get the unique name that identifies this sound device. More...
 
const std::string & getDescription () const
 Gets a description of this sound device, to be presented to the user. More...
 
bool isStereo () const
 Is this a stereo device? This is set in the constructor and cannot be changed anymore. More...
 
std::pair< float, float > getAmplificationFactor () const
 Gets this device its 'amplification factor'. More...
 
void setSoftwareVolume (float volume, EmuTime::param time)
 Change the 'software volume' of this sound device. More...
 
void setSoftwareVolume (float left, float right, EmuTime::param time)
 
void recordChannel (unsigned channel, const Filename &filename)
 
void muteChannel (unsigned channel, bool muted)
 

Additional Inherited Members

- Static Public Attributes inherited from openmsx::SoundDevice
static const unsigned MAX_CHANNELS = 24
 
- Protected Member Functions inherited from openmsx::ResampledSoundDevice
 ResampledSoundDevice (MSXMotherBoard &motherBoard, string_view name, string_view description, unsigned channels, unsigned inputSampleRate, bool stereo)
 
 ~ResampledSoundDevice ()
 
void setOutputRate (unsigned sampleRate) override
 When a SoundDevice registers itself with the Mixer, the Mixer sets the required sampleRate through this method. More...
 
bool updateBuffer (unsigned length, float *buffer, EmuTime::param time) override
 Generate sample data. More...
 
void update (const Setting &setting) override
 
void createResampler ()
 
- Protected Member Functions inherited from openmsx::SoundDevice
 SoundDevice (MSXMixer &mixer, string_view name, string_view description, unsigned numChannels, unsigned inputRate, bool stereo)
 Constructor. More...
 
 ~SoundDevice ()
 
void registerSound (const DeviceConfig &config)
 Registers this sound device with the Mixer. More...
 
void unregisterSound ()
 Unregisters this sound device with the Mixer. More...
 
void updateStream (EmuTime::param time)
 
void setInputRate (unsigned sampleRate)
 
unsigned getInputRate () const
 
bool mixChannels (float *dataOut, unsigned samples)
 Calls generateChannels() and combines the output to a single channel. More...
 
const DynamicClockgetHostSampleClock () const
 See MSXMixer::getHostSampleClock(). More...
 
double getEffectiveSpeed () const
 
- Protected Member Functions inherited from openmsx::Observer< Setting >
 ~Observer ()=default
 
virtual void subjectDeleted (const Setting &)
 
- Static Protected Member Functions inherited from openmsx::SoundDevice
static void addFill (float *&buffer, float value, unsigned num)
 Adds a number of samples that all have the same value. More...
 

Detailed Description

Definition at line 25 of file LaserdiscPlayer.hh.

Member Enumeration Documentation

◆ PlayerState

Enumerator
PLAYER_STOPPED 
PLAYER_PLAYING 
PLAYER_MULTISPEED 
PLAYER_PAUSED 
PLAYER_STILL 

Definition at line 57 of file LaserdiscPlayer.hh.

◆ RemoteProtocol

Enumerator
IR_NONE 
IR_NEC 

Definition at line 78 of file LaserdiscPlayer.hh.

◆ RemoteState

Enumerator
REMOTE_IDLE 
REMOTE_HEADER_PULSE 
NEC_HEADER_SPACE 
NEC_BITS_PULSE 
NEC_BITS_SPACE 

Definition at line 49 of file LaserdiscPlayer.hh.

◆ SeekState

Enumerator
SEEK_NONE 
SEEK_CHAPTER 
SEEK_FRAME 
SEEK_WAIT 

Definition at line 65 of file LaserdiscPlayer.hh.

◆ StereoMode

Enumerator
LEFT 
RIGHT 
STEREO 

Definition at line 72 of file LaserdiscPlayer.hh.

Constructor & Destructor Documentation

◆ LaserdiscPlayer()

openmsx::LaserdiscPlayer::LaserdiscPlayer ( const HardwareConfig hwConf,
PioneerLDControl ldcontrol 
)

◆ ~LaserdiscPlayer()

openmsx::LaserdiscPlayer::~LaserdiscPlayer ( )

Member Function Documentation

◆ extAck()

bool openmsx::LaserdiscPlayer::extAck ( EmuTime::param  ) const
inline

Definition at line 39 of file LaserdiscPlayer.hh.

References extControl(), getRawFrame(), and serialize().

◆ extControl()

void openmsx::LaserdiscPlayer::extControl ( bool  bit,
EmuTime::param  time 
)

◆ getMotherBoard()

MSXMotherBoard& openmsx::LaserdiscPlayer::getMotherBoard ( )
inline

◆ getRawFrame()

const RawFrame * openmsx::LaserdiscPlayer::getRawFrame ( ) const

Definition at line 263 of file LaserdiscPlayer.cc.

References openmsx::EmuDuration::msec().

Referenced by extAck().

◆ readSample()

int16_t openmsx::LaserdiscPlayer::readSample ( EmuTime::param  time)

◆ serialize()

template<typename Archive >
void openmsx::LaserdiscPlayer::serialize ( Archive &  ar,
unsigned  version 
)

◆ setMuting()

void openmsx::LaserdiscPlayer::setMuting ( bool  left,
bool  right,
EmuTime::param  time 
)

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