/// <summary> /// renderoi worldin valosta päin (pelkän depthin) /// </summary> public static void SetupShadows(Renderable world, int lightNo, bool withParticles) { if (UseShadowMapping == false) { return; } if (Light.Lights.Count == 0) { Log.WriteLine("SetupShadows requires at least one light source!", false); return; } GL.Disable(EnableCap.Blend); GL.ColorMask(false, false, false, false); GL.Disable(EnableCap.CullFace); GL.PolygonOffset(1, 1); GL.Enable(EnableCap.PolygonOffsetFill); fbo.BindDepth(); fbo.BindFBO(); fbo.Clear(); // kuvakulma valosta päin GLExt.LoadMatrix(ref Light.Lights[lightNo].OrigOrientationMatrix); GLExt.Translate(-Light.Lights[lightNo].Position.X, -Light.Lights[lightNo].Position.Y, -Light.Lights[lightNo].Position.Z); SetTextureMatrix(); Frustum.CalculateFrustum(); VBO.FastRenderPass = true; depthShader.UseProgram(); world.Render(); if (withParticles) { depthShaderAlphaTest.UseProgram(); Particles.Render(); GLSLShader.UnBindShader(); } VBO.FastRenderPass = false; fbo.UnBindFBO(); GL.Disable(EnableCap.PolygonOffsetFill); GL.Enable(EnableCap.CullFace); GL.ColorMask(true, true, true, true); GLExt.LoadIdentity(); GameClass.NumOfObjects = 0; ShadowMapping.UnBindLightMask(); }
protected override void RenderModel() { GLExt.LoadMatrix(ref Matrix); RenderMesh(); }
/// <summary> /// renderoi partikkelit, sorttaa läpinäkyvät. /// </summary> public static new void Render() { GLExt.Color4(1f, 1, 1, 1f); GLExt.PushMatrix(); GLExt.SetLighting(false); List <SortedList_Particles> slist = new List <SortedList_Particles>(); GL.Disable(EnableCap.CullFace); int c = 0; // järjestetään taulukko kauimmaisesta lähimpään. pitää rendata siinä järjestyksessä. // vain läpikuultavat pitää järjestää. täysin näkyvät renderoidaan samantien. for (int q = 0; q < ParticleGroups.Count; q++) { Particles curpar = ParticleGroups[q]; if (curpar.particles.Count <= 0) { continue; } if (VBO.FastRenderPass == true) { if (curpar.CastShadow == false) { continue; } } curpar.particles[0].partTex.Bind(0); GLExt.PushMatrix(); GLExt.MultMatrix(ref curpar.WorldMatrix); for (int w = 0; w < curpar.NumOfParticles; w++) { Particle p = curpar.particles[w]; GLExt.PushMatrix(); GLExt.Translate(p.pos.X, p.pos.Y, p.pos.Z); Matrix4 matrix = Matrix4.Identity; matrix.Row3 = GLExt.ModelViewMatrix.Row3; GLExt.ModelViewMatrix = matrix; Vector3 v = curpar.WorldMatrix.Row3.Xyz + curpar.Position + p.pos; if (Frustum.SphereInFrustum(v.X, v.Y, v.Z, 10) != 0) { if (VBO.FastRenderPass == true) // renderoi partikkeli depthbufferiin (varjostusta varten) { GLExt.Scale(p.size, p.size, p.size); GLExt.RotateZ(p.zrot); p.partTex.RenderBillboard(); } else { c++; if (p.isTransparent == true) // listaan renderoitavaks myöhemmin { float len = (Camera.cam.Position - matrix.Row3.Xyz).LengthSquared; slist.Add(new SortedList_Particles(len, p, matrix)); } else // rendataan se nyt, ei lisätä sortattavaks { GLExt.Scale(p.size, p.size, p.size); GLExt.RotateZ(p.zrot); GLExt.Color4(p.color.X, p.color.Y, p.color.Z, p.color.W);; if (p.callBack != null) { p.callBack(p); } p.partTex.RenderBillboard(); } } } GLExt.PopMatrix(); } GLExt.PopMatrix(); } if (VBO.FastRenderPass == false) { slist.Sort(delegate(SortedList_Particles z1, SortedList_Particles z2) { return(z2.Len.CompareTo(z1.Len)); }); GL.Enable(EnableCap.Blend); GL.BlendFunc(BlendingFactorSrc.SrcAlpha, BlendingFactorDest.One); // rendataan läpikuultavat GL.DepthMask(false); // ei kirjoiteta zbufferiin for (int q = 0; q < slist.Count; q++) { Particle p = slist[q].Part; if (VBO.FastRenderPass == false) { p.partTex.Bind(0); GLExt.Color4(p.color.X, p.color.Y, p.color.Z, p.color.W); if (p.callBack != null) { p.callBack(p); } } GLExt.LoadMatrix(ref slist[q].Matrix); GLExt.Scale(p.size, p.size, p.size); GLExt.RotateZ(p.zrot); p.partTex.RenderBillboard(); } GL.DepthMask(true); GL.Disable(EnableCap.Blend); } GLExt.PopMatrix(); GL.Enable(EnableCap.CullFace); GLExt.Color4(1, 1, 1, 1); GLExt.SetLighting(true); GameClass.NumOfObjects += c; }
/// <summary> /// käytä esim jos kamera on pathissa /// </summary> public void SetCameraMatrix() { GLExt.LoadMatrix(ref OrigOrientationMatrix); }