feat: custom option getter
Signed-off-by: Nikolaos Karaolidis <nick@karaolidis.com>
This commit is contained in:
@@ -1,4 +1,87 @@
|
||||
use clap::Args;
|
||||
|
||||
use crate::camera::ptp::hex::{
|
||||
FujiClarity, FujiColor, FujiColorChromeEffect, FujiColorChromeFXBlue, FujiDynamicRange,
|
||||
FujiFilmSimulation, FujiGrainEffect, FujiHighISONR, FujiHighlightTone, FujiImageQuality,
|
||||
FujiImageSize, FujiShadowTone, FujiSharpness, FujiStillDynamicRangePriority, FujiWhiteBalance,
|
||||
FujiWhiteBalanceShift, FujiWhiteBalanceTemperature,
|
||||
};
|
||||
|
||||
#[derive(Args, Debug)]
|
||||
pub struct FilmSimulationOptions {}
|
||||
pub struct FilmSimulationOptions {
|
||||
/// The name of the slot
|
||||
#[clap(long)]
|
||||
pub name: Option<String>,
|
||||
|
||||
/// The Fujifilm film simulation to use
|
||||
#[clap(long)]
|
||||
pub simulation: Option<FujiFilmSimulation>,
|
||||
|
||||
/// The output image resolution
|
||||
#[clap(long, alias = "size")]
|
||||
pub resolution: Option<FujiImageSize>,
|
||||
|
||||
/// The output image quality (JPEG compression level)
|
||||
#[clap(long, value_parser)]
|
||||
pub quality: Option<FujiImageQuality>,
|
||||
|
||||
/// Highlight Tone
|
||||
#[clap(long, value_parser)]
|
||||
pub highlights: Option<FujiHighlightTone>,
|
||||
|
||||
/// Shadow Tone
|
||||
#[clap(long, value_parser)]
|
||||
pub shadows: Option<FujiShadowTone>,
|
||||
|
||||
/// Color
|
||||
#[clap(long, value_parser)]
|
||||
pub color: Option<FujiColor>,
|
||||
|
||||
/// Sharpness
|
||||
#[clap(long, value_parser)]
|
||||
pub sharpness: Option<FujiSharpness>,
|
||||
|
||||
/// Clarity
|
||||
#[clap(long, value_parser)]
|
||||
pub clarity: Option<FujiClarity>,
|
||||
|
||||
/// White Balance
|
||||
#[clap(long, value_parser)]
|
||||
pub white_balance: Option<FujiWhiteBalance>,
|
||||
|
||||
/// White Balance Shift Red
|
||||
#[clap(long, value_parser)]
|
||||
pub white_balance_shift_red: Option<FujiWhiteBalanceShift>,
|
||||
|
||||
/// White Balance Shift Blue
|
||||
#[clap(long, value_parser)]
|
||||
pub white_balance_shift_blue: Option<FujiWhiteBalanceShift>,
|
||||
|
||||
/// White Balance Temperature (Only used if WB is set to 'Temperature')
|
||||
#[clap(long, value_parser)]
|
||||
pub white_balance_temperature: Option<FujiWhiteBalanceTemperature>,
|
||||
|
||||
/// Dynamic Range
|
||||
#[clap(long, value_parser)]
|
||||
pub dynamic_range: Option<FujiDynamicRange>,
|
||||
|
||||
/// Dynamic Range Priority
|
||||
#[clap(long, value_parser)]
|
||||
pub dynamic_ranga_priority: Option<FujiStillDynamicRangePriority>,
|
||||
|
||||
/// High ISO Noise Reduction
|
||||
#[clap(long, value_parser)]
|
||||
pub noise_reduction: Option<FujiHighISONR>,
|
||||
|
||||
/// Grain Effect
|
||||
#[clap(long, value_parser)]
|
||||
pub grain: Option<FujiGrainEffect>,
|
||||
|
||||
/// Color Chrome Effect
|
||||
#[clap(long, value_parser)]
|
||||
pub color_chrome_effect: Option<FujiColorChromeEffect>,
|
||||
|
||||
/// Color Chrome FX Blue
|
||||
#[clap(long, value_parser)]
|
||||
pub color_chrome_fx_blue: Option<FujiColorChromeFXBlue>,
|
||||
}
|
||||
|
@@ -4,7 +4,7 @@ use clap::Subcommand;
|
||||
use serde::Serialize;
|
||||
|
||||
use crate::{
|
||||
camera::{Camera, ptp::enums::UsbMode},
|
||||
camera::{Camera, ptp::hex::UsbMode},
|
||||
usb,
|
||||
};
|
||||
|
||||
@@ -20,6 +20,7 @@ pub enum DeviceCmd {
|
||||
}
|
||||
|
||||
#[derive(Serialize)]
|
||||
#[serde(rename_all = "camelCase")]
|
||||
pub struct CameraItemRepr {
|
||||
pub name: &'static str,
|
||||
pub usb_id: String,
|
||||
@@ -60,11 +61,11 @@ fn handle_list(json: bool) -> anyhow::Result<()> {
|
||||
}
|
||||
|
||||
if cameras.is_empty() {
|
||||
println!("No supported cameras connected.");
|
||||
println!("No supported cameras connected");
|
||||
return Ok(());
|
||||
}
|
||||
|
||||
println!("Connected cameras:");
|
||||
println!("Connected Cameras:");
|
||||
for d in cameras {
|
||||
println!("- {d}");
|
||||
}
|
||||
@@ -73,6 +74,7 @@ fn handle_list(json: bool) -> anyhow::Result<()> {
|
||||
}
|
||||
|
||||
#[derive(Serialize)]
|
||||
#[serde(rename_all = "camelCase")]
|
||||
pub struct CameraRepr {
|
||||
#[serde(flatten)]
|
||||
pub device: CameraItemRepr,
|
||||
|
@@ -1,8 +1,23 @@
|
||||
use std::fmt;
|
||||
|
||||
use crate::{
|
||||
camera::ptp::hex::{
|
||||
FujiClarity, FujiColor, FujiColorChromeEffect, FujiColorChromeFXBlue, FujiCustomSetting,
|
||||
FujiDynamicRange, FujiFilmSimulation, FujiGrainEffect, FujiHighISONR, FujiHighlightTone,
|
||||
FujiImageQuality, FujiImageSize, FujiShadowTone, FujiSharpness,
|
||||
FujiStillDynamicRangePriority, FujiWhiteBalance, FujiWhiteBalanceShift,
|
||||
FujiWhiteBalanceTemperature,
|
||||
},
|
||||
usb,
|
||||
};
|
||||
|
||||
use super::common::{
|
||||
file::{Input, Output},
|
||||
film::FilmSimulationOptions,
|
||||
};
|
||||
use clap::Subcommand;
|
||||
use serde::Serialize;
|
||||
use strum::IntoEnumIterator;
|
||||
|
||||
#[derive(Subcommand, Debug)]
|
||||
pub enum SimulationCmd {
|
||||
@@ -13,15 +28,15 @@ pub enum SimulationCmd {
|
||||
/// Get simulation
|
||||
#[command(alias = "g")]
|
||||
Get {
|
||||
/// Simulation number or name
|
||||
simulation: u8,
|
||||
/// Simulation slot number
|
||||
slot: FujiCustomSetting,
|
||||
},
|
||||
|
||||
/// Set simulation parameters
|
||||
#[command(alias = "s")]
|
||||
Set {
|
||||
/// Simulation number or name
|
||||
simulation: u8,
|
||||
/// Simulation slot number
|
||||
slot: FujiCustomSetting,
|
||||
|
||||
#[command(flatten)]
|
||||
film_simulation_options: FilmSimulationOptions,
|
||||
@@ -30,8 +45,8 @@ pub enum SimulationCmd {
|
||||
/// Export simulation
|
||||
#[command(alias = "e")]
|
||||
Export {
|
||||
/// Simulation number or name
|
||||
simulation: u8,
|
||||
/// Simulation slot number
|
||||
slot: FujiCustomSetting,
|
||||
|
||||
/// Output file (use '-' to write to stdout)
|
||||
output_file: Output,
|
||||
@@ -40,10 +55,166 @@ pub enum SimulationCmd {
|
||||
/// Import simulation
|
||||
#[command(alias = "i")]
|
||||
Import {
|
||||
/// Simulation number
|
||||
slot: u8,
|
||||
/// Simulation slot number
|
||||
slot: FujiCustomSetting,
|
||||
|
||||
/// Input file (use '-' to read from stdin)
|
||||
input_file: Input,
|
||||
},
|
||||
}
|
||||
|
||||
#[derive(Debug, Serialize)]
|
||||
#[serde(rename_all = "camelCase")]
|
||||
pub struct CustomSettingRepr {
|
||||
pub slot: FujiCustomSetting,
|
||||
pub name: String,
|
||||
}
|
||||
|
||||
fn handle_list(json: bool, device_id: Option<&str>) -> anyhow::Result<()> {
|
||||
let mut camera = usb::get_camera(device_id)?;
|
||||
|
||||
let mut slots = Vec::new();
|
||||
|
||||
for slot in FujiCustomSetting::iter() {
|
||||
camera.set_active_custom_setting(slot)?;
|
||||
let name = camera.get_custom_setting_name()?;
|
||||
slots.push(CustomSettingRepr { slot, name });
|
||||
}
|
||||
|
||||
if json {
|
||||
println!("{}", serde_json::to_string_pretty(&slots)?);
|
||||
} else {
|
||||
println!("Film Simulations:");
|
||||
for slot in slots {
|
||||
println!("- {}: {}", slot.slot, slot.name);
|
||||
}
|
||||
}
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
#[derive(Serialize)]
|
||||
#[serde(rename_all = "camelCase")]
|
||||
pub struct FilmSimulationRepr {
|
||||
pub slot: FujiCustomSetting,
|
||||
pub name: String,
|
||||
pub simulation: FujiFilmSimulation,
|
||||
pub resolution: FujiImageSize,
|
||||
pub quality: FujiImageQuality,
|
||||
pub highlights: FujiHighlightTone,
|
||||
pub shadows: FujiShadowTone,
|
||||
pub color: FujiColor,
|
||||
pub sharpness: FujiSharpness,
|
||||
pub clarity: FujiClarity,
|
||||
pub white_balance: FujiWhiteBalance,
|
||||
pub white_balance_shift_red: FujiWhiteBalanceShift,
|
||||
pub white_balance_shift_blue: FujiWhiteBalanceShift,
|
||||
pub white_balance_temperature: FujiWhiteBalanceTemperature,
|
||||
pub dynamic_range: FujiDynamicRange,
|
||||
pub dynamic_range_priority: FujiStillDynamicRangePriority,
|
||||
pub noise_reduction: FujiHighISONR,
|
||||
pub grain: FujiGrainEffect,
|
||||
pub color_chrome_effect: FujiColorChromeEffect,
|
||||
pub color_chrome_fx_blue: FujiColorChromeFXBlue,
|
||||
}
|
||||
|
||||
impl fmt::Display for FilmSimulationRepr {
|
||||
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||
writeln!(f, "Slot: {}", self.slot)?;
|
||||
writeln!(f, "Name: {}", self.name)?;
|
||||
writeln!(f, "Simulation: {}", self.simulation)?;
|
||||
writeln!(f, "Resolution: {}", self.resolution)?;
|
||||
writeln!(f, "Quality: {}", self.quality)?;
|
||||
writeln!(f, "Highlights: {}", self.highlights)?;
|
||||
writeln!(f, "Shadows: {}", self.shadows)?;
|
||||
writeln!(f, "Color: {}", self.color)?;
|
||||
writeln!(f, "Sharpness: {}", self.sharpness)?;
|
||||
writeln!(f, "Clarity: {}", self.clarity)?;
|
||||
writeln!(f, "White Balance: {}", self.white_balance)?;
|
||||
writeln!(
|
||||
f,
|
||||
"White Balance Shift (R/B): {} / {}",
|
||||
self.white_balance_shift_red, self.white_balance_shift_blue
|
||||
)?;
|
||||
writeln!(f, "White Balance Temperature: {}K", self.white_balance_temperature)?;
|
||||
writeln!(f, "Dynamic Range: {}", self.dynamic_range)?;
|
||||
writeln!(f, "Dynamic Range Priority: {}", self.dynamic_range_priority)?;
|
||||
writeln!(f, "Noise Reduction: {}", self.noise_reduction)?;
|
||||
writeln!(f, "Grain: {}", self.grain)?;
|
||||
writeln!(f, "Color Chrome Effect: {}", self.color_chrome_effect)?;
|
||||
writeln!(f, "Color Chrome FX Blue: {}", self.color_chrome_fx_blue)
|
||||
}
|
||||
}
|
||||
|
||||
fn handle_get(json: bool, device_id: Option<&str>, slot: FujiCustomSetting) -> anyhow::Result<()> {
|
||||
let mut camera = usb::get_camera(device_id)?;
|
||||
camera.set_active_custom_setting(slot)?;
|
||||
|
||||
let repr = FilmSimulationRepr {
|
||||
slot,
|
||||
name: camera.get_custom_setting_name()?,
|
||||
simulation: camera.get_film_simulation()?,
|
||||
resolution: camera.get_image_size()?,
|
||||
quality: camera.get_image_quality()?,
|
||||
highlights: camera.get_highlight_tone()?,
|
||||
shadows: camera.get_shadow_tone()?,
|
||||
color: camera.get_color()?,
|
||||
sharpness: camera.get_sharpness()?,
|
||||
clarity: camera.get_clarity()?,
|
||||
white_balance: camera.get_white_balance()?,
|
||||
white_balance_shift_red: camera.get_wb_shift_red()?,
|
||||
white_balance_shift_blue: camera.get_wb_shift_blue()?,
|
||||
white_balance_temperature: camera.get_wb_temperature()?,
|
||||
dynamic_range: camera.get_dynamic_range()?,
|
||||
dynamic_range_priority: camera.get_dynamic_range_priority()?,
|
||||
noise_reduction: camera.get_high_iso_nr()?,
|
||||
grain: camera.get_grain_effect()?,
|
||||
color_chrome_effect: camera.get_color_chrome_effect()?,
|
||||
color_chrome_fx_blue: camera.get_color_chrome_fx_blue()?,
|
||||
};
|
||||
|
||||
if json {
|
||||
println!("{}", serde_json::to_string_pretty(&repr)?);
|
||||
} else {
|
||||
println!("{repr}");
|
||||
}
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
fn handle_set(
|
||||
_device_id: Option<&str>,
|
||||
_slot: FujiCustomSetting,
|
||||
_opts: &FilmSimulationOptions,
|
||||
) -> anyhow::Result<()> {
|
||||
todo!();
|
||||
}
|
||||
|
||||
fn handle_export(
|
||||
_device_id: Option<&str>,
|
||||
_slot: FujiCustomSetting,
|
||||
_output: &Output,
|
||||
) -> anyhow::Result<()> {
|
||||
todo!();
|
||||
}
|
||||
|
||||
fn handle_import(
|
||||
_device_id: Option<&str>,
|
||||
_slot: FujiCustomSetting,
|
||||
_input: &Input,
|
||||
) -> anyhow::Result<()> {
|
||||
todo!();
|
||||
}
|
||||
|
||||
pub fn handle(cmd: SimulationCmd, json: bool, device_id: Option<&str>) -> anyhow::Result<()> {
|
||||
match cmd {
|
||||
SimulationCmd::List => handle_list(json, device_id),
|
||||
SimulationCmd::Get { slot } => handle_get(json, device_id, slot),
|
||||
SimulationCmd::Set {
|
||||
slot,
|
||||
film_simulation_options,
|
||||
} => handle_set(device_id, slot, &film_simulation_options),
|
||||
SimulationCmd::Export { slot, output_file } => handle_export(device_id, slot, &output_file),
|
||||
SimulationCmd::Import { slot, input_file } => handle_import(device_id, slot, &input_file),
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user