Suivi de versions
Cette page sert à informer des évolutions du moteur depuis les premières versions
Version 0.7.0
Modifications
CMake
-
Ajout de la possibilité de changer le dossier des binaires, au travers des variables PROJECTS_BINARIES_OUTPUT_PATH et PROJECTS_BINTEMP_OUTPUT_PATH.
-
Ajout du support d'AStyle, activé via l'option PROJECTS_USE_PRETTY_PRINTING.
-
Utilisation de CPack pour générer le setup WiX (ou DEB), activé via l'option PROJECTS_PACKAGE_WIX (respectivement PROJECTS_PACKAGE_DEB).
-
Ajout de la possibilité d'activer le profileur de code de Visual Studio, avec l'option PROJECTS_PROFILING.
-
Ajout de la possibilité de choisir quels projets du Castor sont à générer (dans le groupe CASTOR).
-
Réorganisation globale de l'arborescence des fichiers
Général
-
Découpe des fichiers afin de n'avoir plus qu'une classe par fichier.
-
Support de la compilation x64.
-
Compabilité avec wxWidgets 2.8 et Linux améliorée.
-
Ajout de fonctions Destroy pour chaque fonction Create dans les plug-ins, afin que la création et la destruction de ceux-ci se fassent dans l'espace mémoire des DLL (pour Windows).
-
Ajout du plug-in d'import ASSIMP, permettant d'élargir le nombre de formats supportés. La fonction ImporterPlugin::GetExtensions permet maintenant de récupérer un tableau de paires <extension, file type>.
CastorUtils
-
Toutes les variables statiques et globales ont été enlevées.
-
Remplacement de la classe String par une classe str_utils.
-
Suppression des dépendances à boost, à part pour thread, et uniquement pour les compilateurs ne supportant pas std::thread.
-
Les macros cstrnlen, cstrftime, cstrncpy, cfopen, cfopen64, cfseek et cftell ont été remplacées par des fonctions dans Castor.
-
Suppression de la macro DECLARE_SHARED_PTR, remplacée par DECLARE_SMART_PTR, et les typedefs XxxPtr ont été remplacés par leurs équivalents XxxSPtr.
-
Suppression de l'encodage Unicode pour les fichiers.
-
Ajout du support de l'indentation de flux.
-
Améliorations de Castor::FileParser :
-
Il peut ignorer des sections de code sans avoir à les commenter (tels que les blocs de shader HLSL alors que le RenderSystem chargé est GlRenderSystem, etc.).
-
Il prend en compte les paramètres des fonctions d'analyse.
-
Les fonctions peuvent maintenant avoir des paramètres, pas uniquement des types de paramètres, et ces paramètres s'analysent eux-mêmes.
-
Réduction de l'occupation mémoire des images.
-
Modification de Castor::Point :
-
les fonctions non dépendantes ont été déplacées dans une classe d'aide : Castor::point. Cette classe contient donc les fonctions normalise, get_normalised, dot, cos_theta, negate et toutes les fonctions de calcul de distance.
-
Suppression des méthodes link, copy/clopy/clone.
-
Il contient maintenant un tableau statique au lieu d'un tableau dynamique.
-
La classe Castor::Colour ne dérive plus de Point4f.
-
La fonction DynamicLibrary::GetFunction a été modifiée, ajout d'un paramètre template, le type de fonction, afin de ne plus avoir de conversions lors de l'utilisation de DynamicLibrary::GetFunction.
-
Ajout du support des niveaux de log pour Castor::Logger.
-
Modifications de Castor::Line3D :
-
Implémentation de la méthode de calcul d'intersection
-
Cette classe a maintenant deux constructeurs nommés : FromPointAndSlope et FromPoints, pour éviter les confusions.
-
Création de deux nouvelles classes : Size et Positionau lieu d'un typedef pour chacune.
-
Création de la classe Castor::Coord pour récupérer les fonctionnalités dynamiques de l'ancien Castor::Point.
Castor3D
-
Ajout des méthodes HasParameter et SetParameter dans la classe ShaderObject, pour appliquer les matrices de la classe Pipeline.
-
Ajout de fonctions Begin et End dans la classe Mesh afin de pouvoir itérer sur les submeshes sans passer par les fonctions GetSubmesh et GetSubmeshCount.
-
Ajout de fonctions Begin et End dans la classe Material functions Begin and End.
-
Ajout de la classe FrameVariableBuffer pour gérer les variables uniformes avec les UBO OpenGL ou les Constant buffer de Direct3D 11.
-
Ajout de la classe DepthStencilState pour gérer ces états à la mode Direct3D 11 (qui fait ça bien).
-
De même, ajout des classes BlendState et RasteriserState.
-
Création des classes TextureBase, StaticTexture et DynamicTexture pour faciliter l'implémentation des cibles de rendu.
-
Ajout de canaux pour les textures (couleur, ambiante, diffusion, speculaire, normale, hauteur, brillance).
-
Création de la classe TechniqueParameters pour passer des paramètres spécifiques aux techniques comme, par exemple, le nombre d'échantillons (pour le MSAA).
-
Introduction de la classe SamplerState pour grouper les appels à SetSamplerState et autres.
-
Implémentation des Frame Buffers.
-
Réduction de l'occupation mémoire des tampons de sommets.
-
Modification de BufferElementGroup afin qu'il ne puisse plus contenir son tampon.
-
La classe Overlay n'étend plus Renderable, il n'y a plus qu'une instance de OverlayRenderer, gérée par la classe OverlayManager. Toutes les incrustations sont maintenant rendues via cette instance.
-
Amélioration de l'occupation mémoire : diminution drastique de la taille d'un Vertex (de 152 à 24 octets) et d'une Face (de 140 à 16 octets).
-
Modification de Subdivision, elle se trouve maintenant uniquement dans Subdivider et plus dans Geometry, Mesh ou Submesh.
-
Les lumières sont maintenant implémentées dans une texture, passant la limite de 8 à 100 sources.
-
Suppression des méthodes ApplyXXXMatrix de la classe IPipelineImpl, maintenant la classe Pipeline applique les matrices elle-même.
-
Implémentation du MSAA.
-
Implémentation de l'Alpha to Coverage lorsque le MSAA est activé.
-
Revue des tailles : Viewport contient la taille interne, RenderTarget et RenderWindow contiennent la taille externe.
-
Découpe de eBUFFER_MODE en eBUFFER_ACCESS_TYPE et eBUFFER_ACCESS_NATURE.
-
L'initialisation des objets GPU se passe maintenant avec l'utilisation de deux évènements : InitialiseEvent et CleanupEvent.
-
Fusion de GpuBuffer::Initialise et GpuBuffer::SetShaderProgram afin d'en simplifier l'utilisation.
-
Suppression de la génération automatique des mipmaps. Maintenant, si l'utilisateur vuet les générer, il utilise la fonction DynamicTexture::GenerateMipmaps.
-
Implémentation de l'instanciation hardware des maillages.
-
Modifications de Castor3D::Submesh :
-
Les classes Submesh et SmoothingGroup ont été fusionnées.
-
Modification de la méthode ComputeTangents pour prendre en compte les normales des sommets.
-
Ajout d'un overload pour la méthode AddPoints afin de pouvoir lui donner un stVERTEX_GROUP en paramètre.
-
Modification de la génération des normales.
-
Déplacement des matériaux, de Submesh à Geometry.
-
Modification du compte des instances, pour le rendre spécifique aux matériaux utilisés par les instances du Submesh.
-
Modifications de Castor3D::Pass :
-
Création d'une fonction Pass::Initialise afin que les shaders ne soient initialisés qu'une fois, et pas à chaque frame.
-
Réorganisation des unités de texture des passes, afin que celles associées à un canal arrivent premières.
-
Ajout d'une instance de BlendState dans la classe Pass et suppression de la gestion du mélange RGB/Alpha de la classe Pass.
-
Modifications de Castor3D::Scene :
-
Ajout de la possibilité d'activer ou désactiver le deferred rendering, option disponible dans les fichier cscn.
-
Ajout de fonctions templates pour ajouter, supprimer ou récupérer un objet quel que soit son type (Light, Geometry, Camera, SceneNode).
-
Les Submesh sont maintenant triés en fonction du matériau appliqué afin de pouvoir, entre autres, rendre les sous-maillages avec transparence après les autres.
-
Modifications de Castor3D::RenderTarget :
-
Modifié RenderTarget : elle contient maintenant son frame buffer et ce qui s'y rattache. C'est maintenant un Renderable et un TargetRenderer a donc été créé.
-
RenderTarget utilise maintenant RenderTechnique pour effectuer son rendu.
-
Modifications de Castor3D::RenderWindow :
-
RenderWindow n'étend plus RenderTarget, mais en a un en membre privé.
-
Création d'une méthode WindowRenderer::EndScene pour préparer le rendu du frame buffer de la RenderTarget dans la fenêtre.
-
Modifications des shaders :
-
Suppression des appels à ShaderObject afin d'en faire une classe interne à Castor3D.
-
Modification des shaders, ils prennent maintenant en compte le modèle de shader, contiennent tous les fichiers et sources définis par modèle. Le choix du modèle est fait à la compilation, en choisissant le modèle le plus haut supporté.
-
Modification des sources par défaut pour les shaders. Elles sont maitenant générées automatiquement et plus aucun fichier externe n'est nécessaire.
-
Modification de FrameVariable afin de prendre en compte eFRAME_VARIABLE_TYPE.
-
Modifications de Castor3D::Context
-
Suppression des méthodes Context::Enable et Context::Disable, suppression de la classe RenderState.
-
Suppression de la méthode Context::SetPolygonMode.
GlRenderSystem
-
Création de la classe GeometryBuffers pour gérer les Vertex Array Objects. Ils contiennent maintenant leurs tampons, permettant d'intégrer le choix d'utiliser les VAO ou non.
-
Les Geometry shader fonctionnent dans GlRenderSystem.
-
Suppression de la dépendance à GLEW.
-
Support des extensions de debug d'OpenGL.
-
Ajout du support de GL_MIRRORED_REPEAT.
-
Ajout du support de GL_TEXTURE_MAX_ANISOTROPY.
GuiCommon
-
Maintenant ShaderDialog utilise wxSizers.
-
Utilisation de wxStcEditor pour l'édition de shaders.
-
La fenêtre de matériaux utilise les wxSizers pour placer et redimensionner les éléments.
-
Ajout de la possibilité de changer le matériau utilisé par un sous-maillage, avec la fenêtre wxGeometriesListFrame.
-
Correction de bugs dans le chargement des images.
-
Amélioration de StcTextEditor afin d'avoir une meilleure coloration syntaxique.
CastorViewer
-
Maintenant, MainFrame utilise wxSizers.
-
Ajout d'options de ligne de commande :
-
-f/–file pour charger un fichier de scène au chargement
-
-h/–help pour afficher une aide
-
-l/–level pour définir le niveau de log :
-
- 0 pour logger debug, infos, warnings et erreurs
-
- 1 pour logger infos, warnings et erreurs
-
- 2 pour logger warnings et erreurs
-
- 3 pour logger les erreurs uniquement.
-
Maintenant les plug-ins sont chargés dans un thread
-
Ajout d'un bouton "Export".
Corrections
General
-
Modification des importeurs afin de ne plus avoir de fuites de mémoires détectées par Visual Studio.
CastorUtils
-
Castor::Image a été modifiée, j'ai retiré la possibilité de charger les images par handle, car cela provoquait des problèmes avec FreeImage sur certains formats.
-
Réparation d'un problème de matrices lors du rendu des incrustations.
-
Correction des transformations récursives.
Castor3D
-
Corrections des sous-maillages ayant un matériau transparent, car ils n'étaient pas affichés.
-
Corrigé la génération de mipmaps.
CastorViewer
-
Déplacement de la destruction de m_pCastor3D dans la méthode OnDestroy.
GlRenderSystem
-
Correction d'un bug dans DoGetDeferredShaderSource.
-
Correction de la génération des mipmaps dans les classes GlStaticTexture et GlDynamicTexture.
-
Correction du traitement des textures de brillance dans les programmes GLSL auto générés.
ObjImporter
-
L'import des matériaux et textures a été corrigé.
Version 0.6.1.2
Ajouts
-
Création du renderer Dx9Renderer, pour le rendu sous Direct3D 9. Il reste des choses à régler, notamment au niveau shaders et matrices, mais l'essentiel est là.
-
Création de différents fichiers pour les contextes OpenGL (X11, Gtk, Msw), je n'ai pas encore pu tester ça correctement, mes drivers ATI ayant tué OpenGL sur ma Debian (snif...).
-
Création d'une boîte de dialogue de sélection de renderer au lancement de CastorViewer, CastorShape et CastorArchitect, ajout d'un splash screen pour ces 3 applis.
-
Ajout d'une petite appli qui transforme n'inmporte quel type d'image en XPM, plus facile pour le développement multiplateforme avec wxWidgets.
-
Ajout de nouvelles fonctionnalités aux fichiers de scène (alpha_rejection, rgb_blend, alpha_blend, hl_shader_program, ...)
Modifications
-
Optimisation du fichier CMakeLists et des fichiers du dossier 'cmake_modules' de façon à mieux prendre en charge les différentes plateformes, ainsi que les différentes configurations des PC clients.
-
Revue du système de VertexBuffers et IndexBuffers, in troduction de la notion de VertexDeclaration et BufferElementGroup, ainsi on peut créer des VertexBuffers en mettant à peu près ce que l'on veut comme données dedans (parmi vertex, normals, tangents, diffuse, texcoords0,1,2,3) et ordonnées comme on veut.
-
La classe Vertex dérive donc maintenant de BufferElementGroup.
-
Les TextureEnvironment vont disparaitre à la prochaine version, la gestion du multitexturing se faisant maintenant directement au niveau des passes et des texture units.
-
Suppression des fonctions issues de GLU, afin d'avoir une librairie de moins à linker.
Bugs
-
Problème avec les matrices pour DxRenderSystem (je pense à la différence right-handed / left-handed, mais mes premiers tests à ce niveau ne sont pas concluants).
-
Problème avec les shaders HLSL, je n'ai pour l'instant pas d'affichage, je pense que c'est lié aux problèmes de matrices que je rencontre avec Direct3D.
-
Je n'ai pas avancé sur les shaders Cg et ai donc toujours les mêmes problèmes qu'auparavant.
Version 0.6.1.1
Ajouts
-
Création d'un fichier CMakeLists pour générer la solution à partir de CMake.
-
Réorganisation des fichiers du dossier afin de mieux se prêter à ça.
-
Séparation de la classe Plugin en 3 types différents : Renderer, Divider et Importer. Ainsi on pourra ajouter de nouveaux types de plugin aisément et l'ajout d'importers et de subdiviseurs se fera sans devoir recompiler tous les projets.
-
Ca entraîne la création d'un projet par importeur existant (OBJ, PLY, MD2, MD3, 3DS, ...)
-
PNTrianglesDivider reste dans le Castor car utilisé par la primitive Icosahedron, LoopDivider est quand à lui placé dans un plugin.
-
J'ai commencé à implémenter les shaders Cg. Ca implique une modification des fichiers de scène, car dans Cg les variables uniform sont liées à un programme (vertex, pixel, geometry) plutôt qu'au shader complet comme c'est le cas en GLSL. Il reste quelques trucs à revoir (je ne sais pas encore quoi) pour que ça fonctionne.
Modifications
-
Suppression de FreeImagePlus, maintenant les projets ne nécessitent plus que FreeImage.
-
La création des tampons utilisés pour le rendu (Vertex, Attribute, Texture, Normals, ...) se fait maintenant par le RenderSystem => on peut donc les créer dans Castor3D et pas seulement dans les renderer (GL2, GL3 et dans le futur D3D).
-
Suppression des Singletons pour les différents Managers (Image, Font, Scene, Material, Animation et Mesh).
-
J'ai retouché les SceneNodes, j'ai refusionné les 3 classes différentes en une seule pour des commodités d'utilisation.
-
Création d'une classe IdPoint, qui étend Point et y ajoute un Index qui correspond à son index dans le submesh. La fonction AddPoint de Submesh crée maintenant des IdPoint et la fonction AddFace se sert d'eux pour générer les Vertex.
-
Les subdiviseurs peuvent subdiviser dans un thread à part, permettant de ne pas figer une application pendant la subdivision (cf. CastorShape). Il est possible d'assigner une fonction qui sera lancée à la fin de la subdivision (cf. CastorShape).
Corrections
-
Correction du LoopDivider qui ne repositionnait plus les Vertex (les nouveaux étaient créés mais plus replacés, dû à la nouvelle architecture des Vertex)
Version 0.6.1.0
Ajouts
-
Utilisation des smart pointers tr1.
-
Création d'un tronc commun 'OpenGLCommon' pour les 2 renderers OpenGL
-
Création d'une classe de Pipeline qui effectue les calculs matriciels et d'autres petites fonctions (perspective, ortho, ...)
Modifications
-
Le MemoryManager (activé uniquement en debug) a été modifié, ajout d'une classe template MemoryTraced qui surcharge les operateurs new, delete new [] et delete [], ce afin d'avoir une meilleure trace des objets créés et détruits. Chaque classe des projets du Castor dérivent maintenant de celle-ci, et 3 fichiers sont donc créés dans le répertoire racine (C:\ sous Windows) : memoryleaks.log, memoryalloc.log et memorydealloc.log
-
La classe TransformationMatrix n'existe plus, il ne s'agit plus que d'une collection de fonctions sur matrices carrées 4x4.
-
Modification de la gestion des SceneNode : Une classe de base NodeBase qui contient les informations qui se trouvaient dans SceneNode, 3 classes dérivées (GeometryNode, CameraNode et LightNode) qui s'occupent des fonctionnalités spécifiques au rendu de chacun des types liés (respectivement Geometry, Camera et Light).
-
La classe MovableObject a maintenant moins de fonctionnalités (en fait elle n'a plus qu'un nom et un NodeBase) et les classes Light et Camera dérivent maintenant de cette classe (pour plus d'uniformité dans les déplacements de ces objets par rapport aux géométries)
-
Renommage des classes UniformVariable en FrameVariable, pour refléter plus ce que c'est et moins lier ce genre de choses à OpenGL.
-
Le module OpenGL 3.x/4.x est achevé.
-
Modifier la structure des vertex de façon à ce qu'ils incluent les coordonnées de texture et les normales directement, de façon à n'avoir qu'1 buffer de vertex par mesh au lieu de 3 actuellement.
Corrections
-
Correction du plantage à la fermeture du soft en release uniquement.
-
Correction du rendu noir avec OpenGL 3.x, corrigé je ne sais trop comment, mais grâce à la suppression progressive du pipeline fixe en OpenGL 2.x
Version 0.6.0.0
Ajouts
-
Ajout d'une classe de gestion des matrices de projection, normale et visualisation, en vue de la suppression du pipeline fixe dans les renderers OpenGL.
-
Ajout de smart pointers persos, inspirés de ceux de boost.
-
Ajout d'une classe de gestion des angles, permettant de ne pas s'embeter avec les conversions radian-degrés.
-
Ajout d'une classe de gestion de path, permettant de gérer les slash ou anti-slash selon l'OS.
-
Création de conteneurs thread-safe issus de la stl (vector, list, map, multimap, set).
-
Séparation du renderer OpenGL en 2 projets : un compatible OpenGL 2.x et antérieur (GL2RenderSystem) le second compatible OpenGL3.x et ultérieur (GL3RenderSystem).
-
GL2RenderSystem : en fonction du PC client, suppression du pipeline fixe ou pas (si l'utilisation des shaders est permise le pipeline fixe est supprimé, sinon il est gardé)
Modifications
-
Modification de la gestion des threads et mutexes, permettant le choix de ceux qu'on utilise (Win32, MFC ou boost).
-
Modification des classes de gestion des matrices et points.
-
Modification de la classe de gestion des chaînes de caractères qui sont maintenant indépendantes de Unicode ou MultiByte.
-
Modification de la classe de gestion de fichiers qui ne permet plus le choix IO ou Stream mais utilise Stream uniquement.
-
Modification du render system, ajout d'une classe renderable qui se charge de créer le renderer associé, afin de simplifier la création des dérivés de cette classe (submesh, scene node, light, camera...)
-
Changement des noms des fichiers de scène/materiaux/meshes du moteur (respectivement cscn/cmtl/cmsh)
Corrections
-
Protection par recursive mutex des données partagées (par les managers, essentiellement) permettant d'éviter des plantages aléatoires.
A faire
-
Il reste un plantage à la fermeture du soft en release uniquement, apparemment dû aux shaders.
-
Pour GL3RenderSystem, j'ai un rendu noir (?!?) mais les transformations sont prises en compte correctement.
Version 0.5.0.1
Ajouts
-
Dans cette version l'espace tangent est calculé et est disponible dans les shaders GLSL.
-
Seule la tangente est calculée, la bitangente pouvant l'être dans le shader avec un produit vectoriel entre la tangente et la normale.
-
Pour accéder à la tangente, il suffit de déclarer l'attribut suivant dans le vertex shader :
-
attribute vec3 tangent;
Modifications
-
Les différentes classes de point (2D, 3D, 4D) ont leur membres en union, ce qui permet de personnaliser l'appel de ces membres. Ainsi un point 2D a comme membres (x, y) ou (u, v). Un point 3D a comme membres (x, y, z) ou (u, v, w) ou (r, g, b). Un point 4D a comme membres (x, y, z, w) ou (r, g, b, a) ou (left, top, right, bottom).
Corrections
-
Correction du plantage à la fermeture de l'application lors de la suppression des VBOs. J'ai intégré un buffer manager qui les supprime pendant une boucle d'affichage.