diff options
| author | Sven Hesse | 2011-09-03 20:49:10 +0200 | 
|---|---|---|
| committer | Sven Hesse | 2011-09-14 18:54:27 +0200 | 
| commit | 358f55db402d1c8acd72c65f76b37a310575809d (patch) | |
| tree | bc1c63811bdb26a980174bdcc00ba66c2e72cc2f | |
| parent | 918fe978e2d4f1e149cf8040e087b7b70e54c9d4 (diff) | |
| download | scummvm-rg350-358f55db402d1c8acd72c65f76b37a310575809d.tar.gz scummvm-rg350-358f55db402d1c8acd72c65f76b37a310575809d.tar.bz2 scummvm-rg350-358f55db402d1c8acd72c65f76b37a310575809d.zip | |
GOB: Add stubby "Diving" black pearl drawing
| -rw-r--r-- | engines/gob/minigames/geisha/diving.cpp | 31 | ||||
| -rw-r--r-- | engines/gob/minigames/geisha/diving.h | 6 | 
2 files changed, 35 insertions, 2 deletions
| diff --git a/engines/gob/minigames/geisha/diving.cpp b/engines/gob/minigames/geisha/diving.cpp index 6130ebad78..d2f51e645c 100644 --- a/engines/gob/minigames/geisha/diving.cpp +++ b/engines/gob/minigames/geisha/diving.cpp @@ -37,11 +37,15 @@ namespace Gob {  namespace Geisha {  Diving::Diving(GobEngine *vm) : _vm(vm), _background(0), -	_objects(0), _gui(0), _oko(0), _lungs(0), _heart(0) { +	_objects(0), _gui(0), _oko(0), _lungs(0), _heart(0), +	_blackPearl(0), _blackPearlCount(0) { +	_blackPearl = new Surface(11, 8, 1);  }  Diving::~Diving() { +	delete _blackPearl; +  	deinit();  } @@ -88,10 +92,13 @@ bool Diving::play(uint16 playerCount, bool hasPearlLocation) {  		_vm->_util->waitEndFrame();  		_vm->_util->processInput(); + +		if (_blackPearlCount >= 2) +			break;  	}  	deinit(); -	return true; +	return _blackPearlCount >= 2;  }  void Diving::init() { @@ -117,6 +124,14 @@ void Diving::init() {  	_heart->setPosition();  	_heart->setVisible(true);  	_heart->setPause(true); + +	Surface tmp(320, 103, 1); + +	_vm->_video->drawPackedSprite("tperlobj.cmp", tmp); + +	_blackPearl->blit(tmp, 282, 80, 292, 87, 0, 0); + +	_blackPearlCount = 0;  }  void Diving::deinit() { @@ -154,6 +169,18 @@ void Diving::initScreen() {  	_vm->_draw->dirtiedRect(_vm->_draw->_backSurface, 0, 0, 319, 199);  } +void Diving::foundBlackPearl() { +	_blackPearlCount++; + +	if        (_blackPearlCount == 1) { +		_vm->_draw->_backSurface->blit(*_blackPearl, 0, 0, 10, 7, 147, 179, 0); +		_vm->_draw->dirtiedRect(_vm->_draw->_backSurface, 147, 179, 157, 186); +	} else if (_blackPearlCount == 2) { +		_vm->_draw->_backSurface->blit(*_blackPearl, 0, 0, 10, 7, 160, 179, 0); +		_vm->_draw->dirtiedRect(_vm->_draw->_backSurface, 147, 179, 160, 186); +	} +} +  } // End of namespace Geisha  } // End of namespace Gob diff --git a/engines/gob/minigames/geisha/diving.h b/engines/gob/minigames/geisha/diving.h index 238a1ad75b..96a8a74903 100644 --- a/engines/gob/minigames/geisha/diving.h +++ b/engines/gob/minigames/geisha/diving.h @@ -28,6 +28,7 @@  namespace Gob {  class GobEngine; +class Surface;  class DECFile;  class ANIFile;  class ANIObject; @@ -54,11 +55,16 @@ private:  	ANIObject *_lungs;  	ANIObject *_heart; +	Surface *_blackPearl; + +	uint8 _blackPearlCount;  	void init();  	void deinit();  	void initScreen(); + +	void foundBlackPearl();  };  } // End of namespace Geisha | 
