diff --git a/python/fusion_engine_client/analysis/analyzer.py b/python/fusion_engine_client/analysis/analyzer.py index a58b5ad8..a9adae2f 100755 --- a/python/fusion_engine_client/analysis/analyzer.py +++ b/python/fusion_engine_client/analysis/analyzer.py @@ -49,15 +49,15 @@ } -def _data_to_table(col_titles: List[str], values: List[List[Any]], row_major: bool = False): +def _data_to_table(col_titles: List[str], values: List[List[Any]], row_major: bool = False, id='table'): if row_major: # If values is row major (outer index is the table rows), transpose it. col_values = list(map(list, zip(*values))) else: col_values = values - table_html = '''\ - + table_html = f'''\ +
''' @@ -909,21 +909,21 @@ def _plot_data(name, idx, source_id, marker_style=None): if marker_style is not None: style['marker'].update(marker_style) + # Only put default source ID on map by default. + legendgroup = None if len(self.source_ids) == 1 else source_id + visible = None if source_id == min(self.source_ids) else 'legendonly' + if np.any(idx): text = ["Time: %.3f sec (%.3f sec)
Std (ENU): (%.2f, %.2f, %.2f) m" % (t, t + float(self.t0), std[0], std[1], std[2]) for t, std in zip(time[idx], std_enu_m[:, idx].T)] - # Only put default source ID on map by default. - if source_id == min(self.source_ids): - map_data.append(go.Scattermapbox(lat=lla_deg[0, idx], lon=lla_deg[1, idx], name=name, text=text, - legendgroup=source_id, **style)) - else: - map_data.append(go.Scattermapbox(lat=lla_deg[0, idx], lon=lla_deg[1, idx], name=name, text=text, - legendgroup=source_id, visible='legendonly', **style)) + map_data.append(go.Scattermapbox(lat=lla_deg[0, idx], lon=lla_deg[1, idx], name=name, text=text, + legendgroup=legendgroup, visible=visible, **style)) else: # If there's no data, draw a dummy trace so it shows up in the legend anyway. - map_data.append(go.Scattermapbox(lat=[np.nan], lon=[np.nan], name=name, visible='legendonly', **style)) + map_data.append(go.Scattermapbox(lat=[np.nan], lon=[np.nan], name=name, legendgroup=legendgroup, + visible='legendonly', **style)) # Read the pose data. for source_id in self.source_ids: @@ -2132,9 +2132,39 @@ def plot_events(self): if system_time_ns in times_before_resets: rows[-1][2] = f'{(times_before_resets[system_time_ns]):.3f}' - table_html = _data_to_table(table_columns, rows, row_major=True) - body_html = f"""\ + table_html = _data_to_table(table_columns, rows, row_major=True, id='event_log') + body_html = """\ + +""" + f"""\

Device Event Log

+
+ +
{table_html}
"""