2023-07-02 21:27:24 -05:00
|
|
|
// Copyright 2023 Dolphin Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2023-10-15 16:34:06 -05:00
|
|
|
#include <array>
|
2023-07-02 21:27:24 -05:00
|
|
|
#include <string>
|
|
|
|
#include <variant>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include <picojson.h>
|
|
|
|
|
|
|
|
#include "Common/CommonTypes.h"
|
|
|
|
#include "Common/EnumFormatter.h"
|
|
|
|
#include "VideoCommon/Assets/CustomAsset.h"
|
|
|
|
|
2023-10-15 16:34:06 -05:00
|
|
|
class ShaderCode;
|
|
|
|
|
2023-07-02 21:27:24 -05:00
|
|
|
namespace VideoCommon
|
|
|
|
{
|
|
|
|
struct MaterialProperty
|
|
|
|
{
|
2023-10-15 16:34:06 -05:00
|
|
|
static void WriteToMemory(u8*& buffer, const MaterialProperty& property);
|
|
|
|
static std::size_t GetMemorySize(const MaterialProperty& property);
|
|
|
|
static void WriteAsShaderCode(ShaderCode& shader_source, const MaterialProperty& property);
|
|
|
|
using Value = std::variant<CustomAssetLibrary::AssetID, s32, std::array<s32, 2>,
|
|
|
|
std::array<s32, 3>, std::array<s32, 4>, float, std::array<float, 2>,
|
|
|
|
std::array<float, 3>, std::array<float, 4>, bool>;
|
2023-07-02 21:27:24 -05:00
|
|
|
std::string m_code_name;
|
2023-10-15 16:34:06 -05:00
|
|
|
Value m_value;
|
2023-07-02 21:27:24 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
struct MaterialData
|
|
|
|
{
|
|
|
|
static bool FromJson(const CustomAssetLibrary::AssetID& asset_id, const picojson::object& json,
|
|
|
|
MaterialData* data);
|
2024-01-23 12:47:00 -06:00
|
|
|
static void ToJson(picojson::object* obj, const MaterialData& data);
|
2023-07-02 21:27:24 -05:00
|
|
|
std::string shader_asset;
|
|
|
|
std::vector<MaterialProperty> properties;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Much like Unity and Unreal materials, a Dolphin material does very little on its own
|
|
|
|
// Its sole purpose is to provide data (through properties) that are used in conjunction
|
|
|
|
// with a shader asset that is provided by name. It is up to user of this asset to
|
|
|
|
// use the two together to create the relevant runtime data
|
|
|
|
class MaterialAsset final : public CustomLoadableAsset<MaterialData>
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
using CustomLoadableAsset::CustomLoadableAsset;
|
|
|
|
|
|
|
|
private:
|
|
|
|
CustomAssetLibrary::LoadInfo LoadImpl(const CustomAssetLibrary::AssetID& asset_id) override;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace VideoCommon
|