123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219 |
- #include "VideoSteuerung.h"
- #include "../../Initialisierung/Initialisierung.h"
- #include <DateiSystem.h>
- #include <Text.h>
- #include <Punkt.h>
- #include <Bildschirm.h>
- #include <MausEreignis.h>
- // Inhalt der VideoSteuerung Klasse aus VideoSteuerung.h
- // Konstruktor
- VideoSteuerung::VideoSteuerung( Schrift *zSchrift, Bildschirm *zScreen )
- {
- pos = zScreen->getBackBufferSize() - Punkt( 285, 30 );
- verlassen = initKnopf( 0, 0, 100, 22, zSchrift, Knopf::Style::Sichtbar, "Verlassen" );
- initToolTip( verlassen, "Aufzeichnung verlassen", zSchrift, zScreen );
- langsamer = initKnopf( 105, 0, 22, 22, 0, 0, "" );
- langsamer->setStyle( Knopf::Style::Sichtbar | Knopf::Style::Erlaubt | Knopf::Style::HAlpha | Knopf::Style::HBild | Knopf::Style::Hintergrund | Knopf::Style::KlickBuffer | Knopf::Style::Rahmen );
- langsamer->setRahmenBreite( 1 );
- stop = initKnopf( 130, 0, 22, 22, 0, 0, "" );
- stop->setStyle( Knopf::Style::Sichtbar | Knopf::Style::Erlaubt | Knopf::Style::HAlpha | Knopf::Style::HBild | Knopf::Style::Hintergrund | Knopf::Style::KlickBuffer | Knopf::Style::Rahmen );
- stop->setRahmenBreite( 1 );
- schneller = initKnopf( 155, 0, 22, 22, 0, 0, "" );
- schneller->setStyle( Knopf::Style::Sichtbar | Knopf::Style::Erlaubt | Knopf::Style::HAlpha | Knopf::Style::HBild | Knopf::Style::Hintergrund | Knopf::Style::KlickBuffer | Knopf::Style::Rahmen );
- schneller->setRahmenBreite( 1 );
- LTDBDatei *vBilder = new LTDBDatei();
- vBilder->setDatei( new Text( "data/client/bilder/video.ltdb" ) );
- vBilder->leseDaten( 0 );
- langsamer->setHintergrundBildZ( vBilder->laden( 0, new Text( "zurück.png" ) ) );
- stop->setHintergrundBildZ( vBilder->laden( 0, new Text( "pause.png" ) ) );
- schneller->setHintergrundBildZ( vBilder->laden( 0, new Text( "vor.png" ) ) );
- vBilder->release();
- initToolTip( langsamer, "Langsammer abspielen", zSchrift, zScreen );
- initToolTip( stop, "Pause", zSchrift, zScreen );
- initToolTip( schneller, "Schneller abspielen", zSchrift, zScreen );
- zeit = initTextFeld( 180, 0, 100, 22, zSchrift, TextFeld::Style::Text | TextFeld::Style::Center, "0:0:0" );
- spielZeit = 0;
- speed = 1;
- vorwärts = 1;
- zeitlupe = 0;
- beendet = 0;
- bJetzt = 0;
- ref = 1;
- }
- // Destruktor
- VideoSteuerung::~VideoSteuerung()
- {
- verlassen->release();
- langsamer->release();
- stop->release();
- schneller->release();
- zeit->release();
- }
- // Nicht constant
- void VideoSteuerung::doMausEreignis( MausEreignis &me )
- {
- me.mx -= pos.x;
- me.my -= pos.y;
- bool vera = me.verarbeitet;
- verlassen->doMausEreignis( me );
- if( !vera && me.verarbeitet )
- {
- if( me.id == ME_RLinks )
- {
- bJetzt = 1;
- beendet = 1;
- }
- vera = 1;
- }
- langsamer->doMausEreignis( me );
- if( !vera && me.verarbeitet )
- {
- if( me.id == ME_RLinks )
- {
- if( !speed )
- {
- vorwärts = 0;
- speed = 1;
- stop->addStyle( Knopf::Style::Erlaubt );
- schneller->addStyle( Knopf::Style::Erlaubt );
- }
- else
- {
- speed += ( vorwärts && zeitlupe ) || ( !vorwärts && !zeitlupe );
- speed -= ( vorwärts && !zeitlupe ) || ( !vorwärts && zeitlupe );
- zeitlupe |= vorwärts && ( speed == 0 );
- zeitlupe &= vorwärts || ( speed != 0 );
- speed += speed == 0;
- }
- }
- vera = 1;
- }
- stop->doMausEreignis( me );
- if( !vera && me.verarbeitet )
- {
- if( me.id == ME_RLinks )
- {
- speed = 0;
- zeitlupe = 0;
- stop->removeStyle( Knopf::Style::Erlaubt );
- }
- vera = 1;
- }
- schneller->doMausEreignis( me );
- if( !vera && me.verarbeitet )
- {
- if( me.id == ME_RLinks )
- {
- if( !speed )
- {
- vorwärts = 1;
- speed = 1;
- stop->addStyle( Knopf::Style::Erlaubt );
- langsamer->addStyle( Knopf::Style::Erlaubt );
- }
- else
- {
- speed += ( vorwärts && !zeitlupe ) || ( !vorwärts && zeitlupe );
- speed -= ( vorwärts && zeitlupe ) || ( !vorwärts && !zeitlupe );
- zeitlupe |= !vorwärts && ( speed == 0 );
- zeitlupe &= !vorwärts || ( speed != 0 );
- speed += speed == 0;
- }
- }
- vera = 1;
- }
- me.mx += pos.x;
- me.my += pos.y;
- }
- bool VideoSteuerung::tick( double zeit )
- {
- bool ret = langsamer->tick( zeit );
- ret |= verlassen->tick( zeit );
- ret |= stop->tick( zeit );
- ret |= schneller->tick( zeit );
- spielZeit += zeit;
- if( (int)spielZeit != (int)( spielZeit - zeit ) )
- {
- Text z;
- z = (int)spielZeit / 60 / 60;
- z += ":";
- z += (int)spielZeit / 60 % 60;
- z += ":";
- z += (int)spielZeit % 60;
- this->zeit->setText( z );
- }
- ret |= this->zeit->tick( zeit );
- return ret;
- }
- void VideoSteuerung::render( Bild &zRObj )
- {
- if( !zRObj.setDrawOptions( pos.x, pos.y, 300, 30 ) )
- return;
- verlassen->render( zRObj );
- langsamer->render( zRObj );
- stop->render( zRObj );
- schneller->render( zRObj );
- zeit->render( zRObj );
- zRObj.releaseDrawOptions();
- }
- void VideoSteuerung::pause( bool ende )
- {
- speed = 0;
- zeitlupe = 0;
- stop->removeStyle( Knopf::Style::Erlaubt );
- if( ende )
- schneller->removeStyle( Knopf::Style::Erlaubt );
- else
- langsamer->removeStyle( Knopf::Style::Erlaubt );
- }
- bool VideoSteuerung::istBeendet( bool jetzt )
- {
- if( jetzt )
- {
- if( bJetzt )
- {
- bJetzt = 0;
- return 1;
- }
- return 0;
- }
- return beendet;
- }
- // constant
- int VideoSteuerung::getSpeed() const
- {
- return speed + zeitlupe;
- }
- bool VideoSteuerung::istVorwärts() const
- {
- return vorwärts;
- }
- bool VideoSteuerung::istZeitlupe() const
- {
- return zeitlupe;
- }
- // Reference Counting
- VideoSteuerung *VideoSteuerung::getThis()
- {
- ref++;
- return this;
- }
- VideoSteuerung *VideoSteuerung::release()
- {
- ref--;
- if( !ref )
- delete this;
- return 0;
- }
|