Add config file
This commit is contained in:
parent
f70cd3f1c8
commit
4ac8a3ce74
4 changed files with 102 additions and 16 deletions
|
@ -13,5 +13,7 @@ vulkan-rs = { git = "https://gavania.de/hodasemi/vulkan_lib.git" }
|
||||||
rfactor_sm_reader = { git = "https://gavania.de/hodasemi/rfactor_sm_reader.git" }
|
rfactor_sm_reader = { git = "https://gavania.de/hodasemi/rfactor_sm_reader.git" }
|
||||||
|
|
||||||
anyhow = { version = "1.0.68", features = ["backtrace"] }
|
anyhow = { version = "1.0.68", features = ["backtrace"] }
|
||||||
cgmath = { version = "0.18.0", features = ["swizzle"] }
|
cgmath = { version = "0.18.0", features = ["swizzle", "serde"] }
|
||||||
paste = "1.0.11"
|
paste = "1.0.11"
|
||||||
|
serde = "1.0.152"
|
||||||
|
serde_json = "1.0.91"
|
||||||
|
|
52
src/lib.rs
52
src/lib.rs
|
@ -6,15 +6,16 @@ mod vk_handles;
|
||||||
|
|
||||||
use std::{
|
use std::{
|
||||||
ffi::c_void,
|
ffi::c_void,
|
||||||
fs::{File, OpenOptions},
|
fs::{self, File, OpenOptions},
|
||||||
io::Write,
|
io::Write,
|
||||||
mem,
|
mem,
|
||||||
os::raw::c_char,
|
os::raw::c_char,
|
||||||
|
path::Path,
|
||||||
ptr,
|
ptr,
|
||||||
};
|
};
|
||||||
|
|
||||||
use enums::*;
|
use enums::*;
|
||||||
use overlay::Overlay;
|
use overlay::{Overlay, OverlayConfig};
|
||||||
use structs::*;
|
use structs::*;
|
||||||
use vk_handles::*;
|
use vk_handles::*;
|
||||||
use vulkan_rs::prelude::*;
|
use vulkan_rs::prelude::*;
|
||||||
|
@ -55,8 +56,9 @@ pub(crate) extern "C" fn vkNegotiateLoaderLayerInterfaceVersion(
|
||||||
|
|
||||||
unsafe { LOG_ENABLED = log_enabled };
|
unsafe { LOG_ENABLED = log_enabled };
|
||||||
|
|
||||||
if logging() {
|
|
||||||
let home = std::env::var("HOME").unwrap();
|
let home = std::env::var("HOME").unwrap();
|
||||||
|
|
||||||
|
if logging() {
|
||||||
unsafe {
|
unsafe {
|
||||||
LOG_FILE = format!("{}/rf2_vk_hud.log", home);
|
LOG_FILE = format!("{}/rf2_vk_hud.log", home);
|
||||||
}
|
}
|
||||||
|
@ -68,6 +70,50 @@ pub(crate) extern "C" fn vkNegotiateLoaderLayerInterfaceVersion(
|
||||||
write_log!(" ==================================================================");
|
write_log!(" ==================================================================");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let config_path = Path::new(&home).join(".config/rFactorHUD/config.json");
|
||||||
|
|
||||||
|
let config = if config_path.exists() {
|
||||||
|
fs::read_to_string(&config_path)
|
||||||
|
.map(|s| {
|
||||||
|
serde_json::from_str(&s).unwrap_or({
|
||||||
|
write_log!("failed to deserialize config file");
|
||||||
|
OverlayConfig::new()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
.unwrap_or({
|
||||||
|
write_log!(format!("failed to open config file: {:?}", config_path));
|
||||||
|
OverlayConfig::new()
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
if let Err(err) = std::fs::create_dir_all(config_path.parent().unwrap()) {
|
||||||
|
write_log!(format!("failed to create dirs for config file: {:?}", err));
|
||||||
|
}
|
||||||
|
|
||||||
|
let config = OverlayConfig::new();
|
||||||
|
|
||||||
|
match File::create(config_path) {
|
||||||
|
Ok(mut file) => match serde_json::to_string(&config) {
|
||||||
|
Ok(conf_str) => {
|
||||||
|
if let Err(err) = file.write_all(conf_str.as_bytes()) {
|
||||||
|
write_log!(format!("failed to write to config file: {:?}", err));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Err(err) => {
|
||||||
|
write_log!(format!("failed to serialize config: {:?}", err));
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Err(err) => {
|
||||||
|
write_log!(format!("failed to create config file: {:?}", err));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
config
|
||||||
|
};
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
OVERLAY.set_config(config);
|
||||||
|
}
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
*pVersionStruct = VkNegotiateLayerInterface {
|
*pVersionStruct = VkNegotiateLayerInterface {
|
||||||
sType: enums::VkNegotiateLayerStructType::LAYER_NEGOTIATE_INTERFACE_STRUCT,
|
sType: enums::VkNegotiateLayerStructType::LAYER_NEGOTIATE_INTERFACE_STRUCT,
|
||||||
|
|
|
@ -10,11 +10,27 @@ mod rendering;
|
||||||
mod rfactor_data;
|
mod rfactor_data;
|
||||||
|
|
||||||
use anyhow::Result;
|
use anyhow::Result;
|
||||||
use cgmath::vec3;
|
|
||||||
use std::sync::{Arc, Mutex};
|
use std::sync::{Arc, Mutex};
|
||||||
use vulkan_rs::prelude::*;
|
use vulkan_rs::prelude::*;
|
||||||
|
|
||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
|
#[derive(Deserialize, Serialize)]
|
||||||
|
pub struct OverlayConfig {
|
||||||
|
pub data_config: DataConfig,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl OverlayConfig {
|
||||||
|
pub const fn new() -> Self {
|
||||||
|
Self {
|
||||||
|
data_config: DataConfig::new(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub struct Overlay {
|
pub struct Overlay {
|
||||||
|
config: OverlayConfig,
|
||||||
|
|
||||||
instance: Option<Arc<Instance>>,
|
instance: Option<Arc<Instance>>,
|
||||||
device: Option<Arc<Device>>,
|
device: Option<Arc<Device>>,
|
||||||
queue: Option<Arc<Mutex<Queue>>>,
|
queue: Option<Arc<Mutex<Queue>>>,
|
||||||
|
@ -26,6 +42,8 @@ pub struct Overlay {
|
||||||
impl Overlay {
|
impl Overlay {
|
||||||
pub const fn new() -> Self {
|
pub const fn new() -> Self {
|
||||||
Self {
|
Self {
|
||||||
|
config: OverlayConfig::new(),
|
||||||
|
|
||||||
instance: None,
|
instance: None,
|
||||||
device: None,
|
device: None,
|
||||||
queue: None,
|
queue: None,
|
||||||
|
@ -35,6 +53,10 @@ impl Overlay {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn set_config(&mut self, config: OverlayConfig) {
|
||||||
|
self.config = config;
|
||||||
|
}
|
||||||
|
|
||||||
pub fn set_instance(&mut self, instance: Arc<Instance>) {
|
pub fn set_instance(&mut self, instance: Arc<Instance>) {
|
||||||
self.instance = Some(instance);
|
self.instance = Some(instance);
|
||||||
}
|
}
|
||||||
|
@ -79,7 +101,6 @@ impl Overlay {
|
||||||
self.rendering = Some(Rendering::new(self.device(), self.queue(), swapchain)?);
|
self.rendering = Some(Rendering::new(self.device(), self.queue(), swapchain)?);
|
||||||
|
|
||||||
write_log!("-> create rendering: new created");
|
write_log!("-> create rendering: new created");
|
||||||
|
|
||||||
write_log!("-> create rendering: end");
|
write_log!("-> create rendering: end");
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
@ -90,12 +111,7 @@ impl Overlay {
|
||||||
|
|
||||||
if self.rfactor_data.is_none() {
|
if self.rfactor_data.is_none() {
|
||||||
self.rfactor_data = RFactorData::new(
|
self.rfactor_data = RFactorData::new(
|
||||||
DataConfig {
|
self.config.data_config,
|
||||||
radar_scale: 1.0,
|
|
||||||
radar_car_distance: 20.0,
|
|
||||||
safe_color: vec3(0.0, 0.75, 0.0),
|
|
||||||
danger_color: vec3(0.75, 0.0, 0.0),
|
|
||||||
},
|
|
||||||
self.device(),
|
self.device(),
|
||||||
self.rendering
|
self.rendering
|
||||||
.as_mut()
|
.as_mut()
|
||||||
|
|
|
@ -3,6 +3,8 @@ use cgmath::{ortho, vec2, vec3, vec4, Deg, InnerSpace, Matrix4, Rad, Vector2, Ve
|
||||||
use rfactor_sm_reader::*;
|
use rfactor_sm_reader::*;
|
||||||
use vulkan_rs::prelude::*;
|
use vulkan_rs::prelude::*;
|
||||||
|
|
||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
use std::{sync::Arc, time::Instant};
|
use std::{sync::Arc, time::Instant};
|
||||||
|
|
||||||
use super::rendering::PositionOnlyVertex;
|
use super::rendering::PositionOnlyVertex;
|
||||||
|
@ -17,13 +19,33 @@ pub trait RenderObject {
|
||||||
fn buffer(&self) -> &Arc<Buffer<PositionOnlyVertex>>;
|
fn buffer(&self) -> &Arc<Buffer<PositionOnlyVertex>>;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Deserialize, Serialize, Clone, Copy, Debug)]
|
||||||
pub struct DataConfig {
|
pub struct DataConfig {
|
||||||
pub radar_scale: f32,
|
pub radar_scale: f32,
|
||||||
|
pub radar_center_factor: f32,
|
||||||
|
pub radar_transparency: f32,
|
||||||
|
pub height_scale: f32,
|
||||||
|
pub width_scale: f32,
|
||||||
pub radar_car_distance: f32,
|
pub radar_car_distance: f32,
|
||||||
pub safe_color: Vector3<f32>,
|
pub safe_color: Vector3<f32>,
|
||||||
pub danger_color: Vector3<f32>,
|
pub danger_color: Vector3<f32>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl DataConfig {
|
||||||
|
pub const fn new() -> Self {
|
||||||
|
Self {
|
||||||
|
radar_scale: 1.0,
|
||||||
|
radar_center_factor: 0.25,
|
||||||
|
radar_transparency: 0.5,
|
||||||
|
height_scale: 0.15,
|
||||||
|
width_scale: 0.4,
|
||||||
|
radar_car_distance: 20.0,
|
||||||
|
safe_color: vec3(0.0, 0.75, 0.0),
|
||||||
|
danger_color: vec3(0.75, 0.0, 0.0),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub struct RFactorData {
|
pub struct RFactorData {
|
||||||
// config
|
// config
|
||||||
config: DataConfig,
|
config: DataConfig,
|
||||||
|
@ -69,11 +91,11 @@ impl RFactorData {
|
||||||
write_log!(" =================== create RFactorData ===================");
|
write_log!(" =================== create RFactorData ===================");
|
||||||
|
|
||||||
let radar_extent = width as f32 * 0.075 * config.radar_scale;
|
let radar_extent = width as f32 * 0.075 * config.radar_scale;
|
||||||
let car_height = radar_extent * 0.15;
|
let car_height = radar_extent * config.height_scale;
|
||||||
let car_width = car_height / 2.5;
|
let car_width = car_height * config.width_scale;
|
||||||
let radar_center = vec2(
|
let radar_center = vec2(
|
||||||
width as f32 / 2.0,
|
width as f32 / 2.0,
|
||||||
height as f32 / 2.0 - height as f32 * 0.25,
|
height as f32 / 2.0 - height as f32 * config.radar_center_factor,
|
||||||
);
|
);
|
||||||
|
|
||||||
let flip_y = matrix4_from_diagonal(vec3(1.0, -1.0, 1.0));
|
let flip_y = matrix4_from_diagonal(vec3(1.0, -1.0, 1.0));
|
||||||
|
@ -98,7 +120,7 @@ impl RFactorData {
|
||||||
vec2(radar_extent, -radar_extent),
|
vec2(radar_extent, -radar_extent),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
[0.5, 0.5, 0.5, 0.5],
|
[0.5, 0.5, 0.5, config.radar_transparency],
|
||||||
)?,
|
)?,
|
||||||
player_car: RadarObject::new(
|
player_car: RadarObject::new(
|
||||||
device.clone(),
|
device.clone(),
|
||||||
|
|
Loading…
Reference in a new issue