1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
|
/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
*/
#ifndef CRYOMNI3D_VIDEO_HNM_DECODER_H
#define CRYOMNI3D_VIDEO_HNM_DECODER_H
#include "common/rational.h"
#include "graphics/pixelformat.h"
#include "video/video_decoder.h"
#include "graphics/surface.h"
#include "audio/audiostream.h"
namespace Common {
class SeekableReadStream;
}
namespace Video {
/**
* Decoder for HNM videos.
*
* Video decoder used in engines:
* - cryomni3d
*/
class HNMDecoder : public VideoDecoder {
public:
HNMDecoder(bool loop = false);
virtual ~HNMDecoder();
bool loadStream(Common::SeekableReadStream *stream);
void readNextPacket();
void close();
void setRegularFrameDelay(uint32 regularFrameDelay) { _regularFrameDelay = regularFrameDelay; }
private:
class HNM4VideoTrack : public VideoTrack {
public:
HNM4VideoTrack(uint32 width, uint32 height, uint32 frameSize, uint32 frameCount,
uint32 regularFrameDelay);
~HNM4VideoTrack();
// When _frameCount is 0, it means we are looping
bool endOfTrack() const { return (_frameCount == 0) ? false : VideoTrack::endOfTrack(); }
uint16 getWidth() const { return _surface.w; }
uint16 getHeight() const { return _surface.h; }
Graphics::PixelFormat getPixelFormat() const { return _surface.format; }
int getCurFrame() const { return _curFrame; }
int getFrameCount() const { return _frameCount; }
uint32 getNextFrameStartTime() const { return _nextFrameStartTime; }
const Graphics::Surface *decodeNextFrame() { return &_surface; }
const byte *getPalette() const { _dirtyPalette = false; return _palette; }
bool hasDirtyPalette() const { return _dirtyPalette; }
/** Decode a video chunk. */
void decodePalette(Common::SeekableReadStream *stream, uint32 size);
void decodeInterframe(Common::SeekableReadStream *stream, uint32 size);
void decodeIntraframe(Common::SeekableReadStream *stream, uint32 size);
void restart() { _nextFrameDelay = -1; _nextNextFrameDelay = -1; }
void setFrameDelay(uint32 frameDelay);
private:
Graphics::Surface _surface;
uint32 _regularFrameDelay;
uint32 _nextFrameDelay;
uint32 _nextNextFrameDelay;
uint32 _nextFrameStartTime;
uint32 _frameCount;
int _curFrame;
byte _palette[256 * 3];
mutable bool _dirtyPalette;
byte *_frameBufferC;
byte *_frameBufferP;
};
class DPCMAudioTrack : public AudioTrack {
public:
DPCMAudioTrack(uint16 channels, uint16 bits, unsigned int sampleRate,
Audio::Mixer::SoundType soundType);
~DPCMAudioTrack();
Audio::Timestamp decodeSound(Common::SeekableReadStream *stream, uint32 size);
protected:
Audio::AudioStream *getAudioStream() const { return _audioStream; }
private:
uint16 _channels;
uint16 _bits;
Audio::QueuingAudioStream *_audioStream;
bool _gotLUT;
uint16 _lut[256];
uint16 _lastSample;
};
bool _loop;
uint32 _regularFrameDelay;
// These two pointer are owned by VideoDecoder
HNM4VideoTrack *_videoTrack;
DPCMAudioTrack *_audioTrack;
Common::SeekableReadStream *_stream;
};
} // End of namespace Video
#endif
|