mirror of
				https://github.com/AxioDL/metaforce.git
				synced 2025-10-26 20:10:25 +00:00 
			
		
		
		
	Merge pull request #310 from lioncash/table
CFluidPlane: Make use of std::array where applicable
This commit is contained in:
		
						commit
						594fe2fcbd
					
				| @ -83,8 +83,7 @@ void CFluidPlane::AddRipple(const CRipple& ripple, const CScriptWater& water, CS | |||||||
|   mgr.GetFluidPlaneManager()->RippleManager().AddRipple(ripple); |   mgr.GetFluidPlaneManager()->RippleManager().AddRipple(ripple); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CFluidPlane::RenderStripWithRipples(float curY, const CFluidPlaneRender::SHFieldSample (&heights)[46][46], | void CFluidPlane::RenderStripWithRipples(float curY, const Heights& heights, const Flags& flags, int startYDiv, | ||||||
|                                          const u8 (&flags)[9][9], int startYDiv, |  | ||||||
|                                          const CFluidPlaneRender::SPatchInfo& info, |                                          const CFluidPlaneRender::SPatchInfo& info, | ||||||
|                                          std::vector<CFluidPlaneShader::Vertex>& vOut, |                                          std::vector<CFluidPlaneShader::Vertex>& vOut, | ||||||
|                                          std::vector<CFluidPlaneShader::PatchVertex>& pvOut) { |                                          std::vector<CFluidPlaneShader::PatchVertex>& pvOut) { | ||||||
| @ -310,8 +309,7 @@ void CFluidPlane::RenderStripWithRipples(float curY, const CFluidPlaneRender::SH | |||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CFluidPlane::RenderPatch(const CFluidPlaneRender::SPatchInfo& info, | void CFluidPlane::RenderPatch(const CFluidPlaneRender::SPatchInfo& info, const Heights& heights, const Flags& flags, | ||||||
|                               const CFluidPlaneRender::SHFieldSample (&heights)[46][46], const u8 (&flags)[9][9], |  | ||||||
|                               bool noRipples, bool flagIs1, std::vector<CFluidPlaneShader::Vertex>& vOut, |                               bool noRipples, bool flagIs1, std::vector<CFluidPlaneShader::Vertex>& vOut, | ||||||
|                               std::vector<CFluidPlaneShader::PatchVertex>& pvOut) { |                               std::vector<CFluidPlaneShader::PatchVertex>& pvOut) { | ||||||
|   if (noRipples) { |   if (noRipples) { | ||||||
|  | |||||||
| @ -1,6 +1,7 @@ | |||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #include <algorithm> | #include <algorithm> | ||||||
|  | #include <array> | ||||||
| #include <cmath> | #include <cmath> | ||||||
| #include <optional> | #include <optional> | ||||||
| #include <vector> | #include <vector> | ||||||
| @ -116,6 +117,10 @@ public: | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class CFluidPlane { | class CFluidPlane { | ||||||
|  | public: | ||||||
|  |   using Flags = std::array<std::array<u8, 9>, 9>; | ||||||
|  |   using Heights = std::array<std::array<CFluidPlaneRender::SHFieldSample, 46>, 46>; | ||||||
|  | 
 | ||||||
| protected: | protected: | ||||||
|   CAssetId x4_texPattern1Id; |   CAssetId x4_texPattern1Id; | ||||||
|   CAssetId x8_texPattern2Id; |   CAssetId x8_texPattern2Id; | ||||||
| @ -135,12 +140,12 @@ protected: | |||||||
|   float ProjectRippleVelocity(float baseI, float velDot) const; |   float ProjectRippleVelocity(float baseI, float velDot) const; | ||||||
|   float CalculateRippleIntensity(float baseI) const; |   float CalculateRippleIntensity(float baseI) const; | ||||||
| 
 | 
 | ||||||
|   virtual void RenderStripWithRipples(float curY, const CFluidPlaneRender::SHFieldSample (&heights)[46][46], |   virtual void RenderStripWithRipples(float curY, const Heights& heights, const Flags& flags, int startYDiv, | ||||||
|                                       const u8 (&flags)[9][9], int startYDiv, const CFluidPlaneRender::SPatchInfo& info, |                                       const CFluidPlaneRender::SPatchInfo& info, | ||||||
|                                       std::vector<CFluidPlaneShader::Vertex>& vOut, |                                       std::vector<CFluidPlaneShader::Vertex>& vOut, | ||||||
|                                       std::vector<CFluidPlaneShader::PatchVertex>& pvOut); |                                       std::vector<CFluidPlaneShader::PatchVertex>& pvOut); | ||||||
|   void RenderPatch(const CFluidPlaneRender::SPatchInfo& info, const CFluidPlaneRender::SHFieldSample (&heights)[46][46], |   void RenderPatch(const CFluidPlaneRender::SPatchInfo& info, const Heights& heights, const Flags& flags, | ||||||
|                    const u8 (&flags)[9][9], bool noRipples, bool flagIs1, std::vector<CFluidPlaneShader::Vertex>& vOut, |                    bool noRipples, bool flagIs1, std::vector<CFluidPlaneShader::Vertex>& vOut, | ||||||
|                    std::vector<CFluidPlaneShader::PatchVertex>& pvOut); |                    std::vector<CFluidPlaneShader::PatchVertex>& pvOut); | ||||||
| 
 | 
 | ||||||
| public: | public: | ||||||
|  | |||||||
| @ -110,14 +110,15 @@ void CFluidPlaneCPU::CalculateLightmapMatrix(const zeus::CTransform& areaXf, con | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static bool sSineWaveInitialized = false; | static bool sSineWaveInitialized = false; | ||||||
| static float sGlobalSineWave[256] = {}; | static CFluidPlaneCPU::SineTable sGlobalSineWave{}; | ||||||
| static const float* InitializeSineWave() { | static void InitializeSineWave() { | ||||||
|   if (sSineWaveInitialized) |   if (sSineWaveInitialized) { | ||||||
|     return sGlobalSineWave; |     return; | ||||||
|   for (int i = 0; i < 256; ++i) |   } | ||||||
|     sGlobalSineWave[i] = std::sin(2.f * M_PIF * (i / 256.f)); |   for (size_t i = 0; i < sGlobalSineWave.size(); ++i) { | ||||||
|  |     sGlobalSineWave[i] = std::sin(2.f * M_PIF * (float(i) / 256.f)); | ||||||
|  |   } | ||||||
|   sSineWaveInitialized = true; |   sSineWaveInitialized = true; | ||||||
|   return sGlobalSineWave; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #define kEnableWaterBumpMaps true | #define kEnableWaterBumpMaps true | ||||||
| @ -303,8 +304,7 @@ bool CFluidPlaneCPU::PrepareRipple(const CRipple& ripple, const CFluidPlaneRende | |||||||
|   return !(rippleOut.x14_gfromX > rippleOut.x18_gtoX || rippleOut.x1c_gfromY > rippleOut.x20_gtoY); |   return !(rippleOut.x14_gfromX > rippleOut.x18_gtoX || rippleOut.x1c_gfromY > rippleOut.x20_gtoY); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CFluidPlaneCPU::ApplyTurbulence(float t, CFluidPlaneRender::SHFieldSample (&heights)[46][46], | void CFluidPlaneCPU::ApplyTurbulence(float t, Heights& heights, const Flags& flags, const SineTable& sineWave, | ||||||
|                                      const u8 (&flags)[9][9], const float sineWave[256], |  | ||||||
|                                      const CFluidPlaneRender::SPatchInfo& info, |                                      const CFluidPlaneRender::SPatchInfo& info, | ||||||
|                                      const zeus::CVector3f& areaCenter) const { |                                      const zeus::CVector3f& areaCenter) const { | ||||||
|   if (!HasTurbulence()) { |   if (!HasTurbulence()) { | ||||||
| @ -334,9 +334,8 @@ void CFluidPlaneCPU::ApplyTurbulence(float t, CFluidPlaneRender::SHFieldSample ( | |||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CFluidPlaneCPU::ApplyRipple(const CFluidPlaneRender::SRippleInfo& rippleInfo, | void CFluidPlaneCPU::ApplyRipple(const CFluidPlaneRender::SRippleInfo& rippleInfo, Heights& heights, Flags& flags, | ||||||
|                                  CFluidPlaneRender::SHFieldSample (&heights)[46][46], u8 (&flags)[9][9], |                                  const SineTable& sineWave, const CFluidPlaneRender::SPatchInfo& info) const { | ||||||
|                                  const float sineWave[256], const CFluidPlaneRender::SPatchInfo& info) const { |  | ||||||
|   float lookupT = 256.f * |   float lookupT = 256.f * | ||||||
|                   (1.f - rippleInfo.x0_ripple.GetTime() * rippleInfo.x0_ripple.GetOOTimeFalloff() * |                   (1.f - rippleInfo.x0_ripple.GetTime() * rippleInfo.x0_ripple.GetOOTimeFalloff() * | ||||||
|                              rippleInfo.x0_ripple.GetOOTimeFalloff()) * |                              rippleInfo.x0_ripple.GetOOTimeFalloff()) * | ||||||
| @ -409,8 +408,9 @@ void CFluidPlaneCPU::ApplyRipple(const CFluidPlaneRender::SRippleInfo& rippleInf | |||||||
| 
 | 
 | ||||||
|             float divDist = (divDistSq != 0.f) ? std::sqrt(divDistSq) : 0.f; |             float divDist = (divDistSq != 0.f) ? std::sqrt(divDistSq) : 0.f; | ||||||
|             if (u8 rippleV = CFluidPlaneManager::RippleValues[lifeIdx][int(divDist * distFalloff)]) { |             if (u8 rippleV = CFluidPlaneManager::RippleValues[lifeIdx][int(divDist * distFalloff)]) { | ||||||
|               heights[k][l].height += rippleV * rippleInfo.x0_ripple.GetLookupAmplitude() * |               heights[k][l].height += | ||||||
|                                       sineWave[int(divDist * rippleInfo.x0_ripple.GetLookupPhase() + lookupT) & 0xff]; |                   rippleV * rippleInfo.x0_ripple.GetLookupAmplitude() * | ||||||
|  |                   sineWave[size_t(divDist * rippleInfo.x0_ripple.GetLookupPhase() + lookupT) & 0xff]; | ||||||
|             } else { |             } else { | ||||||
|               heights[k][l].height += 0.f; |               heights[k][l].height += 0.f; | ||||||
|             } |             } | ||||||
| @ -460,8 +460,9 @@ void CFluidPlaneCPU::ApplyRipple(const CFluidPlaneRender::SRippleInfo& rippleInf | |||||||
| 
 | 
 | ||||||
|               float divDist = (divDistSq != 0.f) ? std::sqrt(divDistSq) : 0.f; |               float divDist = (divDistSq != 0.f) ? std::sqrt(divDistSq) : 0.f; | ||||||
|               if (u8 rippleV = CFluidPlaneManager::RippleValues[lifeIdx][int(divDist * distFalloff)]) { |               if (u8 rippleV = CFluidPlaneManager::RippleValues[lifeIdx][int(divDist * distFalloff)]) { | ||||||
|                 heights[k][l].height += rippleV * rippleInfo.x0_ripple.GetLookupAmplitude() * |                 heights[k][l].height += | ||||||
|                                         sineWave[int(divDist * rippleInfo.x0_ripple.GetLookupPhase() + lookupT) & 0xff]; |                     rippleV * rippleInfo.x0_ripple.GetLookupAmplitude() * | ||||||
|  |                     sineWave[size_t(divDist * rippleInfo.x0_ripple.GetLookupPhase() + lookupT) & 0xff]; | ||||||
|               } else { |               } else { | ||||||
|                 heights[k][l].height += 0.f; |                 heights[k][l].height += 0.f; | ||||||
|               } |               } | ||||||
| @ -485,8 +486,8 @@ void CFluidPlaneCPU::ApplyRipple(const CFluidPlaneRender::SRippleInfo& rippleInf | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CFluidPlaneCPU::ApplyRipples(const rstl::reserved_vector<CFluidPlaneRender::SRippleInfo, 32>& rippleInfos, | void CFluidPlaneCPU::ApplyRipples(const rstl::reserved_vector<CFluidPlaneRender::SRippleInfo, 32>& rippleInfos, | ||||||
|                                   CFluidPlaneRender::SHFieldSample (&heights)[46][46], u8 (&flags)[9][9], |                                   Heights& heights, Flags& flags, const SineTable& sineWave, | ||||||
|                                   const float sineWave[256], const CFluidPlaneRender::SPatchInfo& info) const { |                                   const CFluidPlaneRender::SPatchInfo& info) const { | ||||||
|   for (const CFluidPlaneRender::SRippleInfo& rippleInfo : rippleInfos) |   for (const CFluidPlaneRender::SRippleInfo& rippleInfo : rippleInfos) | ||||||
|     ApplyRipple(rippleInfo, heights, flags, sineWave, info); |     ApplyRipple(rippleInfo, heights, flags, sineWave, info); | ||||||
|   for (int i = 0; i < CFluidPlaneRender::numTilesInHField; ++i) |   for (int i = 0; i < CFluidPlaneRender::numTilesInHField; ++i) | ||||||
| @ -499,7 +500,7 @@ void CFluidPlaneCPU::ApplyRipples(const rstl::reserved_vector<CFluidPlaneRender: | |||||||
|     flags[CFluidPlaneRender::numTilesInHField + 1][i + 1] |= 2; |     flags[CFluidPlaneRender::numTilesInHField + 1][i + 1] |= 2; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CFluidPlaneCPU::UpdatePatchNoNormals(CFluidPlaneRender::SHFieldSample (&heights)[46][46], const u8 (&flags)[9][9], | void CFluidPlaneCPU::UpdatePatchNoNormals(Heights& heights, const Flags& flags, | ||||||
|                                           const CFluidPlaneRender::SPatchInfo& info) { |                                           const CFluidPlaneRender::SPatchInfo& info) { | ||||||
|   for (int i = 1; i <= (info.x1_ySubdivs + CFluidPlaneRender::numSubdivisionsInTile - 2) / |   for (int i = 1; i <= (info.x1_ySubdivs + CFluidPlaneRender::numSubdivisionsInTile - 2) / | ||||||
|                            CFluidPlaneRender::numSubdivisionsInTile; |                            CFluidPlaneRender::numSubdivisionsInTile; | ||||||
| @ -558,8 +559,8 @@ void CFluidPlaneCPU::UpdatePatchNoNormals(CFluidPlaneRender::SHFieldSample (&hei | |||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CFluidPlaneCPU::UpdatePatchWithNormals(CFluidPlaneRender::SHFieldSample (&heights)[46][46], | void CFluidPlaneCPU::UpdatePatchWithNormals(Heights& heights, const Flags& flags, | ||||||
|                                             const u8 (&flags)[9][9], const CFluidPlaneRender::SPatchInfo& info) { |                                             const CFluidPlaneRender::SPatchInfo& info) { | ||||||
|   float normalScale = -(2.f * info.x18_rippleResolution); |   float normalScale = -(2.f * info.x18_rippleResolution); | ||||||
|   float nz = 0.25f * 2.f * info.x18_rippleResolution; |   float nz = 0.25f * 2.f * info.x18_rippleResolution; | ||||||
|   int curGridY = info.x2e_tileY * info.x2a_gridDimX - 1 + info.x28_tileX; |   int curGridY = info.x2e_tileY * info.x2a_gridDimX - 1 + info.x28_tileX; | ||||||
| @ -696,11 +697,9 @@ void CFluidPlaneCPU::UpdatePatchWithNormals(CFluidPlaneRender::SHFieldSample (&h | |||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool CFluidPlaneCPU::UpdatePatch(float time, const CFluidPlaneRender::SPatchInfo& info, | bool CFluidPlaneCPU::UpdatePatch(float time, const CFluidPlaneRender::SPatchInfo& info, Heights& heights, Flags& flags, | ||||||
|                                  CFluidPlaneRender::SHFieldSample (&heights)[46][46], u8 (&flags)[9][9], |                                  const zeus::CVector3f& areaCenter, const std::optional<CRippleManager>& rippleManager, | ||||||
|                                  const zeus::CVector3f& areaCenter, |                                  int fromX, int toX, int fromY, int toY) const { | ||||||
|                                  const std::optional<CRippleManager>& rippleManager, int fromX, int toX, |  | ||||||
|                                  int fromY, int toY) const { |  | ||||||
|   rstl::reserved_vector<CFluidPlaneRender::SRippleInfo, 32> rippleInfos; |   rstl::reserved_vector<CFluidPlaneRender::SRippleInfo, 32> rippleInfos; | ||||||
|   if (rippleManager) { |   if (rippleManager) { | ||||||
|     for (const CRipple& ripple : rippleManager->GetRipples()) { |     for (const CRipple& ripple : rippleManager->GetRipples()) { | ||||||
| @ -730,10 +729,10 @@ bool CFluidPlaneCPU::UpdatePatch(float time, const CFluidPlaneRender::SPatchInfo | |||||||
|   return false; |   return false; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* Used to be part of locked cache
 | // Used to be part of locked cache
 | ||||||
|  * These are too big for stack allocation */ | // These are too big for stack allocation
 | ||||||
| static CFluidPlaneRender::SHFieldSample lc_heights[46][46] = {}; | static CFluidPlane::Heights lc_heights{}; | ||||||
| static u8 lc_flags[9][9] = {}; | static CFluidPlane::Flags lc_flags{}; | ||||||
| 
 | 
 | ||||||
| void CFluidPlaneCPU::Render(const CStateManager& mgr, float alpha, const zeus::CAABox& aabb, const zeus::CTransform& xf, | void CFluidPlaneCPU::Render(const CStateManager& mgr, float alpha, const zeus::CAABox& aabb, const zeus::CTransform& xf, | ||||||
|                             const zeus::CTransform& areaXf, bool noNormals, const zeus::CFrustum& frustum, |                             const zeus::CTransform& areaXf, bool noNormals, const zeus::CFrustum& frustum, | ||||||
|  | |||||||
| @ -12,6 +12,9 @@ namespace urde { | |||||||
| class CFluidUVMotion; | class CFluidUVMotion; | ||||||
| 
 | 
 | ||||||
| class CFluidPlaneCPU : public CFluidPlane { | class CFluidPlaneCPU : public CFluidPlane { | ||||||
|  | public: | ||||||
|  |   using SineTable = std::array<float, 256>; | ||||||
|  | 
 | ||||||
| protected: | protected: | ||||||
|   class CTurbulence { |   class CTurbulence { | ||||||
|     float x0_speed; |     float x0_speed; | ||||||
| @ -65,23 +68,17 @@ protected: | |||||||
| 
 | 
 | ||||||
|   static bool PrepareRipple(const CRipple& ripple, const CFluidPlaneRender::SPatchInfo& info, |   static bool PrepareRipple(const CRipple& ripple, const CFluidPlaneRender::SPatchInfo& info, | ||||||
|                             CFluidPlaneRender::SRippleInfo& rippleOut); |                             CFluidPlaneRender::SRippleInfo& rippleOut); | ||||||
|   void ApplyTurbulence(float t, CFluidPlaneRender::SHFieldSample (&heights)[46][46], const u8 (&flags)[9][9], |   void ApplyTurbulence(float t, Heights& heights, const Flags& flags, const SineTable& sineWave, | ||||||
|                        const float sineWave[256], const CFluidPlaneRender::SPatchInfo& info, |                        const CFluidPlaneRender::SPatchInfo& info, const zeus::CVector3f& areaCenter) const; | ||||||
|                        const zeus::CVector3f& areaCenter) const; |   void ApplyRipple(const CFluidPlaneRender::SRippleInfo& rippleInfo, Heights& heights, Flags& flags, | ||||||
|   void ApplyRipple(const CFluidPlaneRender::SRippleInfo& rippleInfo, |                    const SineTable& sineWave, const CFluidPlaneRender::SPatchInfo& info) const; | ||||||
|                    CFluidPlaneRender::SHFieldSample (&heights)[46][46], u8 (&flags)[9][9], const float sineWave[256], |   void ApplyRipples(const rstl::reserved_vector<CFluidPlaneRender::SRippleInfo, 32>& rippleInfos, Heights& heights, | ||||||
|                    const CFluidPlaneRender::SPatchInfo& info) const; |                     Flags& flags, const SineTable& sineWave, const CFluidPlaneRender::SPatchInfo& info) const; | ||||||
|   void ApplyRipples(const rstl::reserved_vector<CFluidPlaneRender::SRippleInfo, 32>& rippleInfos, |   static void UpdatePatchNoNormals(Heights& heights, const Flags& flags, const CFluidPlaneRender::SPatchInfo& info); | ||||||
|                     CFluidPlaneRender::SHFieldSample (&heights)[46][46], u8 (&flags)[9][9], const float sineWave[256], |   static void UpdatePatchWithNormals(Heights& heights, const Flags& flags, const CFluidPlaneRender::SPatchInfo& info); | ||||||
|                     const CFluidPlaneRender::SPatchInfo& info) const; |   bool UpdatePatch(float time, const CFluidPlaneRender::SPatchInfo& info, Heights& heights, Flags& flags, | ||||||
|   static void UpdatePatchNoNormals(CFluidPlaneRender::SHFieldSample (&heights)[46][46], const u8 (&flags)[9][9], |                    const zeus::CVector3f& areaCenter, const std::optional<CRippleManager>& rippleManager, int fromX, | ||||||
|                                    const CFluidPlaneRender::SPatchInfo& info); |                    int toX, int fromY, int toY) const; | ||||||
|   static void UpdatePatchWithNormals(CFluidPlaneRender::SHFieldSample (&heights)[46][46], const u8 (&flags)[9][9], |  | ||||||
|                                      const CFluidPlaneRender::SPatchInfo& info); |  | ||||||
|   bool UpdatePatch(float time, const CFluidPlaneRender::SPatchInfo& info, |  | ||||||
|                    CFluidPlaneRender::SHFieldSample (&heights)[46][46], u8 (&flags)[9][9], |  | ||||||
|                    const zeus::CVector3f& areaCenter, const std::optional<CRippleManager>& rippleManager, |  | ||||||
|                    int fromX, int toX, int fromY, int toY) const; |  | ||||||
| 
 | 
 | ||||||
| public: | public: | ||||||
|   CFluidPlaneCPU(CAssetId texPattern1, CAssetId texPattern2, CAssetId texColor, CAssetId bumpMap, CAssetId envMap, |   CFluidPlaneCPU(CAssetId texPattern1, CAssetId texPattern2, CAssetId texColor, CAssetId bumpMap, CAssetId envMap, | ||||||
|  | |||||||
| @ -51,10 +51,10 @@ CFluidPlaneShader::RenderSetupInfo CFluidPlaneDoor::RenderSetup(const CStateMana | |||||||
|   return out; |   return out; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* Used to be part of locked cache
 | // Used to be part of locked cache
 | ||||||
|  * These are too big for stack allocation */ | // These are too big for stack allocation
 | ||||||
| static CFluidPlaneRender::SHFieldSample lc_heights[46][46] = {}; | static CFluidPlane::Heights lc_heights{}; | ||||||
| static u8 lc_flags[9][9] = {}; | static CFluidPlane::Flags lc_flags{}; | ||||||
| 
 | 
 | ||||||
| void CFluidPlaneDoor::Render(const CStateManager& mgr, float alpha, const zeus::CAABox& aabb, | void CFluidPlaneDoor::Render(const CStateManager& mgr, float alpha, const zeus::CAABox& aabb, | ||||||
|                              const zeus::CTransform& xf, const zeus::CTransform& areaXf, bool noNormals, |                              const zeus::CTransform& xf, const zeus::CTransform& areaXf, bool noNormals, | ||||||
|  | |||||||
| @ -17,8 +17,7 @@ CFluidPlaneGPU::CFluidPlaneGPU(CAssetId texPattern1, CAssetId texPattern2, CAsse | |||||||
|   m_tessellation = true; |   m_tessellation = true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CFluidPlaneGPU::RenderStripWithRipples(float curY, const CFluidPlaneRender::SHFieldSample (&heights)[46][46], | void CFluidPlaneGPU::RenderStripWithRipples(float curY, const Heights& heights, const Flags& flags, int startYDiv, | ||||||
|                                             const u8 (&flags)[9][9], int startYDiv, |  | ||||||
|                                             const CFluidPlaneRender::SPatchInfo& info, |                                             const CFluidPlaneRender::SPatchInfo& info, | ||||||
|                                             std::vector<CFluidPlaneShader::Vertex>& vOut, |                                             std::vector<CFluidPlaneShader::Vertex>& vOut, | ||||||
|                                             std::vector<CFluidPlaneShader::PatchVertex>& pvOut) { |                                             std::vector<CFluidPlaneShader::PatchVertex>& pvOut) { | ||||||
|  | |||||||
| @ -17,9 +17,8 @@ public: | |||||||
|                  float turbAmplitudeMin, float specularMin, float specularMax, float reflectionBlend, |                  float turbAmplitudeMin, float specularMin, float specularMax, float reflectionBlend, | ||||||
|                  float reflectionSize, float rippleIntensity, u32 maxVertCount); |                  float reflectionSize, float rippleIntensity, u32 maxVertCount); | ||||||
| 
 | 
 | ||||||
|   void RenderStripWithRipples(float curY, const CFluidPlaneRender::SHFieldSample (&heights)[46][46], |   void RenderStripWithRipples(float curY, const Heights& heights, const Flags& flags, int startYDiv, | ||||||
|                               const u8 (&flags)[9][9], int startYDiv, const CFluidPlaneRender::SPatchInfo& info, |                               const CFluidPlaneRender::SPatchInfo& info, std::vector<CFluidPlaneShader::Vertex>& vOut, | ||||||
|                               std::vector<CFluidPlaneShader::Vertex>& vOut, |  | ||||||
|                               std::vector<CFluidPlaneShader::PatchVertex>& pvOut) override; |                               std::vector<CFluidPlaneShader::PatchVertex>& pvOut) override; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user