2
0
mirror of https://github.com/AxioDL/metaforce.git synced 2025-07-05 19:15:52 +00:00

CAABoxShader: Convert to hsh pipeline

This commit is contained in:
Luke Street 2020-09-29 00:58:21 -04:00
parent f4f840cb17
commit fc9e18fe46
6 changed files with 58 additions and 57 deletions

View File

@ -1,55 +1,57 @@
#include "Runtime/Graphics/Shaders/CAABoxShader.hpp" #include "Runtime/Graphics/Shaders/CAABoxShader.hpp"
#include <array> #include <array>
#include "Runtime/Graphics/CGraphics.hpp"
#include <hecl/Pipeline.hpp>
#include <zeus/CAABox.hpp> #include <zeus/CAABox.hpp>
#include "Runtime/Graphics/CGraphics.hpp"
#include "CAABoxShader.cpp.hshhead"
namespace urde { namespace urde {
using namespace hsh::pipeline;
CAABoxShader::CAABoxShader(bool zOnly) { template <bool zOnly>
CGraphics::CommitResources([this, zOnly](boo::IGraphicsDataFactory::Context& ctx) { struct CAABoxShaderPipeline
m_vbo = ctx.newDynamicBuffer(boo::BufferUse::Vertex, sizeof(zeus::CVector3f), 34); : pipeline<topology<hsh::TriangleStrip>, std::conditional_t<zOnly, NoColorAttachment<>, BlendAttachment<>>,
m_uniBuf = ctx.newDynamicBuffer(boo::BufferUse::Uniform, sizeof(Uniform), 1); depth_compare<hsh::LEqual>, depth_write<true>, cull_mode<hsh::CullNone>> {
const std::array<boo::ObjToken<boo::IGraphicsBuffer>, 1> bufs{m_uniBuf.get()}; CAABoxShaderPipeline(hsh::vertex_buffer<CAABoxShader::Vert> vbo, hsh::uniform_buffer<CAABoxShader::Uniform> uniBuf) {
constexpr std::array<boo::PipelineStage, 1> stages{boo::PipelineStage::Vertex}; this->position = uniBuf->m_xf * hsh::float4(vbo->m_pos, 1.f);
m_dataBind = this->color_out[0] = uniBuf->m_color;
ctx.newShaderDataBinding(zOnly ? s_zOnlyPipeline : s_Pipeline, m_vbo.get(), nullptr, nullptr, bufs.size(), }
bufs.data(), stages.data(), nullptr, nullptr, 0, nullptr, nullptr, nullptr); };
return true; template struct CAABoxShaderPipeline<true>;
} BooTrace); template struct CAABoxShaderPipeline<false>;
}
void CAABoxShader::setAABB(const zeus::CAABox& aabb) { CAABoxShader::CAABoxShader(const zeus::CAABox& aabb, bool zOnly) {
const std::array<zeus::CVector3f, 34> vboData{{ const std::array<Vert, 34> verts{{
{aabb.max.x(), aabb.max.y(), aabb.min.z()}, {aabb.max.x(), aabb.min.y(), aabb.min.z()}, {{aabb.max.x(), aabb.max.y(), aabb.min.z()}}, {{aabb.max.x(), aabb.min.y(), aabb.min.z()}},
{aabb.max.x(), aabb.max.y(), aabb.max.z()}, {aabb.max.x(), aabb.min.y(), aabb.max.z()}, {{aabb.max.x(), aabb.max.y(), aabb.max.z()}}, {{aabb.max.x(), aabb.min.y(), aabb.max.z()}},
{aabb.max.x(), aabb.min.y(), aabb.max.z()}, {{aabb.max.x(), aabb.min.y(), aabb.max.z()}},
{aabb.min.x(), aabb.max.y(), aabb.min.z()}, {aabb.min.x(), aabb.max.y(), aabb.min.z()}, {{aabb.min.x(), aabb.max.y(), aabb.min.z()}}, {{aabb.min.x(), aabb.max.y(), aabb.min.z()}},
{aabb.max.x(), aabb.max.y(), aabb.min.z()}, {aabb.min.x(), aabb.max.y(), aabb.max.z()}, {{aabb.max.x(), aabb.max.y(), aabb.min.z()}}, {{aabb.min.x(), aabb.max.y(), aabb.max.z()}},
{aabb.max.x(), aabb.max.y(), aabb.max.z()}, {aabb.max.x(), aabb.max.y(), aabb.max.z()}, {{aabb.max.x(), aabb.max.y(), aabb.max.z()}}, {{aabb.max.x(), aabb.max.y(), aabb.max.z()}},
{aabb.min.x(), aabb.max.y(), aabb.min.z()}, {aabb.min.x(), aabb.max.y(), aabb.min.z()}, {{aabb.min.x(), aabb.max.y(), aabb.min.z()}}, {{aabb.min.x(), aabb.max.y(), aabb.min.z()}},
{aabb.min.x(), aabb.min.y(), aabb.min.z()}, {aabb.min.x(), aabb.max.y(), aabb.max.z()}, {{aabb.min.x(), aabb.min.y(), aabb.min.z()}}, {{aabb.min.x(), aabb.max.y(), aabb.max.z()}},
{aabb.min.x(), aabb.min.y(), aabb.max.z()}, {aabb.min.x(), aabb.min.y(), aabb.max.z()}, {{aabb.min.x(), aabb.min.y(), aabb.max.z()}}, {{aabb.min.x(), aabb.min.y(), aabb.max.z()}},
{aabb.min.x(), aabb.min.y(), aabb.min.z()}, {aabb.min.x(), aabb.min.y(), aabb.min.z()}, {{aabb.min.x(), aabb.min.y(), aabb.min.z()}}, {{aabb.min.x(), aabb.min.y(), aabb.min.z()}},
{aabb.max.x(), aabb.min.y(), aabb.min.z()}, {aabb.min.x(), aabb.min.y(), aabb.max.z()}, {{aabb.max.x(), aabb.min.y(), aabb.min.z()}}, {{aabb.min.x(), aabb.min.y(), aabb.max.z()}},
{aabb.max.x(), aabb.min.y(), aabb.max.z()}, {aabb.max.x(), aabb.min.y(), aabb.max.z()}, {{aabb.max.x(), aabb.min.y(), aabb.max.z()}}, {{aabb.max.x(), aabb.min.y(), aabb.max.z()}},
{aabb.min.x(), aabb.min.y(), aabb.max.z()}, {aabb.min.x(), aabb.min.y(), aabb.max.z()}, {{aabb.min.x(), aabb.min.y(), aabb.max.z()}}, {{aabb.min.x(), aabb.min.y(), aabb.max.z()}},
{aabb.max.x(), aabb.min.y(), aabb.max.z()}, {aabb.min.x(), aabb.max.y(), aabb.max.z()}, {{aabb.max.x(), aabb.min.y(), aabb.max.z()}}, {{aabb.min.x(), aabb.max.y(), aabb.max.z()}},
{aabb.max.x(), aabb.max.y(), aabb.max.z()}, {aabb.max.x(), aabb.max.y(), aabb.max.z()}, {{aabb.max.x(), aabb.max.y(), aabb.max.z()}}, {{aabb.max.x(), aabb.max.y(), aabb.max.z()}},
{aabb.min.x(), aabb.min.y(), aabb.min.z()}, {aabb.min.x(), aabb.min.y(), aabb.min.z()}, {{aabb.min.x(), aabb.min.y(), aabb.min.z()}}, {{aabb.min.x(), aabb.min.y(), aabb.min.z()}},
{aabb.max.x(), aabb.min.y(), aabb.min.z()}, {aabb.min.x(), aabb.max.y(), aabb.min.z()}, {{aabb.max.x(), aabb.min.y(), aabb.min.z()}}, {{aabb.min.x(), aabb.max.y(), aabb.min.z()}},
{aabb.max.x(), aabb.max.y(), aabb.min.z()}, {{aabb.max.x(), aabb.max.y(), aabb.min.z()}},
}}; }};
m_vbo->load(vboData.data(), sizeof(vboData)); m_vbo = hsh::create_vertex_buffer(verts);
m_uniBuf = hsh::create_dynamic_uniform_buffer<Uniform>();
m_dataBind.hsh_bind(CAABoxShaderPipeline<zOnly>(m_vbo.get(), m_uniBuf.get()));
} }
void CAABoxShader::draw(const zeus::CColor& color) { void CAABoxShader::draw(const zeus::CColor& color) {
@ -57,10 +59,9 @@ void CAABoxShader::draw(const zeus::CColor& color) {
m_uniform.m_xf = CGraphics::GetPerspectiveProjectionMatrix(true) * CGraphics::g_GXModelView.toMatrix4f(); m_uniform.m_xf = CGraphics::GetPerspectiveProjectionMatrix(true) * CGraphics::g_GXModelView.toMatrix4f();
m_uniform.m_color = color; m_uniform.m_color = color;
m_uniBuf->load(&m_uniform, sizeof(Uniform)); m_uniBuf.load(m_uniform);
CGraphics::SetShaderDataBinding(m_dataBind); m_dataBind.draw(0, 34);
CGraphics::DrawArray(0, 34);
} }
} // namespace urde } // namespace urde

View File

@ -1,15 +1,15 @@
#pragma once #pragma once
#include "zeus/CColor.hpp" #include "hsh/hsh.h"
#include "zeus/CMatrix4f.hpp"
namespace zeus { namespace zeus {
class CColor;
class CAABox; class CAABox;
} } // namespace zeus
namespace urde { namespace urde {
class CAABoxShader { class CAABoxShader {
public:
struct Vert { struct Vert {
hsh::float3 m_pos; hsh::float3 m_pos;
}; };
@ -17,14 +17,15 @@ class CAABoxShader {
hsh::float4x4 m_xf; hsh::float4x4 m_xf;
hsh::float4 m_color; hsh::float4 m_color;
}; };
private:
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;
hsh::binding m_dataBind; hsh::binding m_dataBind;
Uniform m_uniform; Uniform m_uniform{};
public: public:
explicit CAABoxShader(bool zOnly = false); CAABoxShader(const zeus::CAABox& aabb, bool zOnly = false);
void setAABB(const zeus::CAABox& aabb);
void draw(const zeus::CColor& color); void draw(const zeus::CColor& color);
}; };

View File

@ -17,11 +17,11 @@ CPhazonBeam::CPhazonBeam(CAssetId characterId, EWeaponType type, TUniqueId playe
, x238_aaBoxScale(zeus::CVector3f(-0.14664599f, 0.f, -0.14909725f) * scale.y(), , x238_aaBoxScale(zeus::CVector3f(-0.14664599f, 0.f, -0.14909725f) * scale.y(),
zeus::CVector3f(0.14664599f, 0.64619601f, 0.14909725f) * scale.y()) zeus::CVector3f(0.14664599f, 0.64619601f, 0.14909725f) * scale.y())
, x250_aaBoxTranslate(zeus::CVector3f(-0.0625f, 0.f, -0.09375f) * scale.y(), , x250_aaBoxTranslate(zeus::CVector3f(-0.0625f, 0.f, -0.09375f) * scale.y(),
zeus::CVector3f(0.0625f, -0.25f, 0.09375f) * scale.y()) { zeus::CVector3f(0.0625f, -0.25f, 0.09375f) * scale.y())
, m_aaboxShaderScale(x238_aaBoxScale, true)
, m_aaboxShaderTranslate(x250_aaBoxTranslate, true) {
x21c_phazonVeins = g_SimplePool->GetObj("PhazonVeins"); x21c_phazonVeins = g_SimplePool->GetObj("PhazonVeins");
x228_phazon2nd1 = g_SimplePool->GetObj("Phazon2nd_1"); x228_phazon2nd1 = g_SimplePool->GetObj("Phazon2nd_1");
m_aaboxShaderScale.setAABB(x238_aaBoxScale);
m_aaboxShaderTranslate.setAABB(x250_aaBoxTranslate);
} }
void CPhazonBeam::AcceptScriptMsg(EScriptObjectMessage msg, TUniqueId sender, CStateManager& mgr) { void CPhazonBeam::AcceptScriptMsg(EScriptObjectMessage msg, TUniqueId sender, CStateManager& mgr) {
@ -216,4 +216,4 @@ void CPhazonBeam::DrawMuzzleFx(const CStateManager& mgr) const {
CGunWeapon::DrawMuzzleFx(mgr); CGunWeapon::DrawMuzzleFx(mgr);
} }
} // namespace urde } // namespace urde

View File

@ -22,8 +22,8 @@ class CPhazonBeam final : public CGunWeapon {
bool x274_26_veinsAlphaActive : 1 = false; bool x274_26_veinsAlphaActive : 1 = false;
bool x274_27_phazonVeinsIdx : 1 = false; bool x274_27_phazonVeinsIdx : 1 = false;
float x278_fireTime = 1.f / 3.f; float x278_fireTime = 1.f / 3.f;
CAABoxShader m_aaboxShaderScale{true}; CAABoxShader m_aaboxShaderScale;
CAABoxShader m_aaboxShaderTranslate{true}; CAABoxShader m_aaboxShaderTranslate;
void ReInitVariables(); void ReInitVariables();
void DrawClipScaleCube(); void DrawClipScaleCube();
void DrawClipTranslateCube(); void DrawClipTranslateCube();

View File

@ -131,7 +131,8 @@ CPlayerGun::CPlayerGun(TUniqueId playerId)
, x678_morph(g_tweakPlayerGun->GetGunTransformTime(), g_tweakPlayerGun->GetHoloHoldTime()) , x678_morph(g_tweakPlayerGun->GetGunTransformTime(), g_tweakPlayerGun->GetHoloHoldTime())
, x6c8_hologramClipCube(zeus::CVector3f(-0.29329199f, 0.f, -0.2481945f), , x6c8_hologramClipCube(zeus::CVector3f(-0.29329199f, 0.f, -0.2481945f),
zeus::CVector3f(0.29329199f, 1.292392f, 0.2481945f)) zeus::CVector3f(0.29329199f, 1.292392f, 0.2481945f))
, x6e0_rightHandModel(CAnimRes(g_tweakGunRes->xc_rightHand, 0, zeus::CVector3f(3.f), 0, true)) { , x6e0_rightHandModel(CAnimRes(g_tweakGunRes->xc_rightHand, 0, zeus::CVector3f(3.f), 0, true))
, m_aaboxShader(x6c8_hologramClipCube, true) {
x354_bombFuseTime = g_tweakPlayerGun->GetBombFuseTime(); x354_bombFuseTime = g_tweakPlayerGun->GetBombFuseTime();
x358_bombDropDelayTime = g_tweakPlayerGun->GetBombDropDelayTime(); x358_bombDropDelayTime = g_tweakPlayerGun->GetBombDropDelayTime();
x668_aimVerticalSpeed = g_tweakPlayerGun->GetAimVerticalSpeed(); x668_aimVerticalSpeed = g_tweakPlayerGun->GetAimVerticalSpeed();
@ -175,8 +176,6 @@ CPlayerGun::CPlayerGun(TUniqueId playerId)
x550_camBob.SetPlayerVelocity(zeus::skZero3f); x550_camBob.SetPlayerVelocity(zeus::skZero3f);
x550_camBob.SetBobMagnitude(0.f); x550_camBob.SetBobMagnitude(0.f);
x550_camBob.SetBobTimeScale(0.f); x550_camBob.SetBobTimeScale(0.f);
m_aaboxShader.setAABB(x6c8_hologramClipCube);
} }
void CPlayerGun::InitBeamData() { void CPlayerGun::InitBeamData() {

View File

@ -258,7 +258,7 @@ private:
CTexturedQuadFilter m_screenQuad{EFilterType::Blend, CGraphics::g_SpareTexture.get_color(0), CTexturedQuadFilter m_screenQuad{EFilterType::Blend, CGraphics::g_SpareTexture.get_color(0),
CTexturedQuadFilter::ZTest::GEqualZWrite}; CTexturedQuadFilter::ZTest::GEqualZWrite};
CAABoxShader m_aaboxShader{true}; CAABoxShader m_aaboxShader;
void InitBeamData(); void InitBeamData();
void InitBombData(); void InitBombData();