CamelotClient.cpp 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. // CamelotClient.cpp : Defines the entry point for the console application.
  2. //
  3. #include "stdafx.h"
  4. #include "CmApplication.h"
  5. #include "CmDynLibManager.h"
  6. #include "CmGameObject.h"
  7. #include "CmCamera.h"
  8. #include "CmHighLevelGpuProgramManager.h"
  9. #include "CmRenderSystem.h"
  10. #include "CmRenderWindow.h"
  11. #include "CmResources.h"
  12. #include "CmRenderable.h"
  13. #include "CmMaterial.h"
  14. #include "CmShader.h"
  15. #include "CmTechnique.h"
  16. #include "CmPass.h"
  17. #include "CmImporter.h"
  18. #include "CmMesh.h"
  19. #include "CmDebugCamera.h"
  20. using namespace CamelotEngine;
  21. int _tmain(int argc, _TCHAR* argv[])
  22. {
  23. gApplication().startUp("CamelotGLRenderSystem", "CamelotForwardRenderer");
  24. //gApplication().startUp("CamelotD3D9RenderSystem", "CamelotForwardRenderer");
  25. RenderSystem* renderSystem = RenderSystem::instancePtr();
  26. RenderWindowPtr renderWindow = gApplication().getPrimaryRenderWindow();
  27. GameObjectPtr cameraGO = GameObject::create("MainCamera");
  28. CameraPtr camera = cameraGO->addComponent<Camera>();
  29. camera->init(renderWindow, 0.0f, 0.0f, 1.0f, 1.0f, 0);
  30. cameraGO->setPosition(Vector3(0,50,1240));
  31. cameraGO->lookAt(Vector3(0,50,-300));
  32. camera->setNearClipDistance(5);
  33. camera->setAspectRatio(800.0f / 600.0f);
  34. std::shared_ptr<DebugCamera> debugCamera = cameraGO->addComponent<DebugCamera>();
  35. GameObjectPtr testModelGO = GameObject::create("TestMesh");
  36. RenderablePtr testRenderable = testModelGO->addComponent<Renderable>();
  37. HighLevelGpuProgramPtr fragProg;
  38. HighLevelGpuProgramPtr vertProg;
  39. /////////////////// HLSL SHADERS //////////////////////////
  40. //String fragShaderCode = "sampler2D tex; \
  41. // float4 ps_main(float2 uv : TEXCOORD0) : COLOR0 \
  42. // { \
  43. // float4 color = tex2D(tex, uv); \
  44. // return color; \
  45. // }";
  46. //fragProg = HighLevelGpuProgram::create(fragShaderCode, "ps_main", "hlsl", GPT_FRAGMENT_PROGRAM, GPP_PS_2_0);
  47. //String vertShaderCode = "float4x4 matViewProjection; \
  48. // void vs_main( \
  49. // float4 inPos : POSITION, \
  50. // float2 uv : TEXCOORD0, \
  51. // out float4 oPosition : POSITION, \
  52. // out float2 oUv : TEXCOORD0) \
  53. // { \
  54. // oPosition = mul(matViewProjection, inPos); \
  55. // oUv = uv; \
  56. // }";
  57. //vertProg = HighLevelGpuProgram::create(vertShaderCode, "vs_main", "hlsl", GPT_VERTEX_PROGRAM, GPP_VS_2_0);
  58. /////////////////// CG SHADERS //////////////////////////
  59. //String fragShaderCode = "sampler2D tex; \
  60. // float4 ps_main(float2 uv : TEXCOORD0) : COLOR0 \
  61. // { \
  62. // float4 color = tex2D(tex, uv); \
  63. // return color; \
  64. // }";
  65. //fragProg = HighLevelGpuProgram::create(fragShaderCode, "ps_main", "cg", GPT_FRAGMENT_PROGRAM, GPP_PS_2_0);
  66. //String vertShaderCode = "float4x4 matViewProjection; \
  67. // void vs_main( \
  68. // float4 inPos : POSITION, \
  69. // float2 uv : TEXCOORD0, \
  70. // out float4 oPosition : POSITION, \
  71. // out float2 oUv : TEXCOORD0) \
  72. // { \
  73. // oPosition = mul(matViewProjection, inPos); \
  74. // oUv = uv; \
  75. // }";
  76. //vertProg = HighLevelGpuProgram::create(vertShaderCode, "vs_main", "cg", GPT_VERTEX_PROGRAM, GPP_VS_2_0);
  77. ///////////////// GLSL SHADERS ////////////////////////////
  78. String fragShaderCode = "uniform sampler2D tex; \
  79. void main() \
  80. {\
  81. vec4 texColor = texture2D(tex,gl_TexCoord[0].st);\
  82. gl_FragColor = texColor; \
  83. }";
  84. fragProg = HighLevelGpuProgram::create(fragShaderCode, "main", "glsl", GPT_FRAGMENT_PROGRAM, GPP_PS_2_0);
  85. // TODO - Ogres GLSL parsing requires some strict parameter naming, can that be avoided?
  86. String vertShaderCode = "uniform mat4 matViewProjection; \
  87. attribute vec4 vertex; \
  88. void main() \
  89. { \
  90. gl_TexCoord[0] = gl_MultiTexCoord0; \
  91. gl_Position = matViewProjection * vertex; \
  92. }";
  93. vertProg = HighLevelGpuProgram::create(vertShaderCode, "main", "glsl", GPT_VERTEX_PROGRAM, GPP_VS_2_0);
  94. HighLevelGpuProgramHandle vertProgRef(vertProg);
  95. gResources().create(vertProgRef, "C:\\vertProgCg.vprog", true);
  96. vertProgRef = static_resource_cast<HighLevelGpuProgram>(gResources().load("C:\\vertProgCg.vprog"));
  97. HighLevelGpuProgramHandle fragProgRef(fragProg);
  98. gResources().create(fragProgRef, "C:\\fragProgCg.vprog", true);
  99. fragProgRef = static_resource_cast<HighLevelGpuProgram>(gResources().load("C:\\fragProgCg.vprog"));
  100. ShaderPtr testShader = ShaderPtr(new Shader("TestShader"));
  101. TechniquePtr newTechniqueGL = testShader->addTechnique("GLRenderSystem", "ForwardRenderer");
  102. PassPtr newPassGL = newTechniqueGL->addPass();
  103. newPassGL->setVertexProgram(vertProgRef);
  104. newPassGL->setFragmentProgram(fragProgRef);
  105. // TODO - I need to create different techniques for different render systems (and renderers, if there were any),
  106. // which is redundant as some techniques can be reused. I should add a functionality that supports multiple
  107. // render systems/renderers per technique
  108. TechniquePtr newTechniqueDX = testShader->addTechnique("D3D9RenderSystem", "ForwardRenderer");
  109. PassPtr newPassDX = newTechniqueDX->addPass();
  110. newPassDX->setVertexProgram(vertProgRef);
  111. newPassDX->setFragmentProgram(fragProgRef);
  112. MaterialHandle testMaterial = MaterialPtr(new Material());
  113. testMaterial->setShader(testShader);
  114. /*TextureRef testTex = static_resource_cast<Texture>(Importer::instance().import("C:\\ImportTest.tga"));*/
  115. TextureHandle testTex = static_resource_cast<Texture>(Importer::instance().import("C:\\ArenaTowerDFS.psd"));
  116. MeshHandle dbgMesh = static_resource_cast<Mesh>(Importer::instance().import("C:\\X_Arena_Tower.FBX"));
  117. //int tmpFlag = _CrtSetDbgFlag( _CRTDBG_ALLOC_MEM_DF | _CRTDBG_CHECK_CRT_DF | _CRTDBG_DELAY_FREE_MEM_DF);
  118. gResources().create(testTex, "C:\\ExportTest.tex", true);
  119. gResources().create(dbgMesh, "C:\\ExportMesh.mesh", true);
  120. testTex = static_resource_cast<Texture>(gResources().load("C:\\ExportTest.tex"));
  121. dbgMesh = static_resource_cast<Mesh>(gResources().load("C:\\ExportMesh.mesh"));
  122. testMaterial->setTexture("tex", testTex);
  123. gResources().create(testMaterial, "C:\\ExportMaterial.mat", true);
  124. testMaterial = gResources().load("C:\\ExportMaterial.mat");
  125. //_ASSERT(_CrtCheckMemory());
  126. testRenderable->setMesh(dbgMesh);
  127. testRenderable->setMaterial(testMaterial);
  128. //// Set the new state for the flag
  129. //_CrtSetDbgFlag( tmpFlag );
  130. gApplication().runMainLoop();
  131. gApplication().shutDown();
  132. return 0;
  133. }