[Scummvm-cvs-logs] SF.net SVN: scummvm:[51862] scummvm/trunk/graphics/video

drmccoy at users.sourceforge.net drmccoy at users.sourceforge.net
Sun Aug 8 02:40:24 CEST 2010


Revision: 51862
          http://scummvm.svn.sourceforge.net/scummvm/?rev=51862&view=rev
Author:   drmccoy
Date:     2010-08-08 00:40:24 +0000 (Sun, 08 Aug 2010)

Log Message:
-----------
VIDEO: Stub IMDDecoder

Modified Paths:
--------------
    scummvm/trunk/graphics/video/coktel_decoder.cpp
    scummvm/trunk/graphics/video/coktel_decoder.h

Modified: scummvm/trunk/graphics/video/coktel_decoder.cpp
===================================================================
--- scummvm/trunk/graphics/video/coktel_decoder.cpp	2010-08-08 00:40:00 UTC (rev 51861)
+++ scummvm/trunk/graphics/video/coktel_decoder.cpp	2010-08-08 00:40:24 UTC (rev 51862)
@@ -338,6 +338,105 @@
 	return PixelFormat::createFormatCLUT8();
 }
 
+
+IMDDecoder::IMDDecoder(Audio::Mixer &mixer, Audio::Mixer::SoundType soundType) : CoktelDecoder(mixer, soundType),
+	_stream(0), _videoBuffer(0), _videoBufferSize(0) {
+}
+
+IMDDecoder::~IMDDecoder() {
+	close();
+}
+
+bool IMDDecoder::seek(int32 frame, int whence, bool restart) {
+	if (!isVideoLoaded())
+		// Nothing to do
+		return false;
+
+	// Find the frame to which to seek
+	if      (whence == SEEK_CUR)
+		frame += _curFrame;
+	else if (whence == SEEK_END)
+		frame = _frameCount - frame - 1;
+	else if (whence == SEEK_SET)
+		frame--;
+	else
+		return false;
+
+	if ((frame < -1) || (((uint32) frame) >= _frameCount))
+		// Out of range
+		return false;
+
+	if (frame == _curFrame)
+		// Nothing to do
+		return true;
+
+	// TODO
+
+	return true;
+}
+
+bool IMDDecoder::load(Common::SeekableReadStream &stream) {
+	close();
+
+	_stream = &stream;
+
+	warning("IMDDecoder::load()");
+
+	// TODO
+
+	return false;
+}
+
+void IMDDecoder::close() {
+	reset();
+
+	CoktelDecoder::close();
+
+	delete _stream;
+
+	delete[] _videoBuffer;
+
+	_stream = 0;
+
+	_videoBuffer     = 0;
+	_videoBufferSize = 0;
+}
+
+bool IMDDecoder::isVideoLoaded() const {
+	return _stream != 0;
+}
+
+Surface *IMDDecoder::decodeNextFrame() {
+	if (!isVideoLoaded() || endOfVideo())
+		return 0;
+
+	createSurface();
+
+	processFrame();
+	renderFrame();
+
+	_curFrame++;
+
+	if (_curFrame == 0)
+		_startTime = g_system->getMillis();
+
+	return &_surface;
+}
+
+void IMDDecoder::processFrame() {
+	// TODO
+}
+
+void IMDDecoder::renderFrame() {
+	_dirtyRects.clear();
+
+	// TODO
+}
+
+PixelFormat IMDDecoder::getPixelFormat() const {
+	return PixelFormat::createFormatCLUT8();
+}
+
 } // End of namespace Graphics
 
 #endif // GRAPHICS_VIDEO_COKTELDECODER_H

Modified: scummvm/trunk/graphics/video/coktel_decoder.h
===================================================================
--- scummvm/trunk/graphics/video/coktel_decoder.h	2010-08-08 00:40:00 UTC (rev 51861)
+++ scummvm/trunk/graphics/video/coktel_decoder.h	2010-08-08 00:40:24 UTC (rev 51862)
@@ -144,6 +144,34 @@
 	void renderFrame();
 };
 
+class IMDDecoder : public CoktelDecoder {
+public:
+	IMDDecoder(Audio::Mixer &mixer, Audio::Mixer::SoundType soundType = Audio::Mixer::kPlainSoundType);
+	~IMDDecoder();
+
+	bool seek(int32 frame, int whence = SEEK_SET, bool restart = false);
+
+	// VideoDecoder interface
+
+	bool load(Common::SeekableReadStream &stream);
+	void close();
+
+	bool isVideoLoaded() const;
+
+	Surface *decodeNextFrame();
+
+	PixelFormat getPixelFormat() const;
+
+private:
+	Common::SeekableReadStream *_stream;
+
+	byte  *_videoBuffer;
+	uint32 _videoBufferSize;
+
+	void processFrame();
+	void renderFrame();
+};
+
 } // End of namespace Graphics
 
 #endif // GRAPHICS_VIDEO_COKTELDECODER_H


This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site.




More information about the Scummvm-git-logs mailing list