/*==LICENSE==* CyanWorlds.com Engine - MMOG client, server and tools Copyright (C) 2011 Cyan Worlds, Inc. 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 3 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, see <http://www.gnu.org/licenses/>. Additional permissions under GNU GPL version 3 section 7 If you modify this Program, or any covered work, by linking or combining it with any of RAD Game Tools Bink SDK, Autodesk 3ds Max SDK, NVIDIA PhysX SDK, Microsoft DirectX SDK, OpenSSL library, Independent JPEG Group JPEG library, Microsoft Windows Media SDK, or Apple QuickTime SDK (or a modified version of those libraries), containing parts covered by the terms of the Bink SDK EULA, 3ds Max EULA, PhysX SDK EULA, DirectX SDK EULA, OpenSSL and SSLeay licenses, IJG JPEG Library README, Windows Media SDK EULA, or QuickTime SDK EULA, the licensors of this Program grant you additional permission to convey the resulting work. Corresponding Source for a non-source form of such a combination shall include the source code for the parts of OpenSSL and IJG JPEG Library used as well as that of the covered work. You can contact Cyan Worlds, Inc. by email legal@cyan.com or by snail mail at: Cyan Worlds, Inc. 14617 N Newport Hwy Mead, WA 99021 *==LICENSE==*/ #ifndef plPipeline_inc #define plPipeline_inc #include "pnFactory/plCreatable.h" #include "hsGMatState.h" #include "hsTemplates.h" #define MIN_WIDTH 640 #define MIN_HEIGHT 480 #define DEFAULT_WIDTH 800 #define DEFAULT_HEIGHT 600 #define DEFAULT_WINDOWED false #define DEFAULT_COLORDEPTH 32 #define DEFAULT_ANTIALIASAMOUNT 0 #define DEFAULT_ANISOLEVEL 0 #define DEFAULT_TEXTUREQUALITY 2 #define DEFAULT_VIDEOQUALITY 2 #define DEFAULT_SHADOWS 0 #define DEFAULT_PLANARREFLECTIONS 0 struct hsPoint3; struct hsVector3; struct hsMatrix44; struct hsColorRGBA; class hsBounds3Ext; class hsGMaterial; class plDrawPrim; class plRenderTarget; class hsG3DDevice; class hsGView3; class plDrawable; class plGBufferGroup; class plLayerInterface; class plSpaceTree; class plCullPoly; class plRenderRequest; class plShadowSlave; class plAccessSpan; class plTextFont; class plVertexSpan; class plDrawableSpans; class plSceneObject; class plClothingOutfit; class hsGDeviceRef; class plFogEnvironment; class plLightInfo; class plMipmap; class plVisMgr; class plViewTransform; struct PipelineParams { PipelineParams(): Width(DEFAULT_WIDTH), Height(DEFAULT_HEIGHT), Windowed(DEFAULT_WINDOWED), ColorDepth(DEFAULT_COLORDEPTH), AntiAliasingAmount(DEFAULT_ANTIALIASAMOUNT), AnisotropicLevel(DEFAULT_ANISOLEVEL), TextureQuality(DEFAULT_TEXTUREQUALITY), VideoQuality(DEFAULT_VIDEOQUALITY), Shadows(DEFAULT_SHADOWS), PlanarReflections(DEFAULT_PLANARREFLECTIONS), #ifndef PLASMA_EXTERNAL_RELEASE ForceSecondMonitor(false), #endif // PLASMA_EXTERNAL_RELEASE VSync(false) { } int Width; int Height; bool Windowed; int ColorDepth; int AntiAliasingAmount; int AnisotropicLevel; int TextureQuality; int VideoQuality; int Shadows; int PlanarReflections; bool VSync; #ifndef PLASMA_EXTERNAL_RELEASE bool ForceSecondMonitor; #endif // PLASMA_EXTERNAL_RELEASE }; class plDisplayMode { public: int Width; int Height; int ColorDepth; }; class plPipeline : public plCreatable { public: CLASSNAME_REGISTER( plPipeline ); GETINTERFACE_ANY( plPipeline, plCreatable ); // Typical 3D device // // PreRender - fill out the visList with which spans from drawable will be drawn. // visList is write only. On output, visList is UNSORTED visible spans. // Called once per scene render (maybe multiple times per frame). // Returns true if rendering should proceed. virtual bool PreRender(plDrawable* drawable, hsTArray<int16_t>& visList, plVisMgr* visMgr=nil) = 0; // PrepForRender - perform any processing on the drawable data nessecary before rendering. // visList is read only. On input, visList is SORTED visible spans, and is ALL spans which will be drawn this render. // Called once per scene render. // Returns true if rendering should proceed. virtual bool PrepForRender(plDrawable* drawable, hsTArray<int16_t>& visList, plVisMgr* visMgr=nil) = 0; // Render - draw the drawable to the current render target. // visList is read only. On input, visList is SORTED visible spans. May not be the complete list of visible spans // for this drawable. // Called multiple times per scene render e.g.: // Render(drawable0, visList0) // visList0 contains furthest spans in drawable0 // Render(drawable1, visList1) // visList1 contains spans from drawable1 between drawable0's visList0 and visList2 // Render(drawable0, visList2) // visList2 contains closest spans in drawable0. virtual void Render(plDrawable* d, const hsTArray<int16_t>& visList) = 0; // Draw - Convenience wrapper for standalone renders. Calls PreRender, PrepForRender, Render. Currently for internal // use only, but may prove useful for procedurals (render to texture). virtual void Draw(plDrawable* d) = 0; // Device-specific ref creation. Includes buffers and fonts virtual plTextFont *MakeTextFont( char *face, uint16_t size ) = 0; // Create and/or Refresh geometry buffers virtual void CheckVertexBufferRef(plGBufferGroup* owner, uint32_t idx) = 0; virtual void CheckIndexBufferRef(plGBufferGroup* owner, uint32_t idx) = 0; virtual bool OpenAccess(plAccessSpan& dst, plDrawableSpans* d, const plVertexSpan* span, bool readOnly) = 0; virtual bool CloseAccess(plAccessSpan& acc) = 0; virtual void CheckTextureRef(plLayerInterface* lay) = 0; // Default fog settings virtual void SetDefaultFogEnviron( plFogEnvironment *fog ) = 0; virtual const plFogEnvironment &GetDefaultFogEnviron( void ) const = 0; virtual void RegisterLight(plLightInfo* light) = 0; virtual void UnRegisterLight(plLightInfo* light) = 0; enum RenderTargetFlags { kRTMainScreen = 0x0000, kRTOffscreen = 0x0001, kRTTexture = 0x0002, kRTPerspProjected = 0x0004, kRTOrthoProjected = 0x0008, kRTProjected = kRTPerspProjected | kRTOrthoProjected }; enum RenderStateSettings { kRenderNormal = 0x0, kRenderProjection = 0x1, kRenderShadow = 0x2, kRenderBaseLayerOnly = 0x4, kRenderNoPiggyBacks = 0x8, kRenderClearColor = 0x10, kRenderClearDepth = 0x20, kRenderOrthogonal = 0x40, kRenderNoProjection = 0x80, kRenderNoLights = 0x100, kRenderShadowErase = 0x200 }; virtual void PushRenderRequest(plRenderRequest* req) = 0; virtual void PopRenderRequest(plRenderRequest* req) = 0; virtual void ClearRenderTarget( plDrawable* d ) = 0; // nil d reverts to ClearRenderTarget(nil, nil). virtual void ClearRenderTarget(const hsColorRGBA* col = nil, const float* depth = nil) = 0; // col/depth are overrides for current default. virtual void SetClear(const hsColorRGBA* col=nil, const float* depth=nil) = 0; // sets the default clear for current render target. virtual hsColorRGBA GetClearColor() const = 0; virtual float GetClearDepth() const = 0; virtual hsGDeviceRef *MakeRenderTargetRef( plRenderTarget *owner ) = 0; virtual void PushRenderTarget( plRenderTarget *target ) = 0; virtual plRenderTarget *PopRenderTarget( void ) = 0; virtual bool BeginRender() = 0; virtual bool EndRender() = 0; virtual void RenderScreenElements( void ) = 0; virtual bool BeginDrawable(plDrawable* d) = 0; virtual bool EndDrawable(plDrawable* d) = 0; virtual void BeginVisMgr(plVisMgr* visMgr) = 0; virtual void EndVisMgr(plVisMgr* visMgr) = 0; virtual bool IsFullScreen() const = 0; virtual uint32_t Width() const = 0; virtual uint32_t Height() const = 0; virtual uint32_t ColorDepth() const = 0; virtual void Resize( uint32_t width, uint32_t height ) = 0; // Culling. Might be used in Update before bothering to do any serious computation. virtual bool TestVisibleWorld(const hsBounds3Ext& wBnd) = 0; virtual bool TestVisibleWorld(const plSceneObject* sObj) = 0; virtual bool HarvestVisible(plSpaceTree* space, hsTArray<int16_t>& visList) = 0; virtual bool SubmitOccluders(const hsTArray<const plCullPoly*>& polyList) = 0; virtual void SetDebugFlag( uint32_t flag, bool on ) = 0; virtual bool IsDebugFlagSet( uint32_t flag ) const = 0; virtual void SetMaxCullNodes(uint16_t n) = 0; // Debug/analysis only virtual uint16_t GetMaxCullNodes() const = 0; // Debug/analysis only // Properties enum Properties { kPropDontDeleteTextures = 0x00000001 // Keeps the pipeline from deleting textures on // MakeTextureRef, regardless of the kUserOwnsBitmap flag }; virtual bool CheckResources() = 0; // Do we need to call LoadResources? virtual void LoadResources() = 0; virtual void SetProperty( uint32_t prop, bool on ) = 0; virtual bool GetProperty( uint32_t prop ) const = 0; virtual uint32_t GetMaxLayersAtOnce() const = 0; // Drawable type mask virtual void SetDrawableTypeMask( uint32_t mask ) = 0; virtual uint32_t GetDrawableTypeMask( void ) const = 0; virtual void SetSubDrawableTypeMask( uint32_t mask ) = 0; virtual uint32_t GetSubDrawableTypeMask( void ) const = 0; // View state virtual hsPoint3 GetViewPositionWorld() const = 0; virtual hsVector3 GetViewAcrossWorld() const = 0; virtual hsVector3 GetViewUpWorld() const = 0; virtual hsVector3 GetViewDirWorld() const = 0; virtual void GetViewAxesWorld(hsVector3 axes[3] /* ac,up,at */ ) const = 0; virtual void GetFOV(float& fovX, float& fovY) const = 0; virtual void SetFOV(float fovX, float fovY) = 0; virtual void GetSize(float& width, float& height) const = 0; virtual void SetSize(float width, float height) = 0; virtual void GetDepth(float& hither, float& yon) const = 0; virtual void SetDepth(float hither, float yon) = 0; virtual void SetZBiasScale( float scale ) = 0; virtual float GetZBiasScale( void ) const = 0; virtual const hsMatrix44& GetWorldToCamera() const = 0; virtual const hsMatrix44& GetCameraToWorld() const = 0; virtual void SetWorldToCamera(const hsMatrix44& w2c, const hsMatrix44& c2w) = 0; virtual const hsMatrix44& GetWorldToLocal() const = 0; virtual const hsMatrix44& GetLocalToWorld() const = 0; virtual const plViewTransform& GetViewTransform() const = 0; virtual void ScreenToWorldPoint( int n, uint32_t stride, int32_t *scrX, int32_t *scrY, float dist, uint32_t strideOut, hsPoint3 *worldOut ) = 0; virtual void RefreshMatrices( void ) = 0; virtual void RefreshScreenMatrices( void ) = 0; // Overrides, always push returns whatever is necessary to restore on pop. virtual hsGMaterial* PushOverrideMaterial(hsGMaterial* mat) = 0; virtual void PopOverrideMaterial(hsGMaterial* restore) = 0; virtual hsGMaterial* GetOverrideMaterial() const = 0; virtual plLayerInterface* AppendLayerInterface(plLayerInterface* li, bool onAllLayers = false) = 0; virtual plLayerInterface* RemoveLayerInterface(plLayerInterface* li, bool onAllLayers = false) = 0; virtual uint32_t GetMaterialOverrideOn(hsGMatState::StateIdx category) const = 0; virtual uint32_t GetMaterialOverrideOff(hsGMatState::StateIdx category) const = 0; virtual hsGMatState PushMaterialOverride(const hsGMatState& state, bool on) = 0; virtual hsGMatState PushMaterialOverride(hsGMatState::StateIdx cat, uint32_t which, bool on) = 0; virtual void PopMaterialOverride(const hsGMatState& restore, bool on) = 0; virtual const hsGMatState& GetMaterialOverride(bool on) const = 0; virtual hsColorOverride PushColorOverride(const hsColorOverride& over) = 0; virtual void PopColorOverride(const hsColorOverride& restore) = 0; virtual const hsColorOverride& GetColorOverride() const = 0; virtual void SubmitShadowSlave(plShadowSlave* slave) = 0; virtual void SubmitClothingOutfit(plClothingOutfit* co) = 0; // These all return true if the gamma was successfully set. virtual bool SetGamma(float eR, float eG, float eB) = 0; virtual bool SetGamma(const uint16_t* const tabR, const uint16_t* const tabG, const uint16_t* const tabB) = 0; // len table = 256. virtual bool SetGamma(float e) { return SetGamma(e, e, e); } virtual bool SetGamma(const uint16_t* const table) { return SetGamma(table, table, table); } // flipVertical is for the AVI writer, which wants it's frames upside down virtual bool CaptureScreen( plMipmap *dest, bool flipVertical = false, uint16_t desiredWidth = 0, uint16_t desiredHeight = 0 ) = 0; // Returns an un-named (GetKey()==nil) mipmap same dimensions as targ. You are responsible for deleting said mipMap. virtual plMipmap* ExtractMipMap(plRenderTarget* targ) = 0; /// Error handling virtual const char *GetErrorString( void ) = 0; // info about current rendering device virtual void GetSupportedDisplayModes(std::vector<plDisplayMode> *res, int ColorDepth = 32 ) = 0; virtual int GetMaxAnisotropicSamples() = 0; virtual int GetMaxAntiAlias(int Width, int Height, int ColorDepth) = 0; int GetDesktopWidth() { return fDesktopParams.Width; } int GetDesktopHeight() { return fDesktopParams.Height; } int GetDesktopColorDepth() { return fDesktopParams.ColorDepth; } PipelineParams *GetDefaultParams() { return &fDefaultPipeParams; } virtual void ResetDisplayDevice(int Width, int Height, int ColorDepth, bool Windowed, int NumAASamples, int MaxAnisotropicSamples, bool vSync = false ) = 0; static PipelineParams fDefaultPipeParams; static PipelineParams fInitialPipeParams; plDisplayMode fDesktopParams; }; #endif // plPipeline_inc