signal_to_timeline
This commit is contained in:
parent
6e85b7fa35
commit
d8c1b0abac
|
@ -37,8 +37,8 @@ pub async fn load_and_get_signal(signal_ref: wellen::SignalRef) -> wellen::Signa
|
||||||
platform::load_and_get_signal(signal_ref).await
|
platform::load_and_get_signal(signal_ref).await
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn timeline(signal_ref: wellen::SignalRef, screen_width: u32) -> shared::Timeline {
|
pub async fn timeline(signal_ref: wellen::SignalRef, screen_width: u32, block_height: u32) -> shared::Timeline {
|
||||||
platform::timeline(signal_ref, screen_width).await
|
platform::timeline(signal_ref, screen_width, block_height).await
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn unload_signal(signal_ref: wellen::SignalRef) {
|
pub async fn unload_signal(signal_ref: wellen::SignalRef) {
|
||||||
|
|
|
@ -91,7 +91,7 @@ pub(super) async fn load_and_get_signal(signal_ref: wellen::SignalRef) -> wellen
|
||||||
serde_json::from_value(serde_json::to_value(signal).unwrap_throw()).unwrap_throw()
|
serde_json::from_value(serde_json::to_value(signal).unwrap_throw()).unwrap_throw()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(super) async fn timeline(signal_ref: wellen::SignalRef, screen_width: u32) -> shared::Timeline {
|
pub(super) async fn timeline(signal_ref: wellen::SignalRef, screen_width: u32, block_height: u32) -> shared::Timeline {
|
||||||
shared::Timeline { blocks: Vec::new() }
|
shared::Timeline { blocks: Vec::new() }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -30,9 +30,9 @@ pub(super) async fn load_and_get_signal(signal_ref: wellen::SignalRef) -> wellen
|
||||||
.unwrap_throw()
|
.unwrap_throw()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(super) async fn timeline(signal_ref: wellen::SignalRef, screen_width: u32) -> shared::Timeline {
|
pub(super) async fn timeline(signal_ref: wellen::SignalRef, screen_width: u32, block_height: u32) -> shared::Timeline {
|
||||||
serde_wasm_bindgen::from_value(
|
serde_wasm_bindgen::from_value(
|
||||||
tauri_glue::timeline(signal_ref.index(), screen_width)
|
tauri_glue::timeline(signal_ref.index(), screen_width, block_height)
|
||||||
.await
|
.await
|
||||||
.unwrap_throw(),
|
.unwrap_throw(),
|
||||||
)
|
)
|
||||||
|
@ -67,7 +67,7 @@ mod tauri_glue {
|
||||||
pub async fn load_and_get_signal(signal_ref_index: usize) -> Result<JsValue, JsValue>;
|
pub async fn load_and_get_signal(signal_ref_index: usize) -> Result<JsValue, JsValue>;
|
||||||
|
|
||||||
#[wasm_bindgen(catch)]
|
#[wasm_bindgen(catch)]
|
||||||
pub async fn timeline(signal_ref_index: usize, screen_width: u32) -> Result<JsValue, JsValue>;
|
pub async fn timeline(signal_ref_index: usize, screen_width: u32, block_height: u32) -> Result<JsValue, JsValue>;
|
||||||
|
|
||||||
#[wasm_bindgen(catch)]
|
#[wasm_bindgen(catch)]
|
||||||
pub async fn unload_signal(signal_ref_index: usize) -> Result<(), JsValue>;
|
pub async fn unload_signal(signal_ref_index: usize) -> Result<(), JsValue>;
|
||||||
|
|
|
@ -117,7 +117,7 @@ impl WaveformPanel {
|
||||||
|
|
||||||
let var = hierarchy.get(var_ref);
|
let var = hierarchy.get(var_ref);
|
||||||
let signal_ref = var.signal_ref();
|
let signal_ref = var.signal_ref();
|
||||||
let timeline = platform::timeline(signal_ref, controller.screen_width()).await;
|
let timeline = platform::timeline(signal_ref, controller.screen_width(), ROW_HEIGHT).await;
|
||||||
|
|
||||||
// @TODO remove
|
// @TODO remove
|
||||||
zoon::println!("Timeline in Rust: {timeline:#?}");
|
zoon::println!("Timeline in Rust: {timeline:#?}");
|
||||||
|
|
|
@ -35225,7 +35225,7 @@ var VarSignalRow = class {
|
||||||
const signal_block = new Container();
|
const signal_block = new Container();
|
||||||
signal_block.x = timeline_block.x;
|
signal_block.x = timeline_block.x;
|
||||||
this.signal_blocks_container.addChild(signal_block);
|
this.signal_blocks_container.addChild(signal_block);
|
||||||
const background = new Graphics().roundRect(0, 0, timeline_block.width, this.row_height, 15).fill("SlateBlue");
|
const background = new Graphics().roundRect(0, 0, timeline_block.width, timeline_block.height, 15).fill("SlateBlue");
|
||||||
signal_block.addChild(background);
|
signal_block.addChild(background);
|
||||||
if (timeline_block.label !== void 0) {
|
if (timeline_block.label !== void 0) {
|
||||||
const label = new Text({ text: timeline_block.label.text, style: this.label_style });
|
const label = new Text({ text: timeline_block.label.text, style: this.label_style });
|
||||||
|
|
|
@ -2526,8 +2526,8 @@ async function get_time_table() {
|
||||||
async function load_and_get_signal(signal_ref_index) {
|
async function load_and_get_signal(signal_ref_index) {
|
||||||
return await invoke2("load_and_get_signal", { signal_ref_index });
|
return await invoke2("load_and_get_signal", { signal_ref_index });
|
||||||
}
|
}
|
||||||
async function timeline(signal_ref_index, screen_width) {
|
async function timeline(signal_ref_index, screen_width, block_height) {
|
||||||
return await invoke2("timeline", { signal_ref_index, screen_width });
|
return await invoke2("timeline", { signal_ref_index, screen_width, block_height });
|
||||||
}
|
}
|
||||||
async function unload_signal(signal_ref_index) {
|
async function unload_signal(signal_ref_index) {
|
||||||
return await invoke2("unload_signal", { signal_ref_index });
|
return await invoke2("unload_signal", { signal_ref_index });
|
||||||
|
|
|
@ -7,6 +7,7 @@ type Timeline = {
|
||||||
type TimelineBlock = {
|
type TimelineBlock = {
|
||||||
x: number,
|
x: number,
|
||||||
width: number,
|
width: number,
|
||||||
|
height: number,
|
||||||
label: TimeLineBlockLabel | undefined,
|
label: TimeLineBlockLabel | undefined,
|
||||||
}
|
}
|
||||||
type TimeLineBlockLabel = {
|
type TimeLineBlockLabel = {
|
||||||
|
@ -153,7 +154,7 @@ class VarSignalRow {
|
||||||
|
|
||||||
// background
|
// background
|
||||||
const background = new Graphics()
|
const background = new Graphics()
|
||||||
.roundRect(0, 0, timeline_block.width, this.row_height, 15)
|
.roundRect(0, 0, timeline_block.width, timeline_block.height, 15)
|
||||||
.fill("SlateBlue");
|
.fill("SlateBlue");
|
||||||
signal_block.addChild(background);
|
signal_block.addChild(background);
|
||||||
|
|
||||||
|
|
|
@ -30,8 +30,8 @@ export async function load_and_get_signal(signal_ref_index: number): Promise<Wel
|
||||||
return await invoke("load_and_get_signal", { signal_ref_index });
|
return await invoke("load_and_get_signal", { signal_ref_index });
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function timeline(signal_ref_index: number, screen_width: number): Promise<Timeline> {
|
export async function timeline(signal_ref_index: number, screen_width: number, block_height: number): Promise<Timeline> {
|
||||||
return await invoke("timeline", { signal_ref_index, screen_width });
|
return await invoke("timeline", { signal_ref_index, screen_width, block_height });
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function unload_signal(signal_ref_index: number): Promise<void> {
|
export async function unload_signal(signal_ref_index: number): Promise<void> {
|
||||||
|
|
|
@ -2,21 +2,22 @@ use moonlight::*;
|
||||||
|
|
||||||
pub mod wellen_helpers;
|
pub mod wellen_helpers;
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Debug)]
|
#[derive(Serialize, Deserialize, Debug, Default)]
|
||||||
#[serde(crate = "serde")]
|
#[serde(crate = "serde")]
|
||||||
pub struct Timeline {
|
pub struct Timeline {
|
||||||
pub blocks: Vec<TimelineBlock>
|
pub blocks: Vec<TimelineBlock>
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Debug)]
|
#[derive(Serialize, Deserialize, Debug, Default)]
|
||||||
#[serde(crate = "serde")]
|
#[serde(crate = "serde")]
|
||||||
pub struct TimelineBlock {
|
pub struct TimelineBlock {
|
||||||
pub x: u32,
|
pub x: u32,
|
||||||
pub width: u32,
|
pub width: u32,
|
||||||
|
pub height: u32,
|
||||||
pub label: Option<TimeLineBlockLabel>,
|
pub label: Option<TimeLineBlockLabel>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Debug)]
|
#[derive(Serialize, Deserialize, Debug, Default)]
|
||||||
#[serde(crate = "serde")]
|
#[serde(crate = "serde")]
|
||||||
pub struct TimeLineBlockLabel {
|
pub struct TimeLineBlockLabel {
|
||||||
pub text: String,
|
pub text: String,
|
||||||
|
|
|
@ -65,18 +65,17 @@ async fn load_and_get_signal(
|
||||||
async fn timeline(
|
async fn timeline(
|
||||||
signal_ref_index: usize,
|
signal_ref_index: usize,
|
||||||
screen_width: u32,
|
screen_width: u32,
|
||||||
|
block_height: u32,
|
||||||
store: tauri::State<'_, Store>,
|
store: tauri::State<'_, Store>,
|
||||||
) -> Result<serde_json::Value, ()> {
|
) -> Result<serde_json::Value, ()> {
|
||||||
|
// @TODO run (all?) in a blocking thread
|
||||||
let signal_ref = wellen::SignalRef::from_index(signal_ref_index).unwrap();
|
let signal_ref = wellen::SignalRef::from_index(signal_ref_index).unwrap();
|
||||||
let mut waveform_lock = store.waveform.lock().unwrap();
|
let mut waveform_lock = store.waveform.lock().unwrap();
|
||||||
let waveform = waveform_lock.as_mut().unwrap();
|
let waveform = waveform_lock.as_mut().unwrap();
|
||||||
// @TODO maybe run it in a thread to not block the main one or return the result through a Tauri channel
|
|
||||||
waveform.load_signals_multi_threaded(&[signal_ref]);
|
waveform.load_signals_multi_threaded(&[signal_ref]);
|
||||||
let signal = waveform.get_signal(signal_ref).unwrap();
|
let signal = waveform.get_signal(signal_ref).unwrap();
|
||||||
|
let time_table = waveform.time_table();
|
||||||
// @TODO create Timeline
|
let timeline = signal_to_timeline(signal, time_table, screen_width, block_height);
|
||||||
let timeline = shared::Timeline { blocks: Vec::new() };
|
|
||||||
|
|
||||||
Ok(serde_json::to_value(timeline).unwrap())
|
Ok(serde_json::to_value(timeline).unwrap())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,3 +111,73 @@ pub fn run() {
|
||||||
.run(tauri::generate_context!())
|
.run(tauri::generate_context!())
|
||||||
.expect("error while running tauri application");
|
.expect("error while running tauri application");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn signal_to_timeline(
|
||||||
|
signal: &wellen::Signal,
|
||||||
|
time_table: &[wellen::Time],
|
||||||
|
screen_width: u32,
|
||||||
|
block_height: u32,
|
||||||
|
) -> shared::Timeline {
|
||||||
|
const MIN_BLOCK_WIDTH: u32 = 3;
|
||||||
|
const LETTER_WIDTH: u32 = 15;
|
||||||
|
const LETTER_HEIGHT: u32 = 21;
|
||||||
|
const LABEL_X_PADDING: u32 = 10;
|
||||||
|
|
||||||
|
let Some(last_time) = time_table.last().copied() else {
|
||||||
|
return shared::Timeline::default()
|
||||||
|
};
|
||||||
|
|
||||||
|
let last_time = last_time as f64;
|
||||||
|
let screen_width = screen_width as f64;
|
||||||
|
|
||||||
|
let mut x_value_pairs = signal
|
||||||
|
.iter_changes()
|
||||||
|
.map(|(index, value)| {
|
||||||
|
let index = index as usize;
|
||||||
|
let time = time_table[index] as f64;
|
||||||
|
let x = time / last_time * screen_width;
|
||||||
|
(x, value)
|
||||||
|
})
|
||||||
|
.peekable();
|
||||||
|
|
||||||
|
let mut blocks = Vec::new();
|
||||||
|
|
||||||
|
while let Some((block_x, value)) = x_value_pairs.next() {
|
||||||
|
let next_block_x = if let Some((next_block_x, _)) = x_value_pairs.peek() {
|
||||||
|
*next_block_x
|
||||||
|
} else {
|
||||||
|
screen_width
|
||||||
|
};
|
||||||
|
|
||||||
|
let block_width = (next_block_x - block_x) as u32;
|
||||||
|
if block_width < MIN_BLOCK_WIDTH {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
let value = value.to_string();
|
||||||
|
// @TODO dynamic formatter
|
||||||
|
let value = u32::from_str_radix(&value, 2).unwrap();
|
||||||
|
let value = format!("{value:x}");
|
||||||
|
|
||||||
|
let value_width = value.chars().count() as u32 * LETTER_WIDTH;
|
||||||
|
let label = if (value_width + (2 * LABEL_X_PADDING)) <= block_width {
|
||||||
|
Some(shared::TimeLineBlockLabel {
|
||||||
|
text: value,
|
||||||
|
x: (block_width - value_width) / 2,
|
||||||
|
y: (block_height - LETTER_HEIGHT) / 2,
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
};
|
||||||
|
|
||||||
|
let block = shared::TimelineBlock {
|
||||||
|
x: block_x as u32,
|
||||||
|
width: block_width,
|
||||||
|
height: block_height,
|
||||||
|
label,
|
||||||
|
};
|
||||||
|
blocks.push(block);
|
||||||
|
}
|
||||||
|
|
||||||
|
shared::Timeline { blocks }
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue