mirror of
https://github.com/Caraxi/mare.client.git
synced 2025-12-12 19:47:21 +01:00
requested changes
This commit is contained in:
parent
9023aa8006
commit
57a4e65383
2 changed files with 29 additions and 27 deletions
|
|
@ -179,30 +179,29 @@ public sealed class CharacterAnalyzer : MediatorSubscriberBase, IDisposable
|
||||||
public long OriginalSize { get; private set; } = OriginalSize;
|
public long OriginalSize { get; private set; } = OriginalSize;
|
||||||
public long CompressedSize { get; private set; } = CompressedSize;
|
public long CompressedSize { get; private set; } = CompressedSize;
|
||||||
|
|
||||||
private string? _format;
|
public Lazy<string> Format = new(() =>
|
||||||
|
|
||||||
public string? Format
|
|
||||||
{
|
{
|
||||||
get
|
|
||||||
{
|
|
||||||
if (_format != null) return _format;
|
|
||||||
|
|
||||||
switch (FileType)
|
switch (FileType)
|
||||||
{
|
{
|
||||||
case "tex":
|
case "tex":
|
||||||
|
{
|
||||||
|
try
|
||||||
{
|
{
|
||||||
using var stream = new FileStream(FilePaths[0], FileMode.Open, FileAccess.Read, FileShare.Read);
|
using var stream = new FileStream(FilePaths[0], FileMode.Open, FileAccess.Read, FileShare.Read);
|
||||||
using var reader = new BinaryReader(stream);
|
using var reader = new BinaryReader(stream);
|
||||||
reader.BaseStream.Position = 4;
|
reader.BaseStream.Position = 4;
|
||||||
var format = (TexFile.TextureFormat)reader.ReadInt32();
|
var format = (TexFile.TextureFormat)reader.ReadInt32();
|
||||||
_format = format.ToString();
|
return format.ToString();
|
||||||
return _format;
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
return "unknown";
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
_format = string.Empty;
|
return string.Empty;
|
||||||
return _format;
|
}
|
||||||
}
|
});
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -240,7 +240,7 @@ public class DataAnalysisUi : WindowMediatorSubscriberBase
|
||||||
|
|
||||||
private void DrawTable(IGrouping<string, CharacterAnalyzer.FileDataEntry> fileGroup)
|
private void DrawTable(IGrouping<string, CharacterAnalyzer.FileDataEntry> fileGroup)
|
||||||
{
|
{
|
||||||
using var table = ImRaii.Table("Analysis", 6, ImGuiTableFlags.Sortable | ImGuiTableFlags.RowBg | ImGuiTableFlags.ScrollY | ImGuiTableFlags.SizingFixedFit,
|
using var table = ImRaii.Table("Analysis", fileGroup.Key == "tex" ? 6 : 5, ImGuiTableFlags.Sortable | ImGuiTableFlags.RowBg | ImGuiTableFlags.ScrollY | ImGuiTableFlags.SizingFixedFit,
|
||||||
new Vector2(0, 300));
|
new Vector2(0, 300));
|
||||||
if (!table.Success) return;
|
if (!table.Success) return;
|
||||||
ImGui.TableSetupColumn("Hash");
|
ImGui.TableSetupColumn("Hash");
|
||||||
|
|
@ -248,7 +248,7 @@ new Vector2(0, 300));
|
||||||
ImGui.TableSetupColumn("Gamepaths");
|
ImGui.TableSetupColumn("Gamepaths");
|
||||||
ImGui.TableSetupColumn("Original Size");
|
ImGui.TableSetupColumn("Original Size");
|
||||||
ImGui.TableSetupColumn("Compressed Size");
|
ImGui.TableSetupColumn("Compressed Size");
|
||||||
ImGui.TableSetupColumn("Format");
|
if (fileGroup.Key == "tex") ImGui.TableSetupColumn("Format");
|
||||||
ImGui.TableSetupScrollFreeze(0, 1);
|
ImGui.TableSetupScrollFreeze(0, 1);
|
||||||
ImGui.TableHeadersRow();
|
ImGui.TableHeadersRow();
|
||||||
|
|
||||||
|
|
@ -277,9 +277,9 @@ new Vector2(0, 300));
|
||||||
_cachedAnalysis![_selectedObjectTab] = _cachedAnalysis[_selectedObjectTab].OrderBy(k => k.Value.CompressedSize).ToDictionary(d => d.Key, d => d.Value, StringComparer.Ordinal);
|
_cachedAnalysis![_selectedObjectTab] = _cachedAnalysis[_selectedObjectTab].OrderBy(k => k.Value.CompressedSize).ToDictionary(d => d.Key, d => d.Value, StringComparer.Ordinal);
|
||||||
if (idx == 4 && sortSpecs.Specs.SortDirection == ImGuiSortDirection.Descending)
|
if (idx == 4 && sortSpecs.Specs.SortDirection == ImGuiSortDirection.Descending)
|
||||||
_cachedAnalysis![_selectedObjectTab] = _cachedAnalysis[_selectedObjectTab].OrderByDescending(k => k.Value.CompressedSize).ToDictionary(d => d.Key, d => d.Value, StringComparer.Ordinal);
|
_cachedAnalysis![_selectedObjectTab] = _cachedAnalysis[_selectedObjectTab].OrderByDescending(k => k.Value.CompressedSize).ToDictionary(d => d.Key, d => d.Value, StringComparer.Ordinal);
|
||||||
if (idx == 5 && sortSpecs.Specs.SortDirection == ImGuiSortDirection.Ascending)
|
if (fileGroup.Key == "tex" && idx == 5 && sortSpecs.Specs.SortDirection == ImGuiSortDirection.Ascending)
|
||||||
_cachedAnalysis![_selectedObjectTab] = _cachedAnalysis[_selectedObjectTab].OrderBy(k => k.Value.Format).ToDictionary(d => d.Key, d => d.Value, StringComparer.Ordinal);
|
_cachedAnalysis![_selectedObjectTab] = _cachedAnalysis[_selectedObjectTab].OrderBy(k => k.Value.Format).ToDictionary(d => d.Key, d => d.Value, StringComparer.Ordinal);
|
||||||
if (idx == 5 && sortSpecs.Specs.SortDirection == ImGuiSortDirection.Descending)
|
if (fileGroup.Key == "tex" && idx == 5 && sortSpecs.Specs.SortDirection == ImGuiSortDirection.Descending)
|
||||||
_cachedAnalysis![_selectedObjectTab] = _cachedAnalysis[_selectedObjectTab].OrderByDescending(k => k.Value.Format).ToDictionary(d => d.Key, d => d.Value, StringComparer.Ordinal);
|
_cachedAnalysis![_selectedObjectTab] = _cachedAnalysis[_selectedObjectTab].OrderByDescending(k => k.Value.Format).ToDictionary(d => d.Key, d => d.Value, StringComparer.Ordinal);
|
||||||
|
|
||||||
sortSpecs.SpecsDirty = false;
|
sortSpecs.SpecsDirty = false;
|
||||||
|
|
@ -314,9 +314,12 @@ new Vector2(0, 300));
|
||||||
ImGui.TableNextColumn();
|
ImGui.TableNextColumn();
|
||||||
ImGui.TextUnformatted(UiSharedService.ByteToString(item.CompressedSize));
|
ImGui.TextUnformatted(UiSharedService.ByteToString(item.CompressedSize));
|
||||||
if (ImGui.IsItemClicked()) _selectedHash = item.Hash;
|
if (ImGui.IsItemClicked()) _selectedHash = item.Hash;
|
||||||
|
if (fileGroup.Key == "tex")
|
||||||
|
{
|
||||||
ImGui.TableNextColumn();
|
ImGui.TableNextColumn();
|
||||||
ImGui.TextUnformatted(item.Format);
|
ImGui.TextUnformatted(item.Format.Value);
|
||||||
if (ImGui.IsItemClicked()) _selectedHash = item.Hash;
|
if (ImGui.IsItemClicked()) _selectedHash = item.Hash;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue