mirror of
https://codeberg.org/icewind/vmdl.git
synced 2026-06-03 08:34:23 +02:00
fmt
This commit is contained in:
parent
c55dec1b4f
commit
f4f173c84e
11 changed files with 134 additions and 52 deletions
|
|
@ -82,10 +82,13 @@ fn main() -> Result<(), Error> {
|
|||
..Default::default()
|
||||
};
|
||||
|
||||
let model: three_d::Model<PhysicalMaterial> = three_d::Model::new(&context, &CpuModel {
|
||||
let model: three_d::Model<PhysicalMaterial> = three_d::Model::new(
|
||||
&context,
|
||||
&CpuModel {
|
||||
materials: vec![material],
|
||||
geometries: vec![cpu_mesh],
|
||||
})?;
|
||||
},
|
||||
)?;
|
||||
|
||||
let mut directional = [
|
||||
DirectionalLight::new(&context, 1.0, Color::WHITE, &vec3(1.0, -1.0, 0.0)),
|
||||
|
|
@ -107,16 +110,19 @@ fn main() -> Result<(), Error> {
|
|||
window.render_loop(move |mut frame_input| {
|
||||
let mut change = frame_input.first_frame;
|
||||
let mut panel_width = frame_input.viewport.width;
|
||||
change |= gui
|
||||
.update(&mut frame_input.events, frame_input.accumulated_time, frame_input.viewport, frame_input.device_pixel_ratio, |gui_context| {
|
||||
change |= gui.update(
|
||||
&mut frame_input.events,
|
||||
frame_input.accumulated_time,
|
||||
frame_input.viewport,
|
||||
frame_input.device_pixel_ratio,
|
||||
|gui_context| {
|
||||
use three_d::egui::*;
|
||||
SidePanel::left("side_panel").show(gui_context, |ui| {
|
||||
ui.heading("Debug Panel");
|
||||
|
||||
ui.label("Light options");
|
||||
ui.add(
|
||||
Slider::new(&mut ambient.intensity, 0.0..=1.0)
|
||||
.text("Ambient intensity"),
|
||||
Slider::new(&mut ambient.intensity, 0.0..=1.0).text("Ambient intensity"),
|
||||
);
|
||||
ui.add(
|
||||
Slider::new(&mut directional_intensity, 0.0..=1.0)
|
||||
|
|
@ -149,7 +155,8 @@ fn main() -> Result<(), Error> {
|
|||
ui.add(Label::new(format!("\tz: {}", camera.position().z)));
|
||||
});
|
||||
panel_width = gui_context.used_size().x as u32;
|
||||
});
|
||||
},
|
||||
);
|
||||
|
||||
let viewport = Viewport {
|
||||
x: panel_width as i32,
|
||||
|
|
@ -158,70 +165,71 @@ fn main() -> Result<(), Error> {
|
|||
height: frame_input.viewport.height,
|
||||
};
|
||||
change |= camera.set_viewport(viewport);
|
||||
change |= control
|
||||
.handle_events(&mut camera, &mut frame_input.events);
|
||||
change |= control.handle_events(&mut camera, &mut frame_input.events);
|
||||
|
||||
// Draw
|
||||
{
|
||||
camera
|
||||
.set_perspective_projection(degrees(fov), camera.z_near(), camera.z_far());
|
||||
camera.set_perspective_projection(degrees(fov), camera.z_near(), camera.z_far());
|
||||
if shadows_enabled {
|
||||
directional[0]
|
||||
.generate_shadow_map(1024, model.iter().map(|gm| &gm.geometry));
|
||||
directional[1]
|
||||
.generate_shadow_map(1024, model.iter().map(|gm| &gm.geometry));
|
||||
directional[0].generate_shadow_map(1024, model.iter().map(|gm| &gm.geometry));
|
||||
directional[1].generate_shadow_map(1024, model.iter().map(|gm| &gm.geometry));
|
||||
}
|
||||
|
||||
|
||||
let lights = &[
|
||||
&ambient as &dyn Light,
|
||||
&directional[0],
|
||||
&directional[1],
|
||||
];
|
||||
let lights = &[&ambient as &dyn Light, &directional[0], &directional[1]];
|
||||
|
||||
// Light pass
|
||||
let screen = frame_input.screen();
|
||||
let target = screen.clear(ClearState::default());
|
||||
match debug_type {
|
||||
DebugType::NORMAL => {
|
||||
target.render_with_material(
|
||||
DebugType::NORMAL => target.render_with_material(
|
||||
&NormalMaterial::from_physical_material(&ph_material),
|
||||
&camera,
|
||||
model.iter().map(|gm| &gm.geometry),
|
||||
lights,
|
||||
)
|
||||
}
|
||||
),
|
||||
DebugType::DEPTH => {
|
||||
let mut depth_material = DepthMaterial::default();
|
||||
depth_material.max_distance = Some(depth_max);
|
||||
target.render_with_material(&depth_material, &camera, model.iter().map(|gm| &gm.geometry), lights)
|
||||
}
|
||||
DebugType::ORM => {
|
||||
target.render_with_material(
|
||||
&depth_material,
|
||||
&camera,
|
||||
model.iter().map(|gm| &gm.geometry),
|
||||
lights,
|
||||
)
|
||||
}
|
||||
DebugType::ORM => target.render_with_material(
|
||||
&ORMMaterial::from_physical_material(&ph_material),
|
||||
&camera,
|
||||
model.iter().map(|gm| &gm.geometry),
|
||||
lights,
|
||||
)
|
||||
}
|
||||
),
|
||||
DebugType::POSITION => {
|
||||
let position_material = PositionMaterial::default();
|
||||
target.render_with_material(&position_material, &camera, model.iter().map(|gm| &gm.geometry), lights)
|
||||
}
|
||||
DebugType::UV => {
|
||||
let uv_material = UVMaterial::default();
|
||||
target.render_with_material(&uv_material, &camera, model.iter().map(|gm| &gm.geometry), lights)
|
||||
}
|
||||
DebugType::COLOR => {
|
||||
target.render_with_material(
|
||||
&ColorMaterial::from_physical_material(&ph_material),
|
||||
&position_material,
|
||||
&camera,
|
||||
model.iter().map(|gm| &gm.geometry),
|
||||
lights,
|
||||
)
|
||||
}
|
||||
DebugType::UV => {
|
||||
let uv_material = UVMaterial::default();
|
||||
target.render_with_material(
|
||||
&uv_material,
|
||||
&camera,
|
||||
model.iter().map(|gm| &gm.geometry),
|
||||
lights,
|
||||
)
|
||||
}
|
||||
DebugType::COLOR => target.render_with_material(
|
||||
&ColorMaterial::from_physical_material(&ph_material),
|
||||
&camera,
|
||||
model.iter().map(|gm| &gm.geometry),
|
||||
lights,
|
||||
),
|
||||
DebugType::NONE => target.render(&camera, &model, lights),
|
||||
}.write(|| gui.render());
|
||||
}
|
||||
.write(|| gui.render());
|
||||
}
|
||||
|
||||
let _ = change;
|
||||
|
|
@ -261,9 +269,7 @@ fn model_to_mesh(model: &Model) -> CpuMesh {
|
|||
let positions: Vec<Vec3> = model
|
||||
.vertices()
|
||||
.iter()
|
||||
.map(|vertex| {
|
||||
((vertex.position + offset) * UNIT_SCALE * 10.0).into()
|
||||
})
|
||||
.map(|vertex| ((vertex.position + offset) * UNIT_SCALE * 10.0).into())
|
||||
.collect();
|
||||
let normals: Vec<Vec3> = model
|
||||
.vertices()
|
||||
|
|
|
|||
1
fuzz/.envrc
Normal file
1
fuzz/.envrc
Normal file
|
|
@ -0,0 +1 @@
|
|||
use flake
|
||||
5
fuzz/.gitignore
vendored
Normal file
5
fuzz/.gitignore
vendored
Normal file
|
|
@ -0,0 +1,5 @@
|
|||
target
|
||||
corpus
|
||||
artifacts
|
||||
.direnv
|
||||
result
|
||||
25
fuzz/Cargo.toml
Normal file
25
fuzz/Cargo.toml
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
[package]
|
||||
name = "vmdl-fuzz"
|
||||
version = "0.0.0"
|
||||
authors = ["Automatically generated"]
|
||||
publish = false
|
||||
edition = "2018"
|
||||
|
||||
[package.metadata]
|
||||
cargo-fuzz = true
|
||||
|
||||
[dependencies]
|
||||
libfuzzer-sys = "0.4"
|
||||
|
||||
[dependencies.vmdl]
|
||||
path = ".."
|
||||
|
||||
# Prevent this from interfering with workspaces
|
||||
[workspace]
|
||||
members = ["."]
|
||||
|
||||
[[bin]]
|
||||
name = "fuzz_target_1"
|
||||
path = "fuzz_targets/fuzz_target_1.rs"
|
||||
test = false
|
||||
doc = false
|
||||
22
fuzz/flake.nix
Normal file
22
fuzz/flake.nix
Normal file
|
|
@ -0,0 +1,22 @@
|
|||
{
|
||||
inputs = {
|
||||
utils.url = "github:numtide/flake-utils";
|
||||
nixpkgs.url = "nixpkgs/release-22.11";
|
||||
};
|
||||
|
||||
outputs = {
|
||||
self,
|
||||
nixpkgs,
|
||||
utils,
|
||||
}:
|
||||
utils.lib.eachDefaultSystem (system: let
|
||||
pkgs = (import nixpkgs) {
|
||||
inherit system;
|
||||
};
|
||||
in rec {
|
||||
# `nix develop`
|
||||
devShell = pkgs.mkShell {
|
||||
nativeBuildInputs = with pkgs; [rustup cargo-edit cargo-fuzz];
|
||||
};
|
||||
});
|
||||
}
|
||||
6
fuzz/fuzz_targets/mdl.rs
Normal file
6
fuzz/fuzz_targets/mdl.rs
Normal file
|
|
@ -0,0 +1,6 @@
|
|||
#![no_main]
|
||||
use libfuzzer_sys::fuzz_target;
|
||||
|
||||
fuzz_target!(|data: &[u8]| {
|
||||
// fuzzed code goes here
|
||||
});
|
||||
8
fuzz/fuzz_targets/vtx.rs
Normal file
8
fuzz/fuzz_targets/vtx.rs
Normal file
|
|
@ -0,0 +1,8 @@
|
|||
#![no_main]
|
||||
use libfuzzer_sys::fuzz_target;
|
||||
|
||||
fn fuzz(data: &[u8]) {
|
||||
let _ = vmdl::Mdl::read(data).ok();
|
||||
}
|
||||
|
||||
fuzz_target!(|data: &[u8]| {fuzz(data)});
|
||||
8
fuzz/fuzz_targets/vvd.rs
Normal file
8
fuzz/fuzz_targets/vvd.rs
Normal file
|
|
@ -0,0 +1,8 @@
|
|||
#![no_main]
|
||||
use libfuzzer_sys::fuzz_target;
|
||||
|
||||
fn fuzz(data: &[u8]) {
|
||||
let _ = vmdl::Mdl::read(data).ok();
|
||||
}
|
||||
|
||||
fuzz_target!(|data: &[u8]| {fuzz(data)});
|
||||
|
|
@ -5,9 +5,10 @@ mod shared;
|
|||
pub mod vtx;
|
||||
pub mod vvd;
|
||||
|
||||
use crate::mdl::Mdl;
|
||||
use crate::vtx::Vtx;
|
||||
use crate::vvd::{Vertex, Vvd};
|
||||
pub use crate::mdl::Mdl;
|
||||
pub use crate::vtx::Vtx;
|
||||
use crate::vvd::Vertex;
|
||||
pub use crate::vvd::Vvd;
|
||||
use bytemuck::{pod_read_unaligned, Pod};
|
||||
pub use error::*;
|
||||
pub use handle::Handle;
|
||||
|
|
|
|||
|
|
@ -1,12 +1,12 @@
|
|||
mod raw;
|
||||
|
||||
use std::mem::size_of;
|
||||
pub use raw::header::*;
|
||||
pub use raw::header2::*;
|
||||
use std::mem::size_of;
|
||||
|
||||
use crate::mdl::raw::{BodyPartHeader, Bone, MeshHeader, ModelHeader};
|
||||
use crate::{read_indexes, read_relative, FixedString, ModelError, ReadRelative, Readable};
|
||||
use crate::vvd::Vertex;
|
||||
use crate::{read_indexes, read_relative, FixedString, ModelError, ReadRelative, Readable};
|
||||
|
||||
type Result<T> = std::result::Result<T, ModelError>;
|
||||
|
||||
|
|
|
|||
|
|
@ -1,10 +1,10 @@
|
|||
use crate::{ModelError, StringError};
|
||||
use arrayvec::ArrayString;
|
||||
use bytemuck::{Pod, Zeroable};
|
||||
use cgmath::Vector3;
|
||||
use std::fmt;
|
||||
use std::fmt::{Display, Formatter};
|
||||
use std::ops::{Add, Mul};
|
||||
use cgmath::Vector3;
|
||||
|
||||
#[derive(Debug, Clone, Copy, Zeroable, Pod)]
|
||||
#[repr(C)]
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue