123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- #pragma once
- #include "Critical.h"
- #include "Array.h"
- #include "Vec3.h"
- namespace Framework
- {
- class Zeichnung3D; //! Zeichnung.h
- class Render3D; //! Render3D.h
- struct MausEreignis3D; //! MausEreignis.h
- class Model3D;
- struct DiffuseLight;
- struct PointLight;
- class DXBuffer;
- //! Speichert alle 3D Zeichnungen einer Szene ab
- class Welt3D : public virtual ReferenceCounter
- {
- protected:
- DiffuseLight *diffuseLights;
- int diffuseLightCount;
- PointLight *pointLights;
- int pointLightCount;
- private:
- RCArray< Model3D > *members;
- bool rend;
- Critical cs;
- public:
- //! Konstructor
- DLLEXPORT Welt3D();
- //! Destruktor
- DLLEXPORT virtual ~Welt3D();
- //! Blockiert den zugriff auf das Objekt und wartet gegebenfalls auf den Zugriff
- DLLEXPORT void lock();
- //! Gibt das Objekt für andere Threads frei
- DLLEXPORT void unlock();
- //! Fügt der Welt ein Objekt hinzu
- //! \param obj Das Objekt, was hinzugefügt werden soll
- DLLEXPORT void addZeichnung( Model3D *obj );
- //! Entfernt ein Objekt aus der Welt
- //! \param obj Das Objekt, das entwernt werden soll (ohne erhöhten reference Counter)
- DLLEXPORT void removeZeichnung( Model3D *zObj );
- //! Verarbeitet ein Mausereignis
- //! \param me Das Mausereignis, das verarbeitet werden soll
- DLLEXPORT void doMausEreignis( MausEreignis3D &me );
- //! Verarbeitet die vergangene Zeit
- //! \param tickval Die zeit in sekunden, die seit dem letzten Aufruf der Funktion vergangen ist
- //! \return true, wenn sich das Objekt verändert hat, false sonnst.
- DLLEXPORT virtual bool tick( double tickval );
- //! brerechnet die Farbe eines Sichtstrahls, der von einem bestimmten punkt aus in eine bestimmte richtung schaut
- //! \param point Der ursprung des Strahls,
- //! \param dir Die Richtung des Strahls
- //! \return Die Farbe des Strahls
- DLLEXPORT virtual int traceRay( Vec3< float > &point, Vec3< float > &dir );
- //! Gibt einen Iterator zurück, mit dem alle Members aufgezählt werden können
- DLLEXPORT Iterator< Model3D * > getMembers();
- //! Gibt die Anzahl an Punkt Lichtquellen zurück
- DLLEXPORT int getPointLightCount() const;
- //! Gibt die Anzahl an Richtungs Lichtquellen zurück
- DLLEXPORT int getDiffuseLightCount() const;
- //! Kopiert alle Lichtquellen in die Buffer
- //! \param zDiffuse der Buffer für die rechtungs Lichtquellen
- //! \param zPoints der Buffer für die Punkt Lichtquellen
- DLLEXPORT void copyLight( DXBuffer *zDiffuse, DXBuffer *zPoints ) const;
- };
- }
|