feat(model): set material parameter
This commit is contained in:
@@ -42,7 +42,7 @@ global_counter = "0.2.2"
|
|||||||
[dependencies.stereokit]
|
[dependencies.stereokit]
|
||||||
default-features = false
|
default-features = false
|
||||||
features = ["linux-egl", "color_named", "prisma"]
|
features = ["linux-egl", "color_named", "prisma"]
|
||||||
version = "0.10.0"
|
version = "0.11.0"
|
||||||
|
|
||||||
[dependencies.smithay]
|
[dependencies.smithay]
|
||||||
git = "https://github.com/technobaboo/smithay.git" # Until we get stereokit to understand OES samplers and external textures
|
git = "https://github.com/technobaboo/smithay.git" # Until we get stereokit to understand OES samplers and external textures
|
||||||
@@ -54,3 +54,8 @@ optional = true
|
|||||||
[features]
|
[features]
|
||||||
default = ["wayland"]
|
default = ["wayland"]
|
||||||
wayland = ["dep:smithay", "dep:xkbcommon"]
|
wayland = ["dep:smithay", "dep:xkbcommon"]
|
||||||
|
|
||||||
|
[patch.crates-io.stereokit]
|
||||||
|
path = "../stereokit-rs"
|
||||||
|
# [patch.crates-io.stereokit-sys]
|
||||||
|
# path = "../stereokit-sys"
|
||||||
@@ -5,6 +5,7 @@ use crate::core::registry::Registry;
|
|||||||
use crate::core::resource::ResourceID;
|
use crate::core::resource::ResourceID;
|
||||||
use crate::nodes::spatial::{find_spatial_parent, parse_transform, Spatial};
|
use crate::nodes::spatial::{find_spatial_parent, parse_transform, Spatial};
|
||||||
use color_eyre::eyre::{ensure, eyre, Result};
|
use color_eyre::eyre::{ensure, eyre, Result};
|
||||||
|
use mint::{ColumnMatrix4, Vector2, Vector3, Vector4};
|
||||||
use once_cell::sync::OnceCell;
|
use once_cell::sync::OnceCell;
|
||||||
use parking_lot::Mutex;
|
use parking_lot::Mutex;
|
||||||
use rustc_hash::FxHashMap;
|
use rustc_hash::FxHashMap;
|
||||||
@@ -17,19 +18,96 @@ use std::fmt::Error;
|
|||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
use stereokit::color_named::WHITE;
|
use stereokit::color_named::WHITE;
|
||||||
use stereokit::lifecycle::StereoKitDraw;
|
use stereokit::lifecycle::{StereoKitContext, StereoKitDraw};
|
||||||
use stereokit::material::Material;
|
use stereokit::material::Material;
|
||||||
use stereokit::model::Model as SKModel;
|
use stereokit::model::Model as SKModel;
|
||||||
use stereokit::render::RenderLayer;
|
use stereokit::render::RenderLayer;
|
||||||
use stereokit::texture::Texture;
|
use stereokit::texture::Texture;
|
||||||
|
use stereokit::values::Color128;
|
||||||
|
|
||||||
static MODEL_REGISTRY: Registry<Model> = Registry::new();
|
static MODEL_REGISTRY: Registry<Model> = Registry::new();
|
||||||
|
|
||||||
#[derive(Deserialize, Debug)]
|
#[derive(Deserialize, Debug)]
|
||||||
#[serde(untagged)]
|
#[serde(tag = "t", content = "c")]
|
||||||
pub enum MaterialParameter {
|
pub enum MaterialParameter {
|
||||||
|
Float(f32),
|
||||||
|
Vector2(Vector2<f32>),
|
||||||
|
Vector3(Vector3<f32>),
|
||||||
|
Vector4(Vector4<f32>),
|
||||||
|
Color([f32; 4]),
|
||||||
|
Int(i32),
|
||||||
|
Int2(Vector2<i32>),
|
||||||
|
Int3(Vector3<i32>),
|
||||||
|
Int4(Vector4<i32>),
|
||||||
|
Bool(bool),
|
||||||
|
UInt(u32),
|
||||||
|
UInt2(Vector2<u32>),
|
||||||
|
UInt3(Vector3<u32>),
|
||||||
|
UInt4(Vector4<u32>),
|
||||||
|
Matrix(ColumnMatrix4<f32>),
|
||||||
Texture(PathBuf),
|
Texture(PathBuf),
|
||||||
}
|
}
|
||||||
|
impl MaterialParameter {
|
||||||
|
fn apply_to_material(
|
||||||
|
&self,
|
||||||
|
sk: &impl StereoKitContext,
|
||||||
|
material: &Material,
|
||||||
|
parameter_name: &str,
|
||||||
|
) {
|
||||||
|
match self {
|
||||||
|
MaterialParameter::Float(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::Vector2(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::Vector3(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::Vector4(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::Color(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, &Color128::from(val.clone()));
|
||||||
|
}
|
||||||
|
MaterialParameter::Int(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::Int2(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::Int3(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::Int4(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::Bool(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::UInt(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::UInt2(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::UInt3(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::UInt4(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::Matrix(val) => {
|
||||||
|
material.set_parameter(sk, parameter_name, val);
|
||||||
|
}
|
||||||
|
MaterialParameter::Texture(path) => {
|
||||||
|
if let Some(tex) = Texture::from_file(sk, path.as_path(), true, 0) {
|
||||||
|
material.set_parameter(sk, parameter_name, &tex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub struct Model {
|
pub struct Model {
|
||||||
space: Arc<Spatial>,
|
space: Arc<Spatial>,
|
||||||
@@ -58,7 +136,7 @@ impl Model {
|
|||||||
pending_material_replacements: Mutex::new(FxHashMap::default()),
|
pending_material_replacements: Mutex::new(FxHashMap::default()),
|
||||||
sk_model: OnceCell::new(),
|
sk_model: OnceCell::new(),
|
||||||
};
|
};
|
||||||
node.add_local_signal("set_material_parameter", Model::set_material_parameter);
|
node.add_local_signal("set_material_parameter", Model::set_material_parameter_flex);
|
||||||
let model_arc = MODEL_REGISTRY.add(model);
|
let model_arc = MODEL_REGISTRY.add(model);
|
||||||
let _ = model_arc.pending_model_path.set(
|
let _ = model_arc.pending_model_path.set(
|
||||||
model_arc
|
model_arc
|
||||||
@@ -78,7 +156,7 @@ impl Model {
|
|||||||
Ok(model_arc)
|
Ok(model_arc)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn set_material_parameter(
|
fn set_material_parameter_flex(
|
||||||
node: &Node,
|
node: &Node,
|
||||||
_calling_client: Arc<Client>,
|
_calling_client: Arc<Client>,
|
||||||
data: &[u8],
|
data: &[u8],
|
||||||
@@ -126,13 +204,7 @@ impl Model {
|
|||||||
for ((material_idx, parameter_name), parameter_value) in material_parameters.iter()
|
for ((material_idx, parameter_name), parameter_value) in material_parameters.iter()
|
||||||
{
|
{
|
||||||
if let Some(material) = sk_model.get_material(sk, *material_idx as i32) {
|
if let Some(material) = sk_model.get_material(sk, *material_idx as i32) {
|
||||||
match parameter_value {
|
parameter_value.apply_to_material(sk, &material, parameter_name.as_str());
|
||||||
MaterialParameter::Texture(path) => {
|
|
||||||
if let Some(tex) = Texture::from_file(sk, path.as_path(), true, 0) {
|
|
||||||
material.set_parameter(sk, parameter_name.as_str(), &tex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
material_parameters.clear();
|
material_parameters.clear();
|
||||||
|
|||||||
Reference in New Issue
Block a user