mirror of
https://codeberg.org/icewind/vbspview.git
synced 2026-06-03 18:24:09 +02:00
remove alpha channel for non translucent materials
This commit is contained in:
parent
73d15076dd
commit
57a73d32f4
1 changed files with 26 additions and 18 deletions
|
|
@ -43,9 +43,9 @@ pub fn load_material(
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
let path = format!("{}.vmt", name.to_ascii_lowercase().trim_end_matches(".vmt"));
|
let path = format!("{}.vmt", name.to_ascii_lowercase().trim_end_matches(".vmt"));
|
||||||
let raw = loader.load_from_paths(&path, &dirs)?;
|
let raw = loader.load_from_paths(&path, &dirs)?.to_ascii_lowercase();
|
||||||
|
|
||||||
let vmt = parse_vdf(raw)?;
|
let vmt = parse_vdf(&raw)?;
|
||||||
let vmt = resolve_vmt_patch(vmt, loader)?;
|
let vmt = resolve_vmt_patch(vmt, loader)?;
|
||||||
|
|
||||||
let material_type = vmt
|
let material_type = vmt
|
||||||
|
|
@ -53,6 +53,7 @@ pub fn load_material(
|
||||||
.next()
|
.next()
|
||||||
.ok_or(Error::Other("empty vmt"))?
|
.ok_or(Error::Other("empty vmt"))?
|
||||||
.to_ascii_lowercase();
|
.to_ascii_lowercase();
|
||||||
|
|
||||||
if material_type == "water" {
|
if material_type == "water" {
|
||||||
return Ok(CpuMaterial {
|
return Ok(CpuMaterial {
|
||||||
albedo: Color {
|
albedo: Color {
|
||||||
|
|
@ -68,21 +69,23 @@ pub fn load_material(
|
||||||
|
|
||||||
let table = vmt
|
let table = vmt
|
||||||
.values()
|
.values()
|
||||||
|
.cloned()
|
||||||
.next()
|
.next()
|
||||||
.ok_or(Error::Other("empty vmt"))?
|
.ok_or(Error::Other("empty vmt"))?;
|
||||||
.as_table()
|
|
||||||
.ok_or(Error::Other("vmt not a table"))?;
|
|
||||||
let base_texture = table
|
let base_texture = table
|
||||||
.iter()
|
.lookup("$basetexture")
|
||||||
.find_map(|(key, value)| (key.to_ascii_lowercase() == "$basetexture").then_some(value))
|
|
||||||
.ok_or(Error::Other("no $basetexture"))?
|
.ok_or(Error::Other("no $basetexture"))?
|
||||||
.as_value()
|
.as_str()
|
||||||
.ok_or(Error::Other("$basetexture not a value"))?
|
.ok_or(Error::Other("$basetexture not a string"))?
|
||||||
.to_string()
|
|
||||||
.to_ascii_lowercase()
|
|
||||||
.replace('\\', "/")
|
.replace('\\', "/")
|
||||||
.replace('\t', "/t");
|
.replace('\t', "/t");
|
||||||
let texture = load_texture(base_texture.as_str(), loader)?;
|
|
||||||
|
let translucent = table
|
||||||
|
.lookup("$translucent")
|
||||||
|
.map(|val| val.as_str() == Some("1"))
|
||||||
|
.unwrap_or_default();
|
||||||
|
let texture = load_texture(base_texture.as_str(), loader, translucent)?;
|
||||||
|
|
||||||
Ok(CpuMaterial {
|
Ok(CpuMaterial {
|
||||||
name: name.into(),
|
name: name.into(),
|
||||||
albedo: Color::WHITE,
|
albedo: Color::WHITE,
|
||||||
|
|
@ -91,8 +94,8 @@ pub fn load_material(
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parse_vdf(bytes: Vec<u8>) -> Result<Table, Error> {
|
fn parse_vdf(bytes: &[u8]) -> Result<Table, Error> {
|
||||||
let mut reader = steamy_vdf::Reader::from(bytes.as_slice());
|
let mut reader = steamy_vdf::Reader::from(bytes);
|
||||||
Table::load(&mut reader).map_err(|e| {
|
Table::load(&mut reader).map_err(|e| {
|
||||||
error!(
|
error!(
|
||||||
source = String::from_utf8_lossy(&bytes).to_string(),
|
source = String::from_utf8_lossy(&bytes).to_string(),
|
||||||
|
|
@ -102,7 +105,7 @@ fn parse_vdf(bytes: Vec<u8>) -> Result<Table, Error> {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn load_texture(name: &str, loader: &Loader) -> Result<CpuTexture, Error> {
|
fn load_texture(name: &str, loader: &Loader, translucent: bool) -> Result<CpuTexture, Error> {
|
||||||
let path = format!(
|
let path = format!(
|
||||||
"materials/{}.vtf",
|
"materials/{}.vtf",
|
||||||
name.trim_end_matches(".vtf").trim_start_matches("/")
|
name.trim_end_matches(".vtf").trim_start_matches("/")
|
||||||
|
|
@ -110,9 +113,14 @@ fn load_texture(name: &str, loader: &Loader) -> Result<CpuTexture, Error> {
|
||||||
let mut raw = loader.load(&path)?;
|
let mut raw = loader.load(&path)?;
|
||||||
let vtf = VTF::read(&mut raw)?;
|
let vtf = VTF::read(&mut raw)?;
|
||||||
let image = vtf.highres_image.decode(0)?;
|
let image = vtf.highres_image.decode(0)?;
|
||||||
|
let texture_data = if translucent {
|
||||||
|
TextureData::RgbaU8(image.into_rgba8().pixels().map(|pixel| pixel.0).collect())
|
||||||
|
} else {
|
||||||
|
TextureData::RgbU8(image.into_rgb8().pixels().map(|pixel| pixel.0).collect())
|
||||||
|
};
|
||||||
Ok(CpuTexture {
|
Ok(CpuTexture {
|
||||||
name: name.into(),
|
name: name.into(),
|
||||||
data: TextureData::RgbaU8(image.into_rgba8().pixels().map(|pixel| pixel.0).collect()),
|
data: texture_data,
|
||||||
height: vtf.header.height as u32,
|
height: vtf.header.height as u32,
|
||||||
width: vtf.header.width as u32,
|
width: vtf.header.width as u32,
|
||||||
..CpuTexture::default()
|
..CpuTexture::default()
|
||||||
|
|
@ -135,10 +143,10 @@ fn resolve_vmt_patch(vmt: Table, loader: &Loader) -> Result<Table, Error> {
|
||||||
.expect("no replace in patch")
|
.expect("no replace in patch")
|
||||||
.as_table()
|
.as_table()
|
||||||
.expect("replace is not a table");
|
.expect("replace is not a table");
|
||||||
let included_raw = loader.load(&include.to_ascii_lowercase())?;
|
let included_raw = loader.load(&include)?.to_ascii_lowercase();
|
||||||
|
|
||||||
// todo actually patch
|
// todo actually patch
|
||||||
parse_vdf(included_raw)
|
parse_vdf(&included_raw)
|
||||||
} else {
|
} else {
|
||||||
Ok(vmt)
|
Ok(vmt)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue