mirror of https://github.com/AxioDL/metaforce.git
Fix an insane number of things with hsh refactoring
This commit is contained in:
parent
3c9816af12
commit
036e769210
|
@ -269,7 +269,7 @@ void CNESEmulator::InitializeEmulator() {
|
||||||
};
|
};
|
||||||
m_vbo = hsh::create_vertex_buffer<TexUVVert>(verts);
|
m_vbo = hsh::create_vertex_buffer<TexUVVert>(verts);
|
||||||
m_uniBuf = hsh::create_dynamic_uniform_buffer<ViewBlock>();
|
m_uniBuf = hsh::create_dynamic_uniform_buffer<ViewBlock>();
|
||||||
m_shadBind = CNESShader::BuildShaderDataBinding(m_vbo.get(), m_uniBuf.get(), m_texture.get());
|
CNESShader::BuildShaderDataBinding(m_shadBind, m_vbo.get(), m_uniBuf.get(), m_texture.get());
|
||||||
|
|
||||||
// double useFreq = 223740;
|
// double useFreq = 223740;
|
||||||
double useFreq = apuGetFrequency();
|
double useFreq = apuGetFrequency();
|
||||||
|
@ -753,12 +753,11 @@ void CNESEmulator::Draw(const zeus::CColor& mulColor, bool filtering) {
|
||||||
|
|
||||||
float widthFac = NESAspect / g_Viewport.aspect;
|
float widthFac = NESAspect / g_Viewport.aspect;
|
||||||
|
|
||||||
Uniform uniform = {zeus::CMatrix4f{}, mulColor};
|
ViewBlock uniform = {zeus::CMatrix4f{}, mulColor};
|
||||||
uniform.m_matrix[0][0] = widthFac;
|
uniform.m_mv[0][0] = widthFac;
|
||||||
m_uniBuf->load(&uniform, sizeof(Uniform));
|
m_uniBuf.load(uniform);
|
||||||
|
|
||||||
CGraphics::SetShaderDataBinding(m_shadBind);
|
m_shadBind.draw(0, 4);
|
||||||
CGraphics::DrawArray(0, 4);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CNESEmulator::LoadPassword(const u8* state) {
|
void CNESEmulator::LoadPassword(const u8* state) {
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
#include "Runtime/Graphics/CTexture.hpp"
|
#include "Runtime/Graphics/CTexture.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
std::array<CMappableObject::Vert, 8> CMappableObject::skDoorVerts{};
|
std::array<CMapSurfaceShader::Vert, 8> CMappableObject::skDoorVerts{};
|
||||||
|
|
||||||
constexpr std::array<u32, 24> DoorIndices{
|
constexpr std::array<u32, 24> DoorIndices{
|
||||||
6, 4, 2, 0, 3, 1, 7, 5, 1, 0, 5, 4, 7, 6, 3, 2, 3, 2, 1, 0, 5, 4, 7, 6,
|
6, 4, 2, 0, 3, 1, 7, 5, 1, 0, 5, 4, 7, 6, 3, 2, 3, 2, 1, 0, 5, 4, 7, 6,
|
||||||
|
@ -118,10 +118,10 @@ void CMappableObject::Draw(int curArea, const CMapWorldInfo& mwInfo, float alpha
|
||||||
CLineRenderer& line = ds.m_outline;
|
CLineRenderer& line = ds.m_outline;
|
||||||
const u32* baseIdx = &DoorIndices[s * 4];
|
const u32* baseIdx = &DoorIndices[s * 4];
|
||||||
line.Reset();
|
line.Reset();
|
||||||
line.AddVertex(skDoorVerts[baseIdx[0]].m_pos, colors.second, 1.f);
|
line.AddVertex(skDoorVerts[baseIdx[0]].pos, colors.second, 1.f);
|
||||||
line.AddVertex(skDoorVerts[baseIdx[1]].m_pos, colors.second, 1.f);
|
line.AddVertex(skDoorVerts[baseIdx[1]].pos, colors.second, 1.f);
|
||||||
line.AddVertex(skDoorVerts[baseIdx[3]].m_pos, colors.second, 1.f);
|
line.AddVertex(skDoorVerts[baseIdx[3]].pos, colors.second, 1.f);
|
||||||
line.AddVertex(skDoorVerts[baseIdx[2]].m_pos, colors.second, 1.f);
|
line.AddVertex(skDoorVerts[baseIdx[2]].pos, colors.second, 1.f);
|
||||||
line.Render();
|
line.Render();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -188,10 +188,10 @@ void CMappableObject::DrawDoorSurface(int curArea, const CMapWorldInfo& mwInfo,
|
||||||
CLineRenderer& line = ds.m_outline;
|
CLineRenderer& line = ds.m_outline;
|
||||||
const u32* baseIdx = &DoorIndices[surfIdx * 4];
|
const u32* baseIdx = &DoorIndices[surfIdx * 4];
|
||||||
line.Reset();
|
line.Reset();
|
||||||
line.AddVertex(skDoorVerts[baseIdx[0]].m_pos, colors.second, 1.f);
|
line.AddVertex(skDoorVerts[baseIdx[0]].pos, colors.second, 1.f);
|
||||||
line.AddVertex(skDoorVerts[baseIdx[1]].m_pos, colors.second, 1.f);
|
line.AddVertex(skDoorVerts[baseIdx[1]].pos, colors.second, 1.f);
|
||||||
line.AddVertex(skDoorVerts[baseIdx[3]].m_pos, colors.second, 1.f);
|
line.AddVertex(skDoorVerts[baseIdx[3]].pos, colors.second, 1.f);
|
||||||
line.AddVertex(skDoorVerts[baseIdx[2]].m_pos, colors.second, 1.f);
|
line.AddVertex(skDoorVerts[baseIdx[2]].pos, colors.second, 1.f);
|
||||||
line.Render();
|
line.Render();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -236,7 +236,7 @@ bool CMappableObject::IsVisibleToAutoMapper(bool worldVis, const CMapWorldInfo&
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
hsh::owner<hsh::vertex_buffer<CMappableObject::Vert>> CMappableObject::g_doorVbo;
|
hsh::owner<hsh::vertex_buffer<CMapSurfaceShader::Vert>> CMappableObject::g_doorVbo;
|
||||||
hsh::owner<hsh::index_buffer<u32>> CMappableObject::g_doorIbo;
|
hsh::owner<hsh::index_buffer<u32>> CMappableObject::g_doorIbo;
|
||||||
|
|
||||||
void CMappableObject::ReadAutoMapperTweaks(const ITweakAutoMapper& tweaks) {
|
void CMappableObject::ReadAutoMapperTweaks(const ITweakAutoMapper& tweaks) {
|
||||||
|
@ -245,14 +245,14 @@ void CMappableObject::ReadAutoMapperTweaks(const ITweakAutoMapper& tweaks) {
|
||||||
|
|
||||||
// Wrap door verts around -Z to build surface
|
// Wrap door verts around -Z to build surface
|
||||||
auto& doorVerts = skDoorVerts;
|
auto& doorVerts = skDoorVerts;
|
||||||
doorVerts[0].assign(-centerF[2], -centerF[1], 0.f);
|
doorVerts[0] = {-centerF[2], -centerF[1], 0.f};
|
||||||
doorVerts[1].assign(-centerF[2], -centerF[1], 2.f * centerF[0]);
|
doorVerts[1] = {-centerF[2], -centerF[1], 2.f * centerF[0]};
|
||||||
doorVerts[2].assign(-centerF[2], centerF[1], 0.f);
|
doorVerts[2] = {-centerF[2], centerF[1], 0.f};
|
||||||
doorVerts[3].assign(-centerF[2], centerF[1], 2.f * centerF[0]);
|
doorVerts[3] = {-centerF[2], centerF[1], 2.f * centerF[0]};
|
||||||
doorVerts[4].assign(.2f * -centerF[2], -centerF[1], 0.f);
|
doorVerts[4] = {.2f * -centerF[2], -centerF[1], 0.f};
|
||||||
doorVerts[5].assign(.2f * -centerF[2], -centerF[1], 2.f * centerF[0]);
|
doorVerts[5] = {.2f * -centerF[2], -centerF[1], 2.f * centerF[0]};
|
||||||
doorVerts[6].assign(.2f * -centerF[2], centerF[1], 0.f);
|
doorVerts[6] = {.2f * -centerF[2], centerF[1], 0.f};
|
||||||
doorVerts[7].assign(.2f * -centerF[2], centerF[1], 2.f * centerF[0]);
|
doorVerts[7] = {.2f * -centerF[2], centerF[1], 2.f * centerF[0]};
|
||||||
|
|
||||||
g_doorVbo = hsh::create_vertex_buffer(skDoorVerts);
|
g_doorVbo = hsh::create_vertex_buffer(skDoorVerts);
|
||||||
g_doorIbo = hsh::create_index_buffer(DoorIndices);
|
g_doorIbo = hsh::create_index_buffer(DoorIndices);
|
||||||
|
|
|
@ -19,13 +19,7 @@ class CStateManager;
|
||||||
|
|
||||||
class CMappableObject {
|
class CMappableObject {
|
||||||
public:
|
public:
|
||||||
struct Vert {
|
static hsh::owner<hsh::vertex_buffer<CMapSurfaceShader::Vert>> g_doorVbo;
|
||||||
hsh::float3 m_pos;
|
|
||||||
void assign(float x, float y, float z) {
|
|
||||||
m_pos = hsh::float3(x, y, z);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
static hsh::owner<hsh::vertex_buffer<Vert>> g_doorVbo;
|
|
||||||
static hsh::owner<hsh::index_buffer<u32>> g_doorIbo;
|
static hsh::owner<hsh::index_buffer<u32>> g_doorIbo;
|
||||||
|
|
||||||
enum class EMappableObjectType {
|
enum class EMappableObjectType {
|
||||||
|
@ -59,7 +53,7 @@ public:
|
||||||
enum class EVisMode { Always, MapStationOrVisit, Visit, Never, MapStationOrVisit2 };
|
enum class EVisMode { Always, MapStationOrVisit, Visit, Never, MapStationOrVisit2 };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static std::array<CMappableObject::Vert, 8> skDoorVerts;
|
static std::array<CMapSurfaceShader::Vert, 8> skDoorVerts;
|
||||||
|
|
||||||
EMappableObjectType x0_type;
|
EMappableObjectType x0_type;
|
||||||
EVisMode x4_visibilityMode;
|
EVisMode x4_visibilityMode;
|
||||||
|
|
|
@ -139,9 +139,6 @@ set(RUNTIME_INCLUDES ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
||||||
set(RUNTIME_LIBRARIES RetroDataSpec AssetNameMapNull NESEmulator
|
set(RUNTIME_LIBRARIES RetroDataSpec AssetNameMapNull NESEmulator
|
||||||
libjpeg-turbo jbus kabufuda discord-rpc logvisor)
|
libjpeg-turbo jbus kabufuda discord-rpc logvisor)
|
||||||
|
|
||||||
if(MSVC)
|
|
||||||
# WTF MS???? LINK.EXE is unable to address static libraries larger than 4GB.
|
|
||||||
# This is a hack to split this large library in two.
|
|
||||||
add_runtime_common_library(RuntimeCommon ${RUNTIME_SOURCES_A})
|
add_runtime_common_library(RuntimeCommon ${RUNTIME_SOURCES_A})
|
||||||
add_runtime_common_library(RuntimeCommonB ${RUNTIME_SOURCES_B})
|
add_runtime_common_library(RuntimeCommonB ${RUNTIME_SOURCES_B})
|
||||||
target_include_directories(RuntimeCommonB PUBLIC ${RUNTIME_INCLUDES})
|
target_include_directories(RuntimeCommonB PUBLIC ${RUNTIME_INCLUDES})
|
||||||
|
@ -149,12 +146,6 @@ if(MSVC)
|
||||||
target_link_libraries(RuntimeCommon PUBLIC RuntimeCommonB)
|
target_link_libraries(RuntimeCommon PUBLIC RuntimeCommonB)
|
||||||
target_hsh(RuntimeCommon)
|
target_hsh(RuntimeCommon)
|
||||||
target_hsh(RuntimeCommonB)
|
target_hsh(RuntimeCommonB)
|
||||||
else()
|
|
||||||
add_runtime_common_library(RuntimeCommon ${RUNTIME_SOURCES_A} ${RUNTIME_SOURCES_B})
|
|
||||||
target_include_directories(RuntimeCommon PUBLIC ${RUNTIME_INCLUDES})
|
|
||||||
target_link_libraries(RuntimeCommon PUBLIC ${RUNTIME_LIBRARIES})
|
|
||||||
target_hsh(RuntimeCommon)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_executable(urde CMain.hpp CMain.cpp)
|
add_executable(urde CMain.hpp CMain.cpp)
|
||||||
target_link_libraries(urde PUBLIC RuntimeCommon)
|
target_link_libraries(urde PUBLIC RuntimeCommon)
|
||||||
|
|
|
@ -668,7 +668,7 @@ void CStateManager::ResetViewAfterDraw(const SViewport& backupViewport,
|
||||||
cam->GetFarClipDistance());
|
cam->GetFarClipDistance());
|
||||||
}
|
}
|
||||||
|
|
||||||
void CStateManager::'DrawWorld() {
|
void CStateManager::DrawWorld() {
|
||||||
SCOPED_GRAPHICS_DEBUG_GROUP("CStateManager::DrawWorld", zeus::skBlue);
|
SCOPED_GRAPHICS_DEBUG_GROUP("CStateManager::DrawWorld", zeus::skBlue);
|
||||||
const CTimeProvider timeProvider(xf14_curTimeMod900);
|
const CTimeProvider timeProvider(xf14_curTimeMod900);
|
||||||
const SViewport backupViewport = g_Viewport;
|
const SViewport backupViewport = g_Viewport;
|
||||||
|
|
|
@ -693,8 +693,8 @@ CBooRenderer::CBooRenderer(IObjectStore& store, IFactory& resFac)
|
||||||
|
|
||||||
GenerateFogVolumeRampTex();
|
GenerateFogVolumeRampTex();
|
||||||
GenerateSphereRampTex();
|
GenerateSphereRampTex();
|
||||||
m_ballShadowId = hsh::create_render_texture2d({skBallShadowIdSize, skBallShadowIdSize}, hsh::RGBA8_UNORM, 1, 0);
|
m_ballShadowId = hsh::create_render_texture2d({skBallShadowIdSize, skBallShadowIdSize}, 1, 0);
|
||||||
x14c_reflectionTex = hsh::create_render_texture2d({256, 256}, hsh::RGBA8_UNORM, 1, 0);
|
x14c_reflectionTex = hsh::create_render_texture2d({256, 256}, 1, 0);
|
||||||
GenerateScanLinesVBO();
|
GenerateScanLinesVBO();
|
||||||
|
|
||||||
LoadThermoPalette();
|
LoadThermoPalette();
|
||||||
|
|
|
@ -308,7 +308,7 @@ public:
|
||||||
void BindReflectionDrawTarget() { x14c_reflectionTex.attach(); }
|
void BindReflectionDrawTarget() { x14c_reflectionTex.attach(); }
|
||||||
void BindBallShadowIdTarget() { m_ballShadowId.attach(); }
|
void BindBallShadowIdTarget() { m_ballShadowId.attach(); }
|
||||||
void ResolveBallShadowIdTarget() {
|
void ResolveBallShadowIdTarget() {
|
||||||
m_ballShadowId.resolve_color_binding(0, hsh::rect2d({0, 0}, {m_ballShadowIdW, m_ballShadowIdH}), false);
|
m_ballShadowId.resolve_color_binding(0, hsh::rect2d({0, 0}, {skBallShadowIdSize, skBallShadowIdSize}), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FindOverlappingWorldModels(std::vector<u32>& modelBits, const zeus::CAABox& aabb) const;
|
void FindOverlappingWorldModels(std::vector<u32>& modelBits, const zeus::CAABox& aabb) const;
|
||||||
|
|
|
@ -22,6 +22,7 @@ ERglCullMode gx_CullMode;
|
||||||
std::array<zeus::CColor, 2> gx_AmbientColors;
|
std::array<zeus::CColor, 2> gx_AmbientColors;
|
||||||
/// End GX state
|
/// End GX state
|
||||||
|
|
||||||
|
hsh::owner<hsh::render_texture2d> CGraphics::g_SpareTexture;
|
||||||
CGraphics::CProjectionState CGraphics::g_Proj;
|
CGraphics::CProjectionState CGraphics::g_Proj;
|
||||||
CGraphics::CFogState CGraphics::g_Fog;
|
CGraphics::CFogState CGraphics::g_Fog;
|
||||||
std::array<zeus::CColor, 3> CGraphics::g_ColorRegs{};
|
std::array<zeus::CColor, 3> CGraphics::g_ColorRegs{};
|
||||||
|
@ -176,11 +177,6 @@ void CGraphics::SetModelMatrix(const zeus::CTransform& xf) {
|
||||||
SetViewMatrix();
|
SetViewMatrix();
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr zeus::CMatrix4f PlusOneZ(1.f, 0.f, 0.f, 0.f, 0.f, 1.f, 0.f, 0.f, 0.f, 0.f, 1.f, 1.f, 0.f, 0.f, 0.f, 1.f);
|
|
||||||
|
|
||||||
constexpr zeus::CMatrix4f VulkanCorrect(1.f, 0.f, 0.f, 0.f, 0.f, -1.f, 0.f, 0.f, 0.f, 0.f, 0.5f, 0.5f + FLT_EPSILON,
|
|
||||||
0.f, 0.f, 0.f, 1.f);
|
|
||||||
|
|
||||||
zeus::CMatrix4f CGraphics::CalculatePerspectiveMatrix(float fovy, float aspect, float znear, float zfar,
|
zeus::CMatrix4f CGraphics::CalculatePerspectiveMatrix(float fovy, float aspect, float znear, float zfar,
|
||||||
bool forRenderer) {
|
bool forRenderer) {
|
||||||
CProjectionState st;
|
CProjectionState st;
|
||||||
|
@ -199,14 +195,8 @@ zeus::CMatrix4f CGraphics::CalculatePerspectiveMatrix(float fovy, float aspect,
|
||||||
float fpn = st.x18_far + st.x14_near;
|
float fpn = st.x18_far + st.x14_near;
|
||||||
float fmn = st.x18_far - st.x14_near;
|
float fmn = st.x18_far - st.x14_near;
|
||||||
|
|
||||||
if (!forRenderer) {
|
return zeus::CMatrix4f{2.f * st.x14_near / rml, 0.f, rpl / rml, 0.f, 0.f, 2.f * st.x14_near / tmb, tpb / tmb, 0.f,
|
||||||
return zeus::CMatrix4f(2.f * st.x14_near / rml, 0.f, rpl / rml, 0.f, 0.f, 2.f * st.x14_near / tmb, tpb / tmb, 0.f,
|
0.f, 0.f, -fpn / fmn, -2.f * st.x18_far * st.x14_near / fmn, 0.f, 0.f, -1.f, 0.f};
|
||||||
0.f, 0.f, -fpn / fmn, -2.f * st.x18_far * st.x14_near / fmn, 0.f, 0.f, -1.f, 0.f);
|
|
||||||
}
|
|
||||||
|
|
||||||
zeus::CMatrix4f mat2(2.f * st.x14_near / rml, 0.f, rpl / rml, 0.f, 0.f, 2.f * st.x14_near / tmb, tpb / tmb, 0.f,
|
|
||||||
0.f, 0.f, -fpn / fmn, -2.f * st.x18_far * st.x14_near / fmn, 0.f, 0.f, -1.f, 0.f);
|
|
||||||
return VulkanCorrect * mat2;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
zeus::CMatrix4f CGraphics::GetPerspectiveProjectionMatrix(bool forRenderer) {
|
zeus::CMatrix4f CGraphics::GetPerspectiveProjectionMatrix(bool forRenderer) {
|
||||||
|
@ -218,16 +208,9 @@ zeus::CMatrix4f CGraphics::GetPerspectiveProjectionMatrix(bool forRenderer) {
|
||||||
float fpn = g_Proj.x18_far + g_Proj.x14_near;
|
float fpn = g_Proj.x18_far + g_Proj.x14_near;
|
||||||
float fmn = g_Proj.x18_far - g_Proj.x14_near;
|
float fmn = g_Proj.x18_far - g_Proj.x14_near;
|
||||||
|
|
||||||
if (!forRenderer) {
|
return zeus::CMatrix4f{2.f * g_Proj.x14_near / rml, 0.f, rpl / rml, 0.f, 0.f, 2.f * g_Proj.x14_near / tmb,
|
||||||
return zeus::CMatrix4f(2.f * g_Proj.x14_near / rml, 0.f, rpl / rml, 0.f, 0.f, 2.f * g_Proj.x14_near / tmb,
|
|
||||||
tpb / tmb, 0.f, 0.f, 0.f, -fpn / fmn, -2.f * g_Proj.x18_far * g_Proj.x14_near / fmn, 0.f,
|
tpb / tmb, 0.f, 0.f, 0.f, -fpn / fmn, -2.f * g_Proj.x18_far * g_Proj.x14_near / fmn, 0.f,
|
||||||
0.f, -1.f, 0.f);
|
0.f, -1.f, 0.f};
|
||||||
}
|
|
||||||
|
|
||||||
zeus::CMatrix4f mat2(2.f * g_Proj.x14_near / rml, 0.f, rpl / rml, 0.f, 0.f, 2.f * g_Proj.x14_near / tmb,
|
|
||||||
tpb / tmb, 0.f, 0.f, 0.f, -fpn / fmn, -2.f * g_Proj.x18_far * g_Proj.x14_near / fmn, 0.f,
|
|
||||||
0.f, -1.f, 0.f);
|
|
||||||
return VulkanCorrect * mat2;
|
|
||||||
} else {
|
} else {
|
||||||
float rml = g_Proj.x8_right - g_Proj.x4_left;
|
float rml = g_Proj.x8_right - g_Proj.x4_left;
|
||||||
float rpl = g_Proj.x8_right + g_Proj.x4_left;
|
float rpl = g_Proj.x8_right + g_Proj.x4_left;
|
||||||
|
@ -236,14 +219,8 @@ zeus::CMatrix4f CGraphics::GetPerspectiveProjectionMatrix(bool forRenderer) {
|
||||||
float fpn = g_Proj.x18_far + g_Proj.x14_near;
|
float fpn = g_Proj.x18_far + g_Proj.x14_near;
|
||||||
float fmn = g_Proj.x18_far - g_Proj.x14_near;
|
float fmn = g_Proj.x18_far - g_Proj.x14_near;
|
||||||
|
|
||||||
if (!forRenderer) {
|
return zeus::CMatrix4f{2.f / rml, 0.f, 0.f, -rpl / rml, 0.f, 2.f / tmb, 0.f, -tpb / tmb, 0.f, 0.f, -2.f / fmn,
|
||||||
return zeus::CMatrix4f(2.f / rml, 0.f, 0.f, -rpl / rml, 0.f, 2.f / tmb, 0.f, -tpb / tmb, 0.f, 0.f, -2.f / fmn,
|
-fpn / fmn, 0.f, 0.f, 0.f, 1.f};
|
||||||
-fpn / fmn, 0.f, 0.f, 0.f, 1.f);
|
|
||||||
}
|
|
||||||
|
|
||||||
zeus::CMatrix4f mat2(2.f / rml, 0.f, 0.f, -rpl / rml, 0.f, 2.f / tmb, 0.f, -tpb / tmb, 0.f, 0.f, -2.f / fmn,
|
|
||||||
-fpn / fmn, 0.f, 0.f, 0.f, 1.f);
|
|
||||||
return VulkanCorrect * mat2;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -457,6 +457,7 @@ using BlendAttachmentExt =
|
||||||
hsh::ColorComponentFlags(
|
hsh::ColorComponentFlags(
|
||||||
hsh::CC_Red | hsh::CC_Green | hsh::CC_Blue |
|
hsh::CC_Red | hsh::CC_Green | hsh::CC_Blue |
|
||||||
(Alpha != AlphaMode::NoAlpha ? hsh::CC_Alpha : hsh::ColorComponentFlags()))>;
|
(Alpha != AlphaMode::NoAlpha ? hsh::CC_Alpha : hsh::ColorComponentFlags()))>;
|
||||||
|
|
||||||
template <AlphaMode Alpha = AlphaMode::NoAlpha>
|
template <AlphaMode Alpha = AlphaMode::NoAlpha>
|
||||||
using AdditiveAttachmentExt =
|
using AdditiveAttachmentExt =
|
||||||
hsh::pipeline::color_attachment<hsh::SrcAlpha, hsh::One, hsh::Add, AlphaSrc<Alpha, hsh::SrcAlpha>::Factor,
|
hsh::pipeline::color_attachment<hsh::SrcAlpha, hsh::One, hsh::Add, AlphaSrc<Alpha, hsh::SrcAlpha>::Factor,
|
||||||
|
@ -464,6 +465,7 @@ using AdditiveAttachmentExt =
|
||||||
hsh::ColorComponentFlags(
|
hsh::ColorComponentFlags(
|
||||||
hsh::CC_Red | hsh::CC_Green | hsh::CC_Blue |
|
hsh::CC_Red | hsh::CC_Green | hsh::CC_Blue |
|
||||||
(Alpha != AlphaMode::NoAlpha ? hsh::CC_Alpha : hsh::ColorComponentFlags()))>;
|
(Alpha != AlphaMode::NoAlpha ? hsh::CC_Alpha : hsh::ColorComponentFlags()))>;
|
||||||
|
|
||||||
template <AlphaMode Alpha = AlphaMode::NoAlpha>
|
template <AlphaMode Alpha = AlphaMode::NoAlpha>
|
||||||
using MultiplyAttachmentExt =
|
using MultiplyAttachmentExt =
|
||||||
hsh::pipeline::color_attachment<hsh::Zero, hsh::SrcColor, hsh::Add, AlphaSrc<Alpha, hsh::Zero>::Factor,
|
hsh::pipeline::color_attachment<hsh::Zero, hsh::SrcColor, hsh::Add, AlphaSrc<Alpha, hsh::Zero>::Factor,
|
||||||
|
@ -471,6 +473,7 @@ using MultiplyAttachmentExt =
|
||||||
hsh::ColorComponentFlags(
|
hsh::ColorComponentFlags(
|
||||||
hsh::CC_Red | hsh::CC_Green | hsh::CC_Blue |
|
hsh::CC_Red | hsh::CC_Green | hsh::CC_Blue |
|
||||||
(Alpha != AlphaMode::NoAlpha ? hsh::CC_Alpha : hsh::ColorComponentFlags()))>;
|
(Alpha != AlphaMode::NoAlpha ? hsh::CC_Alpha : hsh::ColorComponentFlags()))>;
|
||||||
|
|
||||||
template <AlphaMode Alpha = AlphaMode::NoAlpha>
|
template <AlphaMode Alpha = AlphaMode::NoAlpha>
|
||||||
using SubtractAttachmentExt = hsh::pipeline::color_attachment<
|
using SubtractAttachmentExt = hsh::pipeline::color_attachment<
|
||||||
hsh::SrcAlpha, hsh::One, hsh::ReverseSubtract, AlphaSrc<Alpha, hsh::SrcAlpha>::Factor,
|
hsh::SrcAlpha, hsh::One, hsh::ReverseSubtract, AlphaSrc<Alpha, hsh::SrcAlpha>::Factor,
|
||||||
|
|
|
@ -176,7 +176,7 @@ private:
|
||||||
ModelInstance m_ballShadowInstance;
|
ModelInstance m_ballShadowInstance;
|
||||||
|
|
||||||
hsh::vertex_buffer_typeless m_staticVbo;
|
hsh::vertex_buffer_typeless m_staticVbo;
|
||||||
hsh::index_buffer<u32> m_staticIbo;
|
hsh::index_buffer_typeless m_staticIbo;
|
||||||
|
|
||||||
hsh::texture2d m_lastDrawnShadowMap;
|
hsh::texture2d m_lastDrawnShadowMap;
|
||||||
hsh::texture2d m_lastDrawnOneTexture;
|
hsh::texture2d m_lastDrawnOneTexture;
|
||||||
|
@ -203,7 +203,7 @@ public:
|
||||||
~CBooModel();
|
~CBooModel();
|
||||||
CBooModel(TToken<CModel>& token, CModel* parent, std::vector<CBooSurface>* surfaces, SShader& shader,
|
CBooModel(TToken<CModel>& token, CModel* parent, std::vector<CBooSurface>* surfaces, SShader& shader,
|
||||||
hsh::vertex_buffer_typeless vbo,
|
hsh::vertex_buffer_typeless vbo,
|
||||||
hsh::index_buffer<u32> ibo,
|
hsh::index_buffer_typeless ibo,
|
||||||
const zeus::CAABox& aabb, u8 renderMask, int numInsts);
|
const zeus::CAABox& aabb, u8 renderMask, int numInsts);
|
||||||
|
|
||||||
static void MakeTexturesFromMats(const MaterialSet& matSet,
|
static void MakeTexturesFromMats(const MaterialSet& matSet,
|
||||||
|
@ -307,9 +307,9 @@ public:
|
||||||
zeus::CVector3f GetPoolVertex(size_t idx) const;
|
zeus::CVector3f GetPoolVertex(size_t idx) const;
|
||||||
size_t GetPoolNormalOffset(size_t idx) const;
|
size_t GetPoolNormalOffset(size_t idx) const;
|
||||||
zeus::CVector3f GetPoolNormal(size_t idx) const;
|
zeus::CVector3f GetPoolNormal(size_t idx) const;
|
||||||
void ApplyVerticesCPU(hsh::owner<hsh::vertex_buffer_typeless>& vertBuf,
|
void ApplyVerticesCPU(hsh::dynamic_owner<hsh::vertex_buffer_typeless>& vertBuf,
|
||||||
const std::vector<std::pair<zeus::CVector3f, zeus::CVector3f>>& vn) const;
|
const std::vector<std::pair<zeus::CVector3f, zeus::CVector3f>>& vn) const;
|
||||||
void RestoreVerticesCPU(hsh::owner<hsh::vertex_buffer_typeless>& vertBuf) const;
|
void RestoreVerticesCPU(hsh::dynamic_owner<hsh::vertex_buffer_typeless>& vertBuf) const;
|
||||||
|
|
||||||
void _WarmupShaders();
|
void _WarmupShaders();
|
||||||
static void WarmupShaders(const SObjectTag& cmdlTag);
|
static void WarmupShaders(const SObjectTag& cmdlTag);
|
||||||
|
|
|
@ -11,7 +11,6 @@
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
|
|
||||||
#include <boo/graphicsdev/Metal.hpp>
|
|
||||||
#include <hecl/CVarManager.hpp>
|
#include <hecl/CVarManager.hpp>
|
||||||
#include <hecl/HMDLMeta.hpp>
|
#include <hecl/HMDLMeta.hpp>
|
||||||
#include <hecl/Runtime.hpp>
|
#include <hecl/Runtime.hpp>
|
||||||
|
@ -124,26 +123,19 @@ void CBooModel::EnsureViewDepStateCached(const CBooModel& model, const CBooSurfa
|
||||||
mtxsOut[1][3][0] = -surfPos.dot(v2) * f1 + 0.5f;
|
mtxsOut[1][3][0] = -surfPos.dot(v2) * f1 + 0.5f;
|
||||||
mtxsOut[1][2][1] = f2;
|
mtxsOut[1][2][1] = f2;
|
||||||
mtxsOut[1][3][1] = -modelToPlayerLocal.z() * f2;
|
mtxsOut[1][3][1] = -modelToPlayerLocal.z() * f2;
|
||||||
switch (CGraphics::g_BooPlatform) {
|
|
||||||
case boo::IGraphicsDataFactory::Platform::OpenGL:
|
|
||||||
mtxsOut[1] = ReflectPostGL * mtxsOut[1];
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
boo::ObjToken<boo::ITexture> CBooModel::g_shadowMap;
|
hsh::texture2d CBooModel::g_shadowMap;
|
||||||
zeus::CTransform CBooModel::g_shadowTexXf;
|
zeus::CTransform CBooModel::g_shadowTexXf;
|
||||||
boo::ObjToken<boo::ITexture> CBooModel::g_disintegrateTexture;
|
hsh::texture2d CBooModel::g_disintegrateTexture;
|
||||||
boo::ObjToken<boo::ITextureCubeR> CBooModel::g_reflectionCube;
|
hsh::texturecube CBooModel::g_reflectionCube;
|
||||||
|
|
||||||
void CBooModel::EnableShadowMaps(hsh::texture2d map, const zeus::CTransform& texXf) {
|
void CBooModel::EnableShadowMaps(hsh::texture2d map, const zeus::CTransform& texXf) {
|
||||||
g_shadowMap = map;
|
g_shadowMap = map;
|
||||||
g_shadowTexXf = texXf;
|
g_shadowTexXf = texXf;
|
||||||
}
|
}
|
||||||
void CBooModel::DisableShadowMaps() { g_shadowMap = nullptr; }
|
void CBooModel::DisableShadowMaps() { g_shadowMap.reset(); }
|
||||||
|
|
||||||
CBooModel::~CBooModel() {
|
CBooModel::~CBooModel() {
|
||||||
if (m_prev)
|
if (m_prev)
|
||||||
|
@ -155,13 +147,14 @@ CBooModel::~CBooModel() {
|
||||||
}
|
}
|
||||||
|
|
||||||
CBooModel::CBooModel(TToken<CModel>& token, CModel* parent, std::vector<CBooSurface>* surfaces, SShader& shader,
|
CBooModel::CBooModel(TToken<CModel>& token, CModel* parent, std::vector<CBooSurface>* surfaces, SShader& shader,
|
||||||
hsh::vertex_buffer_typeless vbo, hsh::index_buffer<u32> ibo, const zeus::CAABox& aabb,
|
hsh::vertex_buffer_typeless vbo, hsh::index_buffer_typeless ibo, const zeus::CAABox& aabb,
|
||||||
u8 renderMask, int numInsts)
|
u8 renderMask, int numInsts)
|
||||||
: m_modelTok(token)
|
: m_modelTok(token)
|
||||||
, m_model(parent)
|
, m_model(parent)
|
||||||
, x0_surfaces(surfaces)
|
, x0_surfaces(surfaces)
|
||||||
, x4_matSet(&shader.m_matSet)
|
, x4_matSet(&shader.m_matSet)
|
||||||
, m_geomLayout(&*shader.m_geomLayout)
|
, m_geomLayout(&*shader.m_geomLayout)
|
||||||
|
, m_vtxFmt(m_model->GetHMDLMeta())
|
||||||
, m_matSetIdx(shader.m_matSetIdx)
|
, m_matSetIdx(shader.m_matSetIdx)
|
||||||
, x1c_textures(shader.x0_textures)
|
, x1c_textures(shader.x0_textures)
|
||||||
, x20_aabb(aabb)
|
, x20_aabb(aabb)
|
||||||
|
@ -302,11 +295,11 @@ CBooModel::ModelInstance* CBooModel::PushNewModelInstance(int sharedLayoutBuf) {
|
||||||
/* Build geometry uniform buffer if shared not available */
|
/* Build geometry uniform buffer if shared not available */
|
||||||
hsh::uniform_buffer_typeless geomUniformBuf;
|
hsh::uniform_buffer_typeless geomUniformBuf;
|
||||||
if (sharedLayoutBuf >= 0) {
|
if (sharedLayoutBuf >= 0) {
|
||||||
geomUniformBuf = m_geomLayout->GetSharedBuffer(sharedLayoutBuf);
|
geomUniformBuf = m_geomLayout->GetSharedBuffer(sharedLayoutBuf).get();
|
||||||
} else {
|
} else {
|
||||||
auto CreateUBO = [&]<uint32_t NSkinSlots>() {
|
auto CreateUBO = [&]<uint32_t NSkinSlots>() {
|
||||||
newInst.m_geomUniformBuffer = hsh::create_dynamic_uniform_buffer<CModelShaders::VertUniform<NSkinSlots>>();
|
newInst.m_geomUniformBuffer = hsh::create_dynamic_uniform_buffer<CModelShaders::VertUniform<NSkinSlots>>();
|
||||||
geomUniformBuf = newInst.m_geomUniformBuffer;
|
geomUniformBuf = newInst.m_geomUniformBuffer.get();
|
||||||
};
|
};
|
||||||
switch (m_vtxFmt.NSkinSlots) {
|
switch (m_vtxFmt.NSkinSlots) {
|
||||||
#define VERT_UNIFORM(nskins) \
|
#define VERT_UNIFORM(nskins) \
|
||||||
|
@ -376,7 +369,7 @@ CBooModel::ModelInstance* CBooModel::PushNewModelInstance(int sharedLayoutBuf) {
|
||||||
for (const CBooSurface& surf : *x0_surfaces) {
|
for (const CBooSurface& surf : *x0_surfaces) {
|
||||||
const MaterialSet::Material& mat = x4_matSet->materials.at(surf.m_data.matIdx);
|
const MaterialSet::Material& mat = x4_matSet->materials.at(surf.m_data.matIdx);
|
||||||
|
|
||||||
std::array<boo::ObjToken<boo::ITexture>, 12> texs{
|
std::array<hsh::texture_typeless, 12> texs{
|
||||||
g_Renderer->m_clearTexture.get(), g_Renderer->m_clearTexture.get(), g_Renderer->m_clearTexture.get(),
|
g_Renderer->m_clearTexture.get(), g_Renderer->m_clearTexture.get(), g_Renderer->m_clearTexture.get(),
|
||||||
g_Renderer->m_clearTexture.get(), g_Renderer->m_clearTexture.get(), g_Renderer->m_clearTexture.get(),
|
g_Renderer->m_clearTexture.get(), g_Renderer->m_clearTexture.get(), g_Renderer->m_clearTexture.get(),
|
||||||
g_Renderer->m_whiteTexture.get(), g_Renderer->m_clearTexture.get(), g_Renderer->x220_sphereRamp.get(),
|
g_Renderer->m_whiteTexture.get(), g_Renderer->m_clearTexture.get(), g_Renderer->x220_sphereRamp.get(),
|
||||||
|
@ -386,12 +379,13 @@ CBooModel::ModelInstance* CBooModel::PushNewModelInstance(int sharedLayoutBuf) {
|
||||||
for (const auto& ch : mat.chunks) {
|
for (const auto& ch : mat.chunks) {
|
||||||
if (const auto* const pass = ch.get_if<MaterialSet::Material::PASS>()) {
|
if (const auto* const pass = ch.get_if<MaterialSet::Material::PASS>()) {
|
||||||
auto search = x1c_textures.find(pass->texId.toUint32());
|
auto search = x1c_textures.find(pass->texId.toUint32());
|
||||||
boo::ObjToken<boo::ITexture> btex;
|
hsh::texture2d tex;
|
||||||
if (search != x1c_textures.cend() && (btex = search->second.GetObj()->GetBooTexture())){
|
if (search != x1c_textures.cend() && (tex = search->second.GetObj()->GetBooTexture())) {
|
||||||
texs[MaterialSet::Material::TexMapIdx(pass->type)] = btex;}
|
texs[MaterialSet::Material::TexMapIdx(pass->type)] = tex;
|
||||||
} else if (const auto* const pass = ch.get_if<MaterialSet::Material::CLR>()) {
|
}
|
||||||
boo::ObjToken<boo::ITexture> btex = g_Renderer->GetColorTexture(zeus::CColor(pass->color));
|
} else if (const auto* const clr = ch.get_if<MaterialSet::Material::CLR>()) {
|
||||||
texs[MaterialSet::Material::TexMapIdx(pass->type)] = btex;
|
hsh::texture2d tex = g_Renderer->GetColorTexture(clr->color);
|
||||||
|
texs[MaterialSet::Material::TexMapIdx(clr->type)] = tex;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -412,8 +406,9 @@ CBooModel::ModelInstance* CBooModel::PushNewModelInstance(int sharedLayoutBuf) {
|
||||||
|
|
||||||
bool useReflection = mat.flags.samusReflection() || mat.flags.samusReflectionSurfaceEye();
|
bool useReflection = mat.flags.samusReflection() || mat.flags.samusReflectionSurfaceEye();
|
||||||
if (useReflection) {
|
if (useReflection) {
|
||||||
if (g_Renderer->x14c_reflectionTex)
|
if (g_Renderer->x14c_reflectionTex.Owner.IsValid()) {
|
||||||
texs[11] = g_Renderer->x14c_reflectionTex.get();
|
// texs[11] = g_Renderer->x14c_reflectionTex.get_color(0);
|
||||||
|
}
|
||||||
thisOffs[3] = curReflect;
|
thisOffs[3] = curReflect;
|
||||||
curReflect += 256;
|
curReflect += 256;
|
||||||
} else {
|
} else {
|
||||||
|
@ -1181,8 +1176,8 @@ static const u8* MemoryFromPartData(const u8*& dataCur, const u32*& secSizeCur)
|
||||||
std::unique_ptr<CBooModel> CModel::MakeNewInstance(int shaderIdx, int subInsts, bool lockParent) {
|
std::unique_ptr<CBooModel> CModel::MakeNewInstance(int shaderIdx, int subInsts, bool lockParent) {
|
||||||
if (shaderIdx >= x18_matSets.size())
|
if (shaderIdx >= x18_matSets.size())
|
||||||
shaderIdx = 0;
|
shaderIdx = 0;
|
||||||
auto ret = std::make_unique<CBooModel>(m_selfToken, this, &x8_surfaces, x18_matSets[shaderIdx], m_staticVbo, m_ibo,
|
auto ret = std::make_unique<CBooModel>(m_selfToken, this, &x8_surfaces, x18_matSets[shaderIdx], m_staticVbo.get(),
|
||||||
m_aabb, (m_flags & 0x2) != 0, subInsts);
|
m_ibo.get(), m_aabb, (m_flags & 0x2) != 0, subInsts);
|
||||||
if (lockParent)
|
if (lockParent)
|
||||||
ret->LockParent();
|
ret->LockParent();
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -1228,15 +1223,59 @@ CModel::CModel(std::unique_ptr<u8[]>&& in, u32 /* dataLen */, IObjectStore* stor
|
||||||
matSet.BuildShaders(m_hmdlMeta);
|
matSet.BuildShaders(m_hmdlMeta);
|
||||||
}
|
}
|
||||||
|
|
||||||
CGraphics::CommitResources([&](boo::IGraphicsDataFactory::Context& ctx) {
|
|
||||||
/* Index buffer is always static */
|
/* Index buffer is always static */
|
||||||
if (m_hmdlMeta.indexCount)
|
if (m_hmdlMeta.indexCount)
|
||||||
m_ibo = ctx.newStaticBuffer(boo::BufferUse::Index, iboData, 4, m_hmdlMeta.indexCount);
|
m_ibo =
|
||||||
|
hsh::create_index_buffer(hsh::detail::ArrayProxy{reinterpret_cast<const u32*>(iboData), m_hmdlMeta.indexCount});
|
||||||
|
|
||||||
if (!m_hmdlMeta.bankCount) {
|
if (!m_hmdlMeta.bankCount) {
|
||||||
/* Non-skinned models use static vertex buffers shared with CBooModel instances */
|
/* Non-skinned models use static vertex buffers shared with CBooModel instances */
|
||||||
if (m_hmdlMeta.vertCount)
|
if (m_hmdlMeta.vertCount) {
|
||||||
m_staticVbo = ctx.newStaticBuffer(boo::BufferUse::Vertex, vboData, m_hmdlMeta.vertStride, m_hmdlMeta.vertCount);
|
auto CreateVBO = [this, vboData]<uint32_t NUVs, uint32_t NWeights>() {
|
||||||
|
using VertData = CModelShaders::VertData<0, NUVs, NWeights>;
|
||||||
|
assert(sizeof(VertData) != m_hmdlMeta.vertStride && "Vert data stride mismatch");
|
||||||
|
m_staticVbo = hsh::create_vertex_buffer(
|
||||||
|
hsh::detail::ArrayProxy{reinterpret_cast<const VertData*>(vboData), m_hmdlMeta.vertCount});
|
||||||
|
};
|
||||||
|
#define VERT_DATA(uvs) \
|
||||||
|
switch (m_hmdlMeta.weightCount) { \
|
||||||
|
case 0: \
|
||||||
|
CreateVBO.operator()<uvs, 0>(); \
|
||||||
|
break; \
|
||||||
|
case 1: \
|
||||||
|
CreateVBO.operator()<uvs, 1>(); \
|
||||||
|
break; \
|
||||||
|
case 2: \
|
||||||
|
CreateVBO.operator()<uvs, 2>(); \
|
||||||
|
break; \
|
||||||
|
case 3: \
|
||||||
|
CreateVBO.operator()<uvs, 3>(); \
|
||||||
|
break; \
|
||||||
|
case 4: \
|
||||||
|
CreateVBO.operator()<uvs, 4>(); \
|
||||||
|
break; \
|
||||||
|
default: \
|
||||||
|
assert(false && "Unhandled weight count"); \
|
||||||
|
break; \
|
||||||
|
} \
|
||||||
|
break;
|
||||||
|
switch (m_hmdlMeta.uvCount) {
|
||||||
|
case 0:
|
||||||
|
VERT_DATA(0)
|
||||||
|
case 1:
|
||||||
|
VERT_DATA(1)
|
||||||
|
case 2:
|
||||||
|
VERT_DATA(2)
|
||||||
|
case 3:
|
||||||
|
VERT_DATA(3)
|
||||||
|
case 4:
|
||||||
|
VERT_DATA(4)
|
||||||
|
#undef VERT_DATA
|
||||||
|
default:
|
||||||
|
assert(false && "Unhandled UV count");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
/* Skinned models use per-instance dynamic buffers for vertex manipulation effects */
|
/* Skinned models use per-instance dynamic buffers for vertex manipulation effects */
|
||||||
size_t vboSz = m_hmdlMeta.vertStride * m_hmdlMeta.vertCount;
|
size_t vboSz = m_hmdlMeta.vertStride * m_hmdlMeta.vertCount;
|
||||||
|
@ -1246,9 +1285,6 @@ CModel::CModel(std::unique_ptr<u8[]>&& in, u32 /* dataLen */, IObjectStore* stor
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
|
||||||
} BooTrace);
|
|
||||||
|
|
||||||
const u32 surfCount = hecl::SBig(*reinterpret_cast<const u32*>(surfInfo));
|
const u32 surfCount = hecl::SBig(*reinterpret_cast<const u32*>(surfInfo));
|
||||||
x8_surfaces.reserve(surfCount);
|
x8_surfaces.reserve(surfCount);
|
||||||
for (u32 i = 0; i < surfCount; ++i) {
|
for (u32 i = 0; i < surfCount; ++i) {
|
||||||
|
@ -1315,9 +1351,9 @@ zeus::CVector3f CModel::GetPoolNormal(size_t idx) const {
|
||||||
return {floats};
|
return {floats};
|
||||||
}
|
}
|
||||||
|
|
||||||
void CModel::ApplyVerticesCPU(hsh::owner<hsh::vertex_buffer_typeless>& vertBuf,
|
void CModel::ApplyVerticesCPU(hsh::dynamic_owner<hsh::vertex_buffer_typeless>& vertBuf,
|
||||||
const std::vector<std::pair<zeus::CVector3f, zeus::CVector3f>>& vn) const {
|
const std::vector<std::pair<zeus::CVector3f, zeus::CVector3f>>& vn) const {
|
||||||
u8* data = reinterpret_cast<u8*>(vertBuf->map(m_hmdlMeta.vertStride * m_hmdlMeta.vertCount));
|
u8* data = reinterpret_cast<u8*>(vertBuf.map()); // m_hmdlMeta.vertStride * m_hmdlMeta.vertCount
|
||||||
for (u32 i = 0; i < std::min(u32(vn.size()), m_hmdlMeta.vertCount); ++i) {
|
for (u32 i = 0; i < std::min(u32(vn.size()), m_hmdlMeta.vertCount); ++i) {
|
||||||
const std::pair<zeus::CVector3f, zeus::CVector3f>& avn = vn[i];
|
const std::pair<zeus::CVector3f, zeus::CVector3f>& avn = vn[i];
|
||||||
float* floats = reinterpret_cast<float*>(data + GetPoolVertexOffset(i));
|
float* floats = reinterpret_cast<float*>(data + GetPoolVertexOffset(i));
|
||||||
|
@ -1328,14 +1364,14 @@ void CModel::ApplyVerticesCPU(hsh::owner<hsh::vertex_buffer_typeless>& vertBuf,
|
||||||
floats[4] = avn.second.y();
|
floats[4] = avn.second.y();
|
||||||
floats[5] = avn.second.z();
|
floats[5] = avn.second.z();
|
||||||
}
|
}
|
||||||
vertBuf->unmap();
|
vertBuf.unmap();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CModel::RestoreVerticesCPU(hsh::owner<hsh::vertex_buffer_typeless>& vertBuf) const {
|
void CModel::RestoreVerticesCPU(hsh::dynamic_owner<hsh::vertex_buffer_typeless>& vertBuf) const {
|
||||||
size_t size = m_hmdlMeta.vertStride * m_hmdlMeta.vertCount;
|
size_t size = m_hmdlMeta.vertStride * m_hmdlMeta.vertCount;
|
||||||
u8* data = reinterpret_cast<u8*>(vertBuf->map(size));
|
u8* data = reinterpret_cast<u8*>(vertBuf.map()); // size
|
||||||
memcpy(data, m_dynamicVertexData.get(), size);
|
memcpy(data, m_dynamicVertexData.get(), size);
|
||||||
vertBuf->unmap();
|
vertBuf.unmap();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CModel::_WarmupShaders() {
|
void CModel::_WarmupShaders() {
|
||||||
|
|
|
@ -76,7 +76,7 @@ public:
|
||||||
hsh::texture_typeless GetBooTexture() const { return m_booTex.get(); }
|
hsh::texture_typeless GetBooTexture() const { return m_booTex.get(); }
|
||||||
hsh::texture_typeless GetPaletteTexture() const { return m_paletteTex.get(); }
|
hsh::texture_typeless GetPaletteTexture() const { return m_paletteTex.get(); }
|
||||||
std::unique_ptr<u8[]> BuildMemoryCardTex(u32& sizeOut, ETexelFormat& fmtOut, std::unique_ptr<u8[]>& paletteOut) const;
|
std::unique_ptr<u8[]> BuildMemoryCardTex(u32& sizeOut, ETexelFormat& fmtOut, std::unique_ptr<u8[]>& paletteOut) const;
|
||||||
hsh::texture_typeless GetFontTexture(EFontType tp);
|
hsh::texture2d_array GetFontTexture(EFontType tp);
|
||||||
|
|
||||||
const CTextureInfo* GetTextureInfo() const { return m_textureInfo; }
|
const CTextureInfo* GetTextureInfo() const { return m_textureInfo; }
|
||||||
};
|
};
|
||||||
|
|
|
@ -204,8 +204,8 @@ void CTexture::BuildIA8FromGCN(CInputStream& in) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
static std::vector<RGBA8> DecodePalette(int numEntries, CInputStream& in) {
|
static std::vector<CTexture::RGBA8> DecodePalette(int numEntries, CInputStream& in) {
|
||||||
std::vector<RGBA8> ret;
|
std::vector<CTexture::RGBA8> ret;
|
||||||
ret.reserve(numEntries);
|
ret.reserve(numEntries);
|
||||||
|
|
||||||
enum class EPaletteType { IA8, RGB565, RGB5A3 };
|
enum class EPaletteType { IA8, RGB565, RGB5A3 };
|
||||||
|
@ -544,8 +544,8 @@ void CTexture::BuildC8Font(const void* data, EFontType ftype) {
|
||||||
h /= 2;
|
h /= 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_booTex = hsh::create_texture2d_array({x4_w, x6_h}, layerCount, hsh::R8_UNORM, x8_mips, [&](void* data, std::size_t size) {
|
m_booTex = hsh::create_texture2d_array({x4_w, x6_h}, layerCount, hsh::RGBA8_UNORM, x8_mips, [&](void* data, std::size_t size) {
|
||||||
std::memcpy(data, texels, size);
|
std::memcpy(data, buf.get(), size);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -609,9 +609,9 @@ CTexture::CTexture(std::unique_ptr<u8[]>&& in, u32 length, bool otex, const CTex
|
||||||
case ETexelFormat::RGBA8:
|
case ETexelFormat::RGBA8:
|
||||||
BuildRGBA8FromGCN(r);
|
BuildRGBA8FromGCN(r);
|
||||||
break;
|
break;
|
||||||
case ETexelFormat::CMPR:
|
// case ETexelFormat::CMPR:
|
||||||
BuildDXT1FromGCN(r);
|
// BuildDXT1FromGCN(r);
|
||||||
break;
|
// break;
|
||||||
case ETexelFormat::RGBA8PC:
|
case ETexelFormat::RGBA8PC:
|
||||||
BuildRGBA8(owned.get() + 12, length - 12);
|
BuildRGBA8(owned.get() + 12, length - 12);
|
||||||
break;
|
break;
|
||||||
|
@ -719,7 +719,7 @@ std::unique_ptr<u8[]> CTexture::BuildMemoryCardTex(u32& sizeOut, ETexelFormat& f
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
hsh::texture_typeless CTexture::GetFontTexture(EFontType tp) {
|
hsh::texture2d_array CTexture::GetFontTexture(EFontType tp) {
|
||||||
if (m_ftype != tp && x0_fmt == ETexelFormat::C8PC) {
|
if (m_ftype != tp && x0_fmt == ETexelFormat::C8PC) {
|
||||||
m_ftype = tp;
|
m_ftype = tp;
|
||||||
BuildC8Font(m_otex.get() + 12, m_ftype);
|
BuildC8Font(m_otex.get() + 12, m_ftype);
|
||||||
|
|
|
@ -9,18 +9,16 @@
|
||||||
namespace urde {
|
namespace urde {
|
||||||
using namespace hsh::pipeline;
|
using namespace hsh::pipeline;
|
||||||
|
|
||||||
template <ERglCullMode CullMode, ERglEnum Compare, bool DepthWrite, ERglBlendMode Mode, ERglBlendFactor SrcFac,
|
struct CAABoxShaderPipeline : pipeline<topology<hsh::TriangleStrip>,
|
||||||
ERglBlendFactor DstFac, ERglLogicOp Op, bool AlphaWrite>
|
ERglBlendModeAttachment<ERglBlendMode::Blend, ERglBlendFactor::SrcAlpha,
|
||||||
struct CAABoxShaderPipeline
|
ERglBlendFactor::InvSrcAlpha, ERglLogicOp::Clear, false>,
|
||||||
: pipeline<topology<hsh::TriangleStrip>, ERglBlendModeAttachment<Mode, SrcFac, DstFac, Op, AlphaWrite>,
|
ERglCullModeAttachment<ERglCullMode::None>,
|
||||||
ERglCullModeAttachment<CullMode>, ERglDepthCompareAttachment<Compare>, depth_write<DepthWrite>> {
|
ERglDepthCompareAttachment<ERglEnum::LEqual>, depth_write<true>> {
|
||||||
CAABoxShaderPipeline(hsh::vertex_buffer<CAABoxShader::Vert> vbo, hsh::uniform_buffer<CAABoxShader::Uniform> uniBuf) {
|
CAABoxShaderPipeline(hsh::vertex_buffer<CAABoxShader::Vert> vbo, hsh::uniform_buffer<CAABoxShader::Uniform> uniBuf) {
|
||||||
this->position = uniBuf->m_xf * hsh::float4(vbo->m_pos, 1.f);
|
this->position = uniBuf->m_xf * hsh::float4(vbo->m_pos, 1.f);
|
||||||
this->color_out[0] = uniBuf->m_color;
|
this->color_out[0] = uniBuf->m_color;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
template struct CAABoxShaderPipeline<ERglCullMode::None, ERglEnum::LEqual, true, ERglBlendMode::Blend,
|
|
||||||
ERglBlendFactor::SrcAlpha, ERglBlendFactor::InvSrcAlpha, ERglLogicOp::Clear, true>;
|
|
||||||
|
|
||||||
constexpr size_t VertexCount = 34;
|
constexpr size_t VertexCount = 34;
|
||||||
|
|
||||||
|
@ -53,8 +51,7 @@ CAABoxShader::CAABoxShader(const zeus::CAABox& aabb) {
|
||||||
|
|
||||||
m_vbo = hsh::create_vertex_buffer(verts);
|
m_vbo = hsh::create_vertex_buffer(verts);
|
||||||
m_uniBuf = hsh::create_dynamic_uniform_buffer<Uniform>();
|
m_uniBuf = hsh::create_dynamic_uniform_buffer<Uniform>();
|
||||||
m_dataBind.hsh_bind(CAABoxShaderPipeline<gx_CullMode, gx_DepthTest, gx_DepthWrite, gx_BlendMode, gx_BlendSrcFac,
|
m_dataBind.hsh_bind(CAABoxShaderPipeline(m_vbo.get(), m_uniBuf.get()));
|
||||||
gx_BlendDstFac, gx_BlendOp, gx_AlphaWrite>(m_vbo.get(), m_uniBuf.get()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CAABoxShader::draw(const zeus::CColor& color) {
|
void CAABoxShader::draw(const zeus::CColor& color) {
|
||||||
|
|
|
@ -14,10 +14,13 @@ template <EFilterType Type>
|
||||||
struct CColoredQuadFilterPipeline : FilterPipeline<Type> {
|
struct CColoredQuadFilterPipeline : FilterPipeline<Type> {
|
||||||
CColoredQuadFilterPipeline(hsh::vertex_buffer<CColoredQuadFilter::Vert> vbo,
|
CColoredQuadFilterPipeline(hsh::vertex_buffer<CColoredQuadFilter::Vert> vbo,
|
||||||
hsh::uniform_buffer<CColoredQuadFilter::Uniform> uniBuf) {
|
hsh::uniform_buffer<CColoredQuadFilter::Uniform> uniBuf) {
|
||||||
this->position = hsh::float4(vbo->m_pos, 1.f);
|
this->position = uniBuf->m_matrix * hsh::float4(vbo->m_pos, 1.f);
|
||||||
this->color_out[0] = uniBuf->m_color;
|
this->color_out[0] = uniBuf->m_color;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
template struct CColoredQuadFilterPipeline<EFilterType::Add>;
|
||||||
|
template struct CColoredQuadFilterPipeline<EFilterType::Blend>;
|
||||||
|
template struct CColoredQuadFilterPipeline<EFilterType::Multiply>;
|
||||||
|
|
||||||
CColoredQuadFilter::CColoredQuadFilter(EFilterType type) {
|
CColoredQuadFilter::CColoredQuadFilter(EFilterType type) {
|
||||||
constexpr std::array<Vert, 4> verts{{
|
constexpr std::array<Vert, 4> verts{{
|
||||||
|
@ -36,6 +39,7 @@ CColoredQuadFilter::CColoredQuadFilter(EFilterType type) {
|
||||||
void CColoredQuadFilter::draw(const zeus::CColor& color, const zeus::CRectangle& rect) {
|
void CColoredQuadFilter::draw(const zeus::CColor& color, const zeus::CRectangle& rect) {
|
||||||
SCOPED_GRAPHICS_DEBUG_GROUP("CColoredQuadFilter::draw", zeus::skMagenta);
|
SCOPED_GRAPHICS_DEBUG_GROUP("CColoredQuadFilter::draw", zeus::skMagenta);
|
||||||
|
|
||||||
|
m_uniform.m_matrix = zeus::CMatrix4f{};
|
||||||
m_uniform.m_matrix[0][0] = rect.size.x() * 2.f;
|
m_uniform.m_matrix[0][0] = rect.size.x() * 2.f;
|
||||||
m_uniform.m_matrix[1][1] = rect.size.y() * 2.f;
|
m_uniform.m_matrix[1][1] = rect.size.y() * 2.f;
|
||||||
m_uniform.m_matrix[3][0] = rect.position.x() * 2.f - 1.f;
|
m_uniform.m_matrix[3][0] = rect.position.x() * 2.f - 1.f;
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
#include "zeus/CColor.hpp"
|
#include "zeus/CColor.hpp"
|
||||||
#include "zeus/CMatrix4f.hpp"
|
#include "zeus/CMatrix4f.hpp"
|
||||||
|
|
||||||
|
|
|
@ -15,8 +15,8 @@ struct CDecalShaderTexPipeline
|
||||||
std::conditional_t<Additive, std::conditional_t<RedToAlpha, MultiplyAttachment<>, AdditiveAttachment<>>,
|
std::conditional_t<Additive, std::conditional_t<RedToAlpha, MultiplyAttachment<>, AdditiveAttachment<>>,
|
||||||
BlendAttachment<>>,
|
BlendAttachment<>>,
|
||||||
depth_compare<hsh::LEqual>, depth_write<false>> {
|
depth_compare<hsh::LEqual>, depth_write<false>> {
|
||||||
CDecalShaderTexPipeline(hsh::vertex_buffer<SParticleInstanceTex> vbo, hsh::uniform_buffer<SParticleUniforms> uniBuf,
|
CDecalShaderTexPipeline(hsh::vertex_buffer<SParticleInstanceTex> vbo HSH_VAR_INSTANCE,
|
||||||
hsh::texture2d tex) {
|
hsh::uniform_buffer<SParticleUniforms> uniBuf, hsh::texture2d tex) {
|
||||||
this->position = uniBuf->mvp * vbo->pos[this->vertex_id];
|
this->position = uniBuf->mvp * vbo->pos[this->vertex_id];
|
||||||
this->color_out[0] = vbo->color * uniBuf->moduColor * tex.sample<float>(vbo->uvs[this->vertex_id]);
|
this->color_out[0] = vbo->color * uniBuf->moduColor * tex.sample<float>(vbo->uvs[this->vertex_id]);
|
||||||
if constexpr (RedToAlpha) {
|
if constexpr (RedToAlpha) {
|
||||||
|
@ -31,7 +31,7 @@ template struct CDecalShaderTexPipeline<false, false>;
|
||||||
template <bool Additive>
|
template <bool Additive>
|
||||||
struct CDecalShaderNoTexPipeline : pipeline<std::conditional_t<Additive, AdditiveAttachment<>, BlendAttachment<>>,
|
struct CDecalShaderNoTexPipeline : pipeline<std::conditional_t<Additive, AdditiveAttachment<>, BlendAttachment<>>,
|
||||||
depth_compare<hsh::LEqual>, depth_write<!Additive>> {
|
depth_compare<hsh::LEqual>, depth_write<!Additive>> {
|
||||||
CDecalShaderNoTexPipeline(hsh::vertex_buffer<SParticleInstanceNoTex> vbo,
|
CDecalShaderNoTexPipeline(hsh::vertex_buffer<SParticleInstanceNoTex> vbo HSH_VAR_INSTANCE,
|
||||||
hsh::uniform_buffer<SParticleUniforms> uniBuf) {
|
hsh::uniform_buffer<SParticleUniforms> uniBuf) {
|
||||||
this->position = uniBuf->mvp * vbo->pos[this->vertex_id];
|
this->position = uniBuf->mvp * vbo->pos[this->vertex_id];
|
||||||
this->color_out[0] = vbo->color * uniBuf->moduColor;
|
this->color_out[0] = vbo->color * uniBuf->moduColor;
|
||||||
|
|
|
@ -33,7 +33,7 @@ using BlendModeAttachment = typename BlendModeAttachmentExt<Mode, AlphaWrite>::t
|
||||||
template <BlendMode Mode, bool AlphaWrite, bool ZTest, bool ZWrite, bool RedToAlpha>
|
template <BlendMode Mode, bool AlphaWrite, bool ZTest, bool ZWrite, bool RedToAlpha>
|
||||||
struct CElementGenShadersTexPipeline : pipeline<topology<hsh::TriangleStrip>, BlendModeAttachment<Mode, AlphaWrite>,
|
struct CElementGenShadersTexPipeline : pipeline<topology<hsh::TriangleStrip>, BlendModeAttachment<Mode, AlphaWrite>,
|
||||||
depth_compare<ZTest ? hsh::LEqual : hsh::Always>, depth_write<ZWrite>> {
|
depth_compare<ZTest ? hsh::LEqual : hsh::Always>, depth_write<ZWrite>> {
|
||||||
CElementGenShadersTexPipeline(hsh::vertex_buffer<SParticleInstanceTex> vbo,
|
CElementGenShadersTexPipeline(hsh::vertex_buffer<SParticleInstanceTex> vbo HSH_VAR_INSTANCE,
|
||||||
hsh::uniform_buffer<SParticleUniforms> uniBuf, hsh::texture2d tex) {
|
hsh::uniform_buffer<SParticleUniforms> uniBuf, hsh::texture2d tex) {
|
||||||
this->position = uniBuf->mvp * vbo->pos[this->vertex_id];
|
this->position = uniBuf->mvp * vbo->pos[this->vertex_id];
|
||||||
this->color_out[0] = vbo->color * uniBuf->moduColor * tex.sample<float>(vbo->uvs[this->vertex_id]);
|
this->color_out[0] = vbo->color * uniBuf->moduColor * tex.sample<float>(vbo->uvs[this->vertex_id]);
|
||||||
|
@ -42,15 +42,14 @@ struct CElementGenShadersTexPipeline : pipeline<topology<hsh::TriangleStrip>, Bl
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
template struct CElementGenShadersTexPipeline<BlendMode::Regular, true, true, true, false>;
|
template struct CElementGenShadersTexPipeline<BlendMode::Additive, false, true, false, false>;
|
||||||
template struct CElementGenShadersTexPipeline<BlendMode::Additive, true, true, true, true>;
|
template struct CElementGenShadersTexPipeline<BlendMode::Regular, false, true, false, false>;
|
||||||
template struct CElementGenShadersTexPipeline<BlendMode::Subtract, true, true, true, true>;
|
|
||||||
|
|
||||||
template <BlendMode Mode, bool AlphaWrite, bool ZTest, bool ZWrite, bool ColoredIndirect>
|
template <BlendMode Mode, bool AlphaWrite, bool ZTest, bool ZWrite, bool ColoredIndirect>
|
||||||
struct CElementGenShadersIndTexPipeline
|
struct CElementGenShadersIndTexPipeline
|
||||||
: pipeline<topology<hsh::TriangleStrip>, BlendModeAttachment<Mode, AlphaWrite>,
|
: pipeline<topology<hsh::TriangleStrip>, BlendModeAttachment<Mode, AlphaWrite>,
|
||||||
depth_compare<ZTest ? hsh::LEqual : hsh::Always>, depth_write<ZWrite>> {
|
depth_compare<ZTest ? hsh::LEqual : hsh::Always>, depth_write<ZWrite>> {
|
||||||
CElementGenShadersIndTexPipeline(hsh::vertex_buffer<SParticleInstanceIndTex> vbo,
|
CElementGenShadersIndTexPipeline(hsh::vertex_buffer<SParticleInstanceIndTex> vbo HSH_VAR_INSTANCE,
|
||||||
hsh::uniform_buffer<SParticleUniforms> uniBuf, hsh::texture2d texrTex,
|
hsh::uniform_buffer<SParticleUniforms> uniBuf, hsh::texture2d texrTex,
|
||||||
hsh::texture2d tindTex, hsh::render_texture2d sceneTex) {
|
hsh::texture2d tindTex, hsh::render_texture2d sceneTex) {
|
||||||
this->position = uniBuf->mvp * vbo->pos[this->vertex_id];
|
this->position = uniBuf->mvp * vbo->pos[this->vertex_id];
|
||||||
|
@ -65,22 +64,19 @@ struct CElementGenShadersIndTexPipeline
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
template struct CElementGenShadersIndTexPipeline<BlendMode::Regular, true, true, true, true>;
|
template struct CElementGenShadersIndTexPipeline<BlendMode::Regular, false, true, false, false>;
|
||||||
template struct CElementGenShadersIndTexPipeline<BlendMode::Additive, true, true, true, false>;
|
|
||||||
|
|
||||||
template <BlendMode Mode, bool AlphaWrite, bool ZTest, bool ZWrite>
|
template <BlendMode Mode, bool AlphaWrite, bool ZTest, bool ZWrite>
|
||||||
struct CElementGenShadersNoTexPipeline
|
struct CElementGenShadersNoTexPipeline
|
||||||
: pipeline<topology<hsh::TriangleStrip>, BlendModeAttachment<Mode, AlphaWrite>,
|
: pipeline<topology<hsh::TriangleStrip>, BlendModeAttachment<Mode, AlphaWrite>,
|
||||||
depth_compare<ZTest ? hsh::LEqual : hsh::Always>, depth_write<ZWrite>> {
|
depth_compare<ZTest ? hsh::LEqual : hsh::Always>, depth_write<ZWrite>> {
|
||||||
CElementGenShadersNoTexPipeline(hsh::vertex_buffer<SParticleInstanceNoTex> vbo,
|
CElementGenShadersNoTexPipeline(hsh::vertex_buffer<SParticleInstanceNoTex> vbo HSH_VAR_INSTANCE,
|
||||||
hsh::uniform_buffer<SParticleUniforms> uniBuf) {
|
hsh::uniform_buffer<SParticleUniforms> uniBuf) {
|
||||||
this->position = uniBuf->mvp * vbo->pos[this->vertex_id];
|
this->position = uniBuf->mvp * vbo->pos[this->vertex_id];
|
||||||
this->color_out[0] = vbo->color * uniBuf->moduColor;
|
this->color_out[0] = vbo->color * uniBuf->moduColor;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
template struct CElementGenShadersNoTexPipeline<BlendMode::Regular, true, true, true>;
|
template struct CElementGenShadersNoTexPipeline<BlendMode::Regular, false, true, false>;
|
||||||
template struct CElementGenShadersNoTexPipeline<BlendMode::Additive, true, true, true>;
|
|
||||||
template struct CElementGenShadersNoTexPipeline<BlendMode::Subtract, true, true, true>;
|
|
||||||
|
|
||||||
CElementGenShaders::EShaderClass CElementGenShaders::GetShaderClass(CElementGen& gen) {
|
CElementGenShaders::EShaderClass CElementGenShaders::GetShaderClass(CElementGen& gen) {
|
||||||
const auto* desc = gen.x1c_genDesc.GetObj();
|
const auto* desc = gen.x1c_genDesc.GetObj();
|
||||||
|
|
|
@ -61,19 +61,19 @@ void CEnergyBarShader::draw(const zeus::CColor& color0, const std::vector<Vertex
|
||||||
if (!verts0.empty()) {
|
if (!verts0.empty()) {
|
||||||
m_uniform.m_color = color0;
|
m_uniform.m_color = color0;
|
||||||
m_uniBuf[0].load(m_uniform);
|
m_uniBuf[0].load(m_uniform);
|
||||||
m_dataBind[0].draw_indexed(0, verts0.size());
|
m_dataBind[0].draw(0, verts0.size());
|
||||||
vertIter += verts0.size();
|
vertIter += verts0.size();
|
||||||
}
|
}
|
||||||
if (!verts1.empty()) {
|
if (!verts1.empty()) {
|
||||||
m_uniform.m_color = color1;
|
m_uniform.m_color = color1;
|
||||||
m_uniBuf[1].load(m_uniform);
|
m_uniBuf[1].load(m_uniform);
|
||||||
m_dataBind[1].draw_indexed(vertIter, verts1.size());
|
m_dataBind[1].draw(vertIter, verts1.size());
|
||||||
vertIter += verts1.size();
|
vertIter += verts1.size();
|
||||||
}
|
}
|
||||||
if (!verts2.empty()) {
|
if (!verts2.empty()) {
|
||||||
m_uniform.m_color = color2;
|
m_uniform.m_color = color2;
|
||||||
m_uniBuf[2].load(m_uniform);
|
m_uniBuf[2].load(m_uniform);
|
||||||
m_dataBind[2].draw_indexed(vertIter, verts2.size());
|
m_dataBind[2].draw(vertIter, verts2.size());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,8 @@
|
||||||
#include "zeus/CVector2f.hpp"
|
#include "zeus/CVector2f.hpp"
|
||||||
#include "zeus/CVector3f.hpp"
|
#include "zeus/CVector3f.hpp"
|
||||||
|
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CTexture;
|
class CTexture;
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,7 @@ struct CEnvFxShadersPipeline
|
||||||
// FIXME replace MultiplyAttachment with ERglBlendFactor One:One equivalent
|
// FIXME replace MultiplyAttachment with ERglBlendFactor One:One equivalent
|
||||||
: pipeline<topology<hsh::TriangleStrip>, std::conditional_t<Blend, BlendAttachment<false>, MultiplyAttachment<false>>,
|
: pipeline<topology<hsh::TriangleStrip>, std::conditional_t<Blend, BlendAttachment<false>, MultiplyAttachment<false>>,
|
||||||
depth_compare<hsh::LEqual>, depth_write<false>> {
|
depth_compare<hsh::LEqual>, depth_write<false>> {
|
||||||
CEnvFxShadersPipeline(hsh::vertex_buffer<CEnvFxShaders::Instance> vbo,
|
CEnvFxShadersPipeline(hsh::vertex_buffer<CEnvFxShaders::Instance> vbo HSH_VAR_INSTANCE,
|
||||||
hsh::uniform_buffer<CEnvFxShaders::Uniform> envFxUniBuf,
|
hsh::uniform_buffer<CEnvFxShaders::Uniform> envFxUniBuf,
|
||||||
hsh::uniform_buffer<CGraphics::CFogState> fogUniBuf, hsh::texture2d texFlake,
|
hsh::uniform_buffer<CGraphics::CFogState> fogUniBuf, hsh::texture2d texFlake,
|
||||||
hsh::texture2d texEnv) {
|
hsh::texture2d texEnv) {
|
||||||
|
|
|
@ -35,7 +35,7 @@ template <bool Additive, bool AlphaWrite, hsh::Compare ZComp>
|
||||||
struct CLineRendererNoTexPipeline
|
struct CLineRendererNoTexPipeline
|
||||||
: pipeline<std::conditional_t<Additive, AdditiveAttachment<AlphaWrite>, BlendAttachment<AlphaWrite>>,
|
: pipeline<std::conditional_t<Additive, AdditiveAttachment<AlphaWrite>, BlendAttachment<AlphaWrite>>,
|
||||||
depth_compare<ZComp>> {
|
depth_compare<ZComp>> {
|
||||||
CLineRendererNoTexPipeline(hsh::vertex_buffer<CLineRenderer::SDrawVertTex> vbo,
|
CLineRendererNoTexPipeline(hsh::vertex_buffer<CLineRenderer::SDrawVertNoTex> vbo,
|
||||||
hsh::uniform_buffer<CLineRenderer::SDrawUniform> uniBuf HSH_VAR_STAGE(fragment)) {
|
hsh::uniform_buffer<CLineRenderer::SDrawUniform> uniBuf HSH_VAR_STAGE(fragment)) {
|
||||||
this->position = vbo->pos;
|
this->position = vbo->pos;
|
||||||
hsh::float4 colorIn = vbo->color * uniBuf->moduColor;
|
hsh::float4 colorIn = vbo->color * uniBuf->moduColor;
|
||||||
|
@ -46,6 +46,7 @@ struct CLineRendererNoTexPipeline
|
||||||
template struct CLineRendererNoTexPipeline<false, false, hsh::Always>;
|
template struct CLineRendererNoTexPipeline<false, false, hsh::Always>;
|
||||||
template struct CLineRendererNoTexPipeline<false, false, hsh::LEqual>;
|
template struct CLineRendererNoTexPipeline<false, false, hsh::LEqual>;
|
||||||
template struct CLineRendererNoTexPipeline<false, false, hsh::Greater>;
|
template struct CLineRendererNoTexPipeline<false, false, hsh::Greater>;
|
||||||
|
template struct CLineRendererNoTexPipeline<false, false, hsh::GEqual>;
|
||||||
template struct CLineRendererNoTexPipeline<false, true, hsh::Always>;
|
template struct CLineRendererNoTexPipeline<false, true, hsh::Always>;
|
||||||
template struct CLineRendererNoTexPipeline<false, true, hsh::LEqual>;
|
template struct CLineRendererNoTexPipeline<false, true, hsh::LEqual>;
|
||||||
template struct CLineRendererNoTexPipeline<false, true, hsh::Greater>;
|
template struct CLineRendererNoTexPipeline<false, true, hsh::Greater>;
|
||||||
|
|
|
@ -23,8 +23,7 @@ CMapSurfaceShader::CMapSurfaceShader(hsh::vertex_buffer<Vert> vbo, hsh::index_bu
|
||||||
|
|
||||||
void CMapSurfaceShader::draw(const zeus::CColor& color, u32 start, u32 count) {
|
void CMapSurfaceShader::draw(const zeus::CColor& color, u32 start, u32 count) {
|
||||||
SCOPED_GRAPHICS_DEBUG_GROUP("CMapSurfaceShader::draw", zeus::skMagenta);
|
SCOPED_GRAPHICS_DEBUG_GROUP("CMapSurfaceShader::draw", zeus::skMagenta);
|
||||||
Uniform uniform = {CGraphics::GetPerspectiveProjectionMatrix(true) * CGraphics::g_GXModelView.toMatrix4f(), color};
|
m_uniBuf.load({CGraphics::GetPerspectiveProjectionMatrix(true) * CGraphics::g_GXModelView.toMatrix4f(), color});
|
||||||
m_uniBuf.load(uniform);
|
|
||||||
m_dataBind.draw_indexed(start, count);
|
m_dataBind.draw_indexed(start, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,8 @@
|
||||||
#include "zeus/CColor.hpp"
|
#include "zeus/CColor.hpp"
|
||||||
#include "zeus/CMatrix4f.hpp"
|
#include "zeus/CMatrix4f.hpp"
|
||||||
|
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
|
|
||||||
class CMapSurfaceShader {
|
class CMapSurfaceShader {
|
||||||
|
|
|
@ -9,7 +9,7 @@ namespace urde {
|
||||||
using namespace hsh::pipeline;
|
using namespace hsh::pipeline;
|
||||||
|
|
||||||
struct CRadarPaintShaderPipeline : pipeline<topology<hsh::TriangleStrip>, AdditiveAttachment<>, depth_write<false>> {
|
struct CRadarPaintShaderPipeline : pipeline<topology<hsh::TriangleStrip>, AdditiveAttachment<>, depth_write<false>> {
|
||||||
CRadarPaintShaderPipeline(hsh::vertex_buffer<CRadarPaintShader::Instance> vbo,
|
CRadarPaintShaderPipeline(hsh::vertex_buffer<CRadarPaintShader::Instance> vbo HSH_VAR_INSTANCE,
|
||||||
hsh::uniform_buffer<CRadarPaintShader::Uniform> ubo, hsh::texture2d tex) {
|
hsh::uniform_buffer<CRadarPaintShader::Uniform> ubo, hsh::texture2d tex) {
|
||||||
this->position = ubo->xf * hsh::float4(vbo->pos[this->vertex_id], 1.f);
|
this->position = ubo->xf * hsh::float4(vbo->pos[this->vertex_id], 1.f);
|
||||||
this->color_out[0] = vbo->color * tex.sample<float>(vbo->uv[this->vertex_id]);
|
this->color_out[0] = vbo->color * tex.sample<float>(vbo->uv[this->vertex_id]);
|
||||||
|
|
|
@ -2,6 +2,8 @@
|
||||||
|
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
|
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
#include "zeus/CColor.hpp"
|
#include "zeus/CColor.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
|
|
|
@ -4,6 +4,8 @@
|
||||||
|
|
||||||
#include "Runtime/GCNTypes.hpp"
|
#include "Runtime/GCNTypes.hpp"
|
||||||
|
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
#include "zeus/CVector3f.hpp"
|
#include "zeus/CVector3f.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
|
|
|
@ -33,7 +33,7 @@ using DrawFlagsAttachment = typename DrawFlagsAttachmentExt<Flags>::type;
|
||||||
template <CGuiWidget::EGuiModelDrawFlags Flags>
|
template <CGuiWidget::EGuiModelDrawFlags Flags>
|
||||||
struct CTextSupportShaderCharacterPipeline
|
struct CTextSupportShaderCharacterPipeline
|
||||||
: pipeline<topology<hsh::TriangleStrip>, DrawFlagsAttachment<Flags>, depth_write<false>, depth_compare<hsh::LEqual>> {
|
: pipeline<topology<hsh::TriangleStrip>, DrawFlagsAttachment<Flags>, depth_write<false>, depth_compare<hsh::LEqual>> {
|
||||||
CTextSupportShaderCharacterPipeline(hsh::vertex_buffer<CTextSupportShader::CharacterInstance> vbo,
|
CTextSupportShaderCharacterPipeline(hsh::vertex_buffer<CTextSupportShader::CharacterInstance> vbo HSH_VAR_INSTANCE,
|
||||||
hsh::uniform_buffer<CTextSupportShader::Uniform> ubo, hsh::texture2d_array tex) {
|
hsh::uniform_buffer<CTextSupportShader::Uniform> ubo, hsh::texture2d_array tex) {
|
||||||
this->position = ubo->m_mvp * hsh::float4(vbo->m_pos[this->vertex_id], 1.f);
|
this->position = ubo->m_mvp * hsh::float4(vbo->m_pos[this->vertex_id], 1.f);
|
||||||
hsh::float4 fontColor = ubo->m_uniformColor * vbo->m_fontColor;
|
hsh::float4 fontColor = ubo->m_uniformColor * vbo->m_fontColor;
|
||||||
|
@ -49,7 +49,7 @@ template struct CTextSupportShaderCharacterPipeline<CGuiWidget::EGuiModelDrawFla
|
||||||
template <CGuiWidget::EGuiModelDrawFlags Flags>
|
template <CGuiWidget::EGuiModelDrawFlags Flags>
|
||||||
struct CTextSupportShaderImagePipeline
|
struct CTextSupportShaderImagePipeline
|
||||||
: pipeline<topology<hsh::TriangleStrip>, DrawFlagsAttachment<Flags>, depth_write<false>, depth_compare<hsh::LEqual>> {
|
: pipeline<topology<hsh::TriangleStrip>, DrawFlagsAttachment<Flags>, depth_write<false>, depth_compare<hsh::LEqual>> {
|
||||||
CTextSupportShaderImagePipeline(hsh::vertex_buffer<CTextSupportShader::ImageInstance> vbo,
|
CTextSupportShaderImagePipeline(hsh::vertex_buffer<CTextSupportShader::ImageInstance> vbo HSH_VAR_INSTANCE,
|
||||||
hsh::uniform_buffer<CTextSupportShader::Uniform> ubo, hsh::texture2d tex) {
|
hsh::uniform_buffer<CTextSupportShader::Uniform> ubo, hsh::texture2d tex) {
|
||||||
this->position = ubo->m_mvp * hsh::float4(vbo->m_pos[this->vertex_id], 1.f);
|
this->position = ubo->m_mvp * hsh::float4(vbo->m_pos[this->vertex_id], 1.f);
|
||||||
// FIXME hsh bug: sampler appears to be completely ignored
|
// FIXME hsh bug: sampler appears to be completely ignored
|
||||||
|
|
|
@ -12,25 +12,51 @@ namespace urde {
|
||||||
template <EFilterType Type, bool TexAlpha>
|
template <EFilterType Type, bool TexAlpha>
|
||||||
struct CTexturedQuadFilterPipeline : FilterPipeline<Type> {
|
struct CTexturedQuadFilterPipeline : FilterPipeline<Type> {
|
||||||
CTexturedQuadFilterPipeline(hsh::vertex_buffer<CTexturedQuadFilter::Vert> vbo,
|
CTexturedQuadFilterPipeline(hsh::vertex_buffer<CTexturedQuadFilter::Vert> vbo,
|
||||||
hsh::uniform_buffer<CTexturedQuadFilter::Uniform> uniBuf, hsh::texture2d tex) {
|
hsh::uniform_buffer<CTexturedQuadFilter::Uniform> uniBuf,
|
||||||
this->position = hsh::float4(vbo->m_pos, 1.f);
|
hsh::texture2d tex) {
|
||||||
|
this->position = uniBuf->m_matrix * hsh::float4(vbo->m_pos, 1.f);
|
||||||
if constexpr (TexAlpha) {
|
if constexpr (TexAlpha) {
|
||||||
this->color_out[0] = uniBuf->m_color * tex.sample_bias<float>(vbo->m_uv, uniBuf->m_lod, {});
|
this->color_out[0] = uniBuf->m_color * tex.sample_bias<float>(vbo->m_uv, uniBuf->m_lod);
|
||||||
} else {
|
} else {
|
||||||
this->color_out[0] =
|
this->color_out[0] =
|
||||||
uniBuf->m_color * hsh::float4(tex.sample_bias<float>(vbo->m_uv, uniBuf->m_lod, {}).xyz(), 1.f);
|
uniBuf->m_color * hsh::float4(tex.sample_bias<float>(vbo->m_uv, uniBuf->m_lod).xyz(), 1.f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
template struct CTexturedQuadFilterPipeline<EFilterType::Blend, false>;
|
||||||
|
template struct CTexturedQuadFilterPipeline<EFilterType::Add, true>;
|
||||||
|
template struct CTexturedQuadFilterPipeline<EFilterType::Multiply, false>;
|
||||||
|
|
||||||
template <typename Tex>
|
template <EFilterType Type, bool TexAlpha>
|
||||||
CTexturedQuadFilter::CTexturedQuadFilter(EFilterType type, Tex tex, ZTest ztest)
|
struct CTexturedQuadFilterRenderTexPipeline : FilterPipeline<Type> {
|
||||||
|
CTexturedQuadFilterRenderTexPipeline(hsh::vertex_buffer<CTexturedQuadFilter::Vert> vbo,
|
||||||
|
hsh::uniform_buffer<CTexturedQuadFilter::Uniform> uniBuf,
|
||||||
|
hsh::render_texture2d tex) {
|
||||||
|
this->position = uniBuf->m_matrix * hsh::float4(vbo->m_pos, 1.f);
|
||||||
|
if constexpr (TexAlpha) {
|
||||||
|
this->color_out[0] = uniBuf->m_color * tex.sample_bias<float>(vbo->m_uv, uniBuf->m_lod);
|
||||||
|
} else {
|
||||||
|
this->color_out[0] =
|
||||||
|
uniBuf->m_color * hsh::float4(tex.sample_bias<float>(vbo->m_uv, uniBuf->m_lod).xyz(), 1.f);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
template struct CTexturedQuadFilterRenderTexPipeline<EFilterType::Blend, false>;
|
||||||
|
|
||||||
|
CTexturedQuadFilter::CTexturedQuadFilter(EFilterType type, hsh::texture2d tex, ZTest ztest)
|
||||||
: m_zTest(ztest) {
|
: m_zTest(ztest) {
|
||||||
m_vbo = hsh::create_dynamic_vertex_buffer<Vert>(16);
|
m_vbo = hsh::create_dynamic_vertex_buffer<Vert>(16);
|
||||||
m_uniBuf = hsh::create_dynamic_uniform_buffer<Uniform>();
|
m_uniBuf = hsh::create_dynamic_uniform_buffer<Uniform>();
|
||||||
m_dataBind.hsh_bind(CTexturedQuadFilterPipeline<type, false>(m_vbo.get(), m_uniBuf.get(), tex));
|
m_dataBind.hsh_bind(CTexturedQuadFilterPipeline<type, false>(m_vbo.get(), m_uniBuf.get(), tex));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CTexturedQuadFilter::CTexturedQuadFilter(EFilterType type, hsh::render_texture2d tex, ZTest ztest)
|
||||||
|
: m_zTest(ztest) {
|
||||||
|
m_vbo = hsh::create_dynamic_vertex_buffer<Vert>(16);
|
||||||
|
m_uniBuf = hsh::create_dynamic_uniform_buffer<Uniform>();
|
||||||
|
m_dataBind.hsh_rend_bind(CTexturedQuadFilterRenderTexPipeline<type, false>(m_vbo.get(), m_uniBuf.get(), tex));
|
||||||
|
}
|
||||||
|
|
||||||
CTexturedQuadFilter::CTexturedQuadFilter(EFilterType type, TLockedToken<CTexture> tex, ZTest ztest)
|
CTexturedQuadFilter::CTexturedQuadFilter(EFilterType type, TLockedToken<CTexture> tex, ZTest ztest)
|
||||||
: CTexturedQuadFilter(type, (tex ? tex->GetBooTexture() : hsh::texture2d{}), ztest) {
|
: CTexturedQuadFilter(type, (tex ? tex->GetBooTexture() : hsh::texture2d{}), ztest) {
|
||||||
m_tex = tex;
|
m_tex = tex;
|
||||||
|
@ -49,8 +75,10 @@ void CTexturedQuadFilter::draw(const zeus::CColor& color, float uvScale, const z
|
||||||
|
|
||||||
m_uniform.m_matrix[0][0] = rect.size.x() * 2.f;
|
m_uniform.m_matrix[0][0] = rect.size.x() * 2.f;
|
||||||
m_uniform.m_matrix[1][1] = rect.size.y() * 2.f;
|
m_uniform.m_matrix[1][1] = rect.size.y() * 2.f;
|
||||||
|
m_uniform.m_matrix[2][2] = 1.f;
|
||||||
m_uniform.m_matrix[3][0] = rect.position.x() * 2.f - 1.f;
|
m_uniform.m_matrix[3][0] = rect.position.x() * 2.f - 1.f;
|
||||||
m_uniform.m_matrix[3][1] = rect.position.y() * 2.f - 1.f;
|
m_uniform.m_matrix[3][1] = rect.position.y() * 2.f - 1.f;
|
||||||
|
m_uniform.m_matrix[3][3] = 1.f;
|
||||||
m_uniform.m_color = color;
|
m_uniform.m_color = color;
|
||||||
m_uniBuf.load(m_uniform);
|
m_uniBuf.load(m_uniform);
|
||||||
|
|
||||||
|
@ -140,13 +168,18 @@ void CTexturedQuadFilter::DrawFilter(EFilterShape shape, const zeus::CColor& col
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Tex>
|
CTexturedQuadFilterAlpha::CTexturedQuadFilterAlpha(EFilterType type, hsh::texture2d tex) {
|
||||||
CTexturedQuadFilterAlpha::CTexturedQuadFilterAlpha(EFilterType type, Tex tex) {
|
|
||||||
m_vbo = hsh::create_dynamic_vertex_buffer<Vert>(16);
|
m_vbo = hsh::create_dynamic_vertex_buffer<Vert>(16);
|
||||||
m_uniBuf = hsh::create_dynamic_uniform_buffer<Uniform>();
|
m_uniBuf = hsh::create_dynamic_uniform_buffer<Uniform>();
|
||||||
m_dataBind.hsh_bind_alpha(CTexturedQuadFilterPipeline<type, true>(m_vbo.get(), m_uniBuf.get(), tex));
|
m_dataBind.hsh_bind_alpha(CTexturedQuadFilterPipeline<type, true>(m_vbo.get(), m_uniBuf.get(), tex));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CTexturedQuadFilterAlpha::CTexturedQuadFilterAlpha(EFilterType type, hsh::render_texture2d tex) {
|
||||||
|
m_vbo = hsh::create_dynamic_vertex_buffer<Vert>(16);
|
||||||
|
m_uniBuf = hsh::create_dynamic_uniform_buffer<Uniform>();
|
||||||
|
m_dataBind.hsh_render_bind_alpha(CTexturedQuadFilterRenderTexPipeline<type, true>(m_vbo.get(), m_uniBuf.get(), tex));
|
||||||
|
}
|
||||||
|
|
||||||
CTexturedQuadFilterAlpha::CTexturedQuadFilterAlpha(EFilterType type, TLockedToken<CTexture> tex)
|
CTexturedQuadFilterAlpha::CTexturedQuadFilterAlpha(EFilterType type, TLockedToken<CTexture> tex)
|
||||||
: CTexturedQuadFilterAlpha(type, (tex ? tex->GetBooTexture() : hsh::texture2d{})) {
|
: CTexturedQuadFilterAlpha(type, (tex ? tex->GetBooTexture() : hsh::texture2d{})) {
|
||||||
m_tex = tex;
|
m_tex = tex;
|
||||||
|
|
|
@ -2,6 +2,8 @@
|
||||||
|
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
|
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
#include "zeus/CColor.hpp"
|
#include "zeus/CColor.hpp"
|
||||||
#include "zeus/CMatrix4f.hpp"
|
#include "zeus/CMatrix4f.hpp"
|
||||||
#include "zeus/CRectangle.hpp"
|
#include "zeus/CRectangle.hpp"
|
||||||
|
@ -32,7 +34,7 @@ protected:
|
||||||
hsh::dynamic_owner<hsh::vertex_buffer<Vert>> m_vbo;
|
hsh::dynamic_owner<hsh::vertex_buffer<Vert>> m_vbo;
|
||||||
hsh::dynamic_owner<hsh::uniform_buffer<Uniform>> m_uniBuf;
|
hsh::dynamic_owner<hsh::uniform_buffer<Uniform>> m_uniBuf;
|
||||||
hsh::binding m_dataBind;
|
hsh::binding m_dataBind;
|
||||||
Uniform m_uniform;
|
Uniform m_uniform{};
|
||||||
ZTest m_zTest;
|
ZTest m_zTest;
|
||||||
|
|
||||||
CTexturedQuadFilter() = default;
|
CTexturedQuadFilter() = default;
|
||||||
|
@ -40,8 +42,8 @@ protected:
|
||||||
public:
|
public:
|
||||||
static constexpr zeus::CRectangle DefaultRect{0.f, 0.f, 1.f, 1.f};
|
static constexpr zeus::CRectangle DefaultRect{0.f, 0.f, 1.f, 1.f};
|
||||||
explicit CTexturedQuadFilter(EFilterType type, TLockedToken<CTexture> tex, ZTest zTest = ZTest::None);
|
explicit CTexturedQuadFilter(EFilterType type, TLockedToken<CTexture> tex, ZTest zTest = ZTest::None);
|
||||||
template <typename Tex>
|
explicit CTexturedQuadFilter(EFilterType type, hsh::texture2d tex, ZTest zTest = ZTest::None);
|
||||||
explicit CTexturedQuadFilter(EFilterType type, Tex tex, ZTest zTest = ZTest::None);
|
explicit CTexturedQuadFilter(EFilterType type, hsh::render_texture2d tex, ZTest zTest = ZTest::None);
|
||||||
CTexturedQuadFilter(const CTexturedQuadFilter&) = delete;
|
CTexturedQuadFilter(const CTexturedQuadFilter&) = delete;
|
||||||
CTexturedQuadFilter& operator=(const CTexturedQuadFilter&) = delete;
|
CTexturedQuadFilter& operator=(const CTexturedQuadFilter&) = delete;
|
||||||
CTexturedQuadFilter(CTexturedQuadFilter&&) = default;
|
CTexturedQuadFilter(CTexturedQuadFilter&&) = default;
|
||||||
|
@ -56,8 +58,8 @@ public:
|
||||||
class CTexturedQuadFilterAlpha : public CTexturedQuadFilter {
|
class CTexturedQuadFilterAlpha : public CTexturedQuadFilter {
|
||||||
public:
|
public:
|
||||||
explicit CTexturedQuadFilterAlpha(EFilterType type, TLockedToken<CTexture> tex);
|
explicit CTexturedQuadFilterAlpha(EFilterType type, TLockedToken<CTexture> tex);
|
||||||
template <typename Tex>
|
explicit CTexturedQuadFilterAlpha(EFilterType type, hsh::texture2d tex);
|
||||||
explicit CTexturedQuadFilterAlpha(EFilterType type, Tex tex);
|
explicit CTexturedQuadFilterAlpha(EFilterType type, hsh::render_texture2d tex);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace urde
|
} // namespace urde
|
||||||
|
|
|
@ -2,6 +2,8 @@
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
|
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
#include "zeus/CColor.hpp"
|
#include "zeus/CColor.hpp"
|
||||||
#include "zeus/CMatrix4f.hpp"
|
#include "zeus/CMatrix4f.hpp"
|
||||||
|
|
||||||
|
|
|
@ -5,11 +5,13 @@
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
#include "zeus/CMatrix4f.hpp"
|
#include "zeus/CMatrix4f.hpp"
|
||||||
|
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CTexture;
|
class CTexture;
|
||||||
|
|
||||||
class CXRayBlurFilter {
|
class CXRayBlurFilter {
|
||||||
friend struct CXRayBlurFilterPipeline;
|
public:
|
||||||
struct Vert {
|
struct Vert {
|
||||||
hsh::float2 m_pos;
|
hsh::float2 m_pos;
|
||||||
hsh::float2 m_uv;
|
hsh::float2 m_uv;
|
||||||
|
@ -17,6 +19,8 @@ class CXRayBlurFilter {
|
||||||
struct Uniform {
|
struct Uniform {
|
||||||
std::array<hsh::float4x4, 8> m_uv;
|
std::array<hsh::float4x4, 8> m_uv;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
private:
|
||||||
TLockedToken<CTexture> m_paletteTex;
|
TLockedToken<CTexture> m_paletteTex;
|
||||||
hsh::owner<hsh::vertex_buffer<Vert>> m_vbo;
|
hsh::owner<hsh::vertex_buffer<Vert>> m_vbo;
|
||||||
hsh::dynamic_owner<hsh::uniform_buffer<Uniform>> m_uniBuf;
|
hsh::dynamic_owner<hsh::uniform_buffer<Uniform>> m_uniBuf;
|
||||||
|
|
|
@ -8,6 +8,9 @@
|
||||||
#include "Runtime/IOStreams.hpp"
|
#include "Runtime/IOStreams.hpp"
|
||||||
#include "Runtime/GuiSys/CGuiObject.hpp"
|
#include "Runtime/GuiSys/CGuiObject.hpp"
|
||||||
|
|
||||||
|
// FIXME move extent/rect/etc to builtin_types
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
#include "zeus/CColor.hpp"
|
#include "zeus/CColor.hpp"
|
||||||
#include "zeus/CTransform.hpp"
|
#include "zeus/CTransform.hpp"
|
||||||
#include "zeus/CVector3f.hpp"
|
#include "zeus/CVector3f.hpp"
|
||||||
|
|
|
@ -148,7 +148,7 @@ public:
|
||||||
const char16_t* str, int len) const;
|
const char16_t* str, int len) const;
|
||||||
const CGlyph* GetGlyph(char16_t chr) const { return InternalGetGlyph(chr); }
|
const CGlyph* GetGlyph(char16_t chr) const { return InternalGetGlyph(chr); }
|
||||||
void GetSize(const CDrawStringOptions& opts, int& width, int& height, const char16_t* str, int len) const;
|
void GetSize(const CDrawStringOptions& opts, int& width, int& height, const char16_t* str, int len) const;
|
||||||
hsh::texture2d GetTexture() {
|
hsh::texture2d_array GetTexture() {
|
||||||
return x80_texture->GetFontTexture(x2c_mode);
|
return x80_texture->GetFontTexture(x2c_mode);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -57,8 +57,10 @@ void CTextRenderBuffer::CommitResources() {
|
||||||
m_uniBuf2 = hsh::create_dynamic_uniform_buffer<CTextSupportShader::Uniform>();
|
m_uniBuf2 = hsh::create_dynamic_uniform_buffer<CTextSupportShader::Uniform>();
|
||||||
}
|
}
|
||||||
for (BooFontCharacters& chs : m_fontCharacters) {
|
for (BooFontCharacters& chs : m_fontCharacters) {
|
||||||
|
if (!chs.m_charData.empty()) {
|
||||||
CTextSupportShader::BuildCharacterShaderBinding(*this, chs, m_drawFlags);
|
CTextSupportShader::BuildCharacterShaderBinding(*this, chs, m_drawFlags);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
for (BooImage& img : m_images) {
|
for (BooImage& img : m_images) {
|
||||||
CTextSupportShader::BuildImageShaderBinding(*this, img, m_drawFlags);
|
CTextSupportShader::BuildImageShaderBinding(*this, img, m_drawFlags);
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,6 +9,8 @@
|
||||||
#include "Runtime/GuiSys/CFontImageDef.hpp"
|
#include "Runtime/GuiSys/CFontImageDef.hpp"
|
||||||
#include "Runtime/GuiSys/CGuiWidget.hpp"
|
#include "Runtime/GuiSys/CGuiWidget.hpp"
|
||||||
|
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
#include "zeus/CColor.hpp"
|
#include "zeus/CColor.hpp"
|
||||||
#include "zeus/CMatrix4f.hpp"
|
#include "zeus/CMatrix4f.hpp"
|
||||||
#include "zeus/CVector2f.hpp"
|
#include "zeus/CVector2f.hpp"
|
||||||
|
|
|
@ -209,7 +209,6 @@ void CGameArchitectureSupport::specialKeyUp(boo2::Keycode key, boo2::KeyModifier
|
||||||
|
|
||||||
CMain::CMain(IFactory* resFactory, CSimplePool* resStore, hsh::surface surface)
|
CMain::CMain(IFactory* resFactory, CSimplePool* resStore, hsh::surface surface)
|
||||||
: x128_globalObjects(std::make_unique<CGameGlobalObjects>(resFactory, resStore)) {
|
: x128_globalObjects(std::make_unique<CGameGlobalObjects>(resFactory, resStore)) {
|
||||||
CGraphics::InitializeBoo(surface);
|
|
||||||
xe4_gameplayResult = EGameplayResult::Playing;
|
xe4_gameplayResult = EGameplayResult::Playing;
|
||||||
g_Main = this;
|
g_Main = this;
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,6 +74,7 @@ CParticleSwoosh::CParticleSwoosh(const TToken<CSwooshDescription>& desc, int len
|
||||||
m_cachedVerts.reserve(maxVerts);
|
m_cachedVerts.reserve(maxVerts);
|
||||||
m_vertBuf = hsh::create_dynamic_vertex_buffer<CParticleSwooshShaders::Vert>(maxVerts);
|
m_vertBuf = hsh::create_dynamic_vertex_buffer<CParticleSwooshShaders::Vert>(maxVerts);
|
||||||
m_uniformBuf = hsh::create_dynamic_uniform_buffer<CParticleSwooshShaders::Uniform>();
|
m_uniformBuf = hsh::create_dynamic_uniform_buffer<CParticleSwooshShaders::Uniform>();
|
||||||
|
CParticleSwooshShaders::BuildShaderDataBinding(*this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -628,7 +628,7 @@ void CActorModelParticles::LightDudeOnFire(CActor& act) {
|
||||||
const CTexture* CActorModelParticles::GetAshyTexture(const CActor& act) {
|
const CTexture* CActorModelParticles::GetAshyTexture(const CActor& act) {
|
||||||
auto iter = FindSystem(act.GetUniqueId());
|
auto iter = FindSystem(act.GetUniqueId());
|
||||||
if (iter != x0_items.cend() && iter->xdc_ashy && iter->xdc_ashy.IsLoaded()) {
|
if (iter != x0_items.cend() && iter->xdc_ashy && iter->xdc_ashy.IsLoaded()) {
|
||||||
iter->xdc_ashy->GetBooTexture()->setClampMode(boo::TextureClampMode::ClampToEdge);
|
//iter->xdc_ashy->GetBooTexture()->setClampMode(boo::TextureClampMode::ClampToEdge);
|
||||||
return iter->xdc_ashy.GetObj();
|
return iter->xdc_ashy.GetObj();
|
||||||
}
|
}
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
|
|
@ -4,6 +4,8 @@
|
||||||
#include "Runtime/rstl.hpp"
|
#include "Runtime/rstl.hpp"
|
||||||
#include "Runtime/World/CRippleManager.hpp"
|
#include "Runtime/World/CRippleManager.hpp"
|
||||||
|
|
||||||
|
#include "hsh/hsh.h"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
|
|
||||||
class CStateManager;
|
class CStateManager;
|
||||||
|
|
|
@ -290,7 +290,7 @@ void CWorldTransManager::DrawEnabled() {
|
||||||
DrawFirstPass(&lights);
|
DrawFirstPass(&lights);
|
||||||
SClipScreenRect rect(g_Viewport);
|
SClipScreenRect rect(g_Viewport);
|
||||||
CGraphics::ResolveSpareTexture(rect);
|
CGraphics::ResolveSpareTexture(rect);
|
||||||
CGraphics::g_BooMainCommandQueue->clearTarget(true, true);
|
hsh::clear_attachments();
|
||||||
DrawSecondPass(&lights);
|
DrawSecondPass(&lights);
|
||||||
m_dissolve.drawCropped(zeus::CColor{1.f, 1.f, 1.f, 1.f - t}, 1.f);
|
m_dissolve.drawCropped(zeus::CColor{1.f, 1.f, 1.f, 1.f - t}, 1.f);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue