Subversion Repository Public Repository


This repository has no backups
This repository's network speed is throttled to 100KB/sec

Entry Size Revision Updated
GFXDevice.h 23.4K 712 Tue 24 May, 2016 16:18:37 +0000
GFXDevice.inl 9.7K 670 Wed 06 Apr, 2016 16:21:35 +0000
GFXState.h 3.9K 664 Wed 30 Mar, 2016 16:23:51 +0000
GraphicsResource.h 1.5K 648 Sun 21 Feb, 2016 16:32:52 +0000
IMPrimitive.h 5.5K 703 Wed 11 May, 2016 15:44:57 +0000
OcclusionQuery.h 2K 648 Sun 21 Feb, 2016 16:32:52 +0000
RenderAPIEnums.h 9.7K 652 Thu 25 Feb, 2016 17:13:10 +0000
RenderAPIWrapper.h 16.1K 712 Tue 24 May, 2016 16:18:37 +0000
RenderStateBlock.h 5.2K 703 Wed 11 May, 2016 15:44:57 +0000
ScopedStates.h 2.2K 648 Sun 21 Feb, 2016 16:32:52 +0000

Commits for Divide-Framework/trunk/Source Code/Platform/Video/Headers

Revision Author Commited Message
712 IonutCava picture IonutCava Tue 24 May, 2016 16:18:37 +0000

- Added the concept of “buffer” to be used by GenericVertexData and ShaderBuffer without caring if it’s persistent or not.
— Persistent buffers handle their own locking instead of relying on the parent class
- HiZ occlusion culling fixes and optimizations

710 IonutCava picture IonutCava Fri 20 May, 2016 16:24:40 +0000

- Code cleanup
- Initial work on Scene loading and unloading with and without unloading assets:
— Need to change AIManager from a Singleton to a per-scene component

709 IonutCava picture IonutCava Thu 19 May, 2016 16:21:46 +0000

- Massive rewrite of the resource system:
— ResourceCache now uses a map of weak pointers and passes shared pointers to the call point of CreateResource
— RemoveResource is no longer needed, but resource based smart pointers use a custom deleter that calls unload()
— Keep a shared_ptr of the resource in the entity that needs it and pass shared_ptr references from getter methods
-— All of this removed the need for calls to RemoveResource, REGISTER_TRACKED_DEPENDENCY and UNREGISTER_TRACKED_DEPENDENCY reducing the number of mutex locks and atomic exchanges
- Singleton cleanup:
— Removed ShaderManager singleton and merged it’s data and responsibilities in static methods in both ShaderProgram and Shader classes.
Explanation: Due to the complex interdependency chains in the system, copying, updating, tracking the cache in a thread safe way became a lot more slower than a straight forward smart pointer based implementation. (e.g. scene graph nodes have 3d objects and material instances, 3d objects have materials, materials have textures and shaders, etc)

706 IonutCava picture IonutCava Fri 13 May, 2016 16:29:40 +0000

- Renamed LightManager to LightPool and changed it from a Singleton to a scene specific pointer
- More scene load / unload updates (changing scenes now works properly!)
- Allowed GUI interface to hold per-scene elements and only render relevant ones
- Reduced dependencies between nodes, scenemanager, scene, loaders and kernel
- Removed Reflector base class as it was useless and integrate Water class with the Reflection system already in place
- Extended RenderingComponent’s reflection system to allow refraction as well

703 IonutCava picture IonutCava Wed 11 May, 2016 15:44:57 +0000

- Finish XML-based control bindings:
— Allow per bind input params (key id, mouse button index, joystick control data, etc)
— Allow mouse binding (with up to 7 buttons)
— Allow up to 4 joysticks (for now) with 120+ button, POV, Axis, Slider and Vector binding support for each
- Change all hashes in code from U32 to size_t for compatibility with STL/Boost

698 IonutCava picture IonutCava Mon 09 May, 2016 20:21:34 +0000

- Remove all anaglyph rendering code. nVidia gained 1 sympathy point with me for VRWorks:
— Single Pass Stereo completely removes the need for double rendering the scene for each eye.
— LiquidVR also support similar technology
-— Once VR development starts for Divide, documentation for both SDKs should be pretty sorted.

692 IonutCava picture IonutCava Wed 27 Apr, 2016 16:24:26 +0000

- Resource system cleanup:
— Resource name and resource file location (if any) is now passed only via explicit constructors! (ResourceDescriptors already contain this data, so why use setters?)
- Fix a bug with ortho projection matrix calculation (set m[3][3] to 1. this was skipped when the identity() call was changed to zero() in the ortho() function)
— This also fixed text rendering

689 IonutCava picture IonutCava Fri 22 Apr, 2016 21:12:33 +0000

- More code cleanup (profile timers)
- Changed project build settings for better performance in both Debug and Profile targets

688 IonutCava picture IonutCava Fri 22 Apr, 2016 16:23:33 +0000

- Code cleanup

684 IonutCava picture IonutCava Wed 20 Apr, 2016 16:27:05 +0000

- More math template code cleanup