Fix mesh isolation.
This commit is contained in:
parent
26d9be2a19
commit
d8d4d1fb3e
@ -48,7 +48,7 @@ OV.Navigator = class
|
||||
this.panelSet.AddPanel (this.filesPanel);
|
||||
this.panelSet.AddPanel (this.materialsPanel);
|
||||
this.panelSet.AddPanel (this.meshesPanel);
|
||||
this.panelSet.ShowPanel (2);
|
||||
this.panelSet.ShowPanel (this.meshesPanel);
|
||||
}
|
||||
|
||||
Init (callbacks)
|
||||
@ -113,24 +113,19 @@ OV.Navigator = class
|
||||
|
||||
ShowAllMeshes ()
|
||||
{
|
||||
this.meshesPanel.navigatorItems.EnumerateMeshItems ((meshItem) => {
|
||||
meshItem.SetVisible (true);
|
||||
return true;
|
||||
});
|
||||
this.meshesPanel.ShowAllMeshes ();
|
||||
this.callbacks.updateMeshesVisibility ();
|
||||
}
|
||||
|
||||
ToggleNodeVisibility (nodeId)
|
||||
{
|
||||
let nodeItem = this.meshesPanel.navigatorItems.GetNodeItem (nodeId);
|
||||
nodeItem.SetVisible (!nodeItem.IsVisible ());
|
||||
this.meshesPanel.ToggleNodeVisibility (nodeId);
|
||||
this.callbacks.updateMeshesVisibility ();
|
||||
}
|
||||
|
||||
ToggleMeshVisibility (meshInstanceId)
|
||||
{
|
||||
let meshItem = this.meshesPanel.navigatorItems.GetMeshItem (meshInstanceId);
|
||||
meshItem.SetVisible (!meshItem.IsVisible ());
|
||||
this.meshesPanel.ToggleMeshVisibility (meshInstanceId);
|
||||
this.callbacks.updateMeshesVisibility ();
|
||||
}
|
||||
|
||||
@ -142,6 +137,7 @@ OV.Navigator = class
|
||||
IsolateMesh (meshInstanceId)
|
||||
{
|
||||
this.meshesPanel.IsolateMesh (meshInstanceId);
|
||||
this.callbacks.updateMeshesVisibility ();
|
||||
}
|
||||
|
||||
GetSelectedMeshId ()
|
||||
@ -162,7 +158,7 @@ OV.Navigator = class
|
||||
if (selection.type === OV.SelectionType.Material) {
|
||||
navigator.materialsPanel.GetMaterialItem (selection.materialIndex).SetSelected (select);
|
||||
} else if (selection.type === OV.SelectionType.Mesh) {
|
||||
navigator.meshesPanel.navigatorItems.GetMeshItem (selection.meshInstanceId).SetSelected (select);
|
||||
navigator.meshesPanel.GetMeshItem (selection.meshInstanceId).SetSelected (select);
|
||||
}
|
||||
}
|
||||
|
||||
@ -209,7 +205,7 @@ OV.Navigator = class
|
||||
FitNodeToWindow (nodeId)
|
||||
{
|
||||
let meshInstanceIdSet = new Set ();
|
||||
let nodeItem = this.meshesPanel.navigatorItems.GetNodeItem (nodeId);
|
||||
let nodeItem = this.meshesPanel.GetNodeItem (nodeId);
|
||||
nodeItem.EnumerateMeshItems ((meshItem) => {
|
||||
meshInstanceIdSet.add (meshItem.GetMeshInstanceId ());
|
||||
});
|
||||
|
||||
@ -128,64 +128,3 @@ OV.NodeItem = class extends OV.TreeViewGroupButtonItem
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
OV.NavigatorItems = class
|
||||
{
|
||||
constructor ()
|
||||
{
|
||||
this.materialIndexToItem = new Map ();
|
||||
this.nodeIdToItem = new Map ();
|
||||
this.meshInstanceIdToItem = new Map ();
|
||||
}
|
||||
|
||||
GetMaterialItem (materialIndex)
|
||||
{
|
||||
return this.materialIndexToItem.get (materialIndex);
|
||||
}
|
||||
|
||||
AddMaterialItem (materialIndex, materialItem)
|
||||
{
|
||||
this.materialIndexToItem.set (materialIndex, materialItem);
|
||||
}
|
||||
|
||||
MeshItemCount ()
|
||||
{
|
||||
return this.meshInstanceIdToItem.size;
|
||||
}
|
||||
|
||||
GetNodeItem (nodeId)
|
||||
{
|
||||
return this.nodeIdToItem.get (nodeId);
|
||||
}
|
||||
|
||||
AddNodeItem (nodeId, meshItem)
|
||||
{
|
||||
this.nodeIdToItem.set (nodeId, meshItem);
|
||||
}
|
||||
|
||||
GetMeshItem (meshInstanceId)
|
||||
{
|
||||
return this.meshInstanceIdToItem.get (meshInstanceId.GetKey ());
|
||||
}
|
||||
|
||||
AddMeshItem (meshInstanceId, meshItem)
|
||||
{
|
||||
this.meshInstanceIdToItem.set (meshInstanceId.GetKey (), meshItem);
|
||||
}
|
||||
|
||||
EnumerateMeshItems (processor)
|
||||
{
|
||||
for (const meshItem of this.meshInstanceIdToItem.values ()) {
|
||||
if (!processor (meshItem)) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Clear ()
|
||||
{
|
||||
this.materialIndexToItem = new Map ();
|
||||
this.nodeIdToItem = new Map ();
|
||||
this.meshInstanceIdToItem = new Map ();
|
||||
}
|
||||
};
|
||||
|
||||
@ -262,9 +262,10 @@ OV.NavigatorMeshesPanel = class extends OV.NavigatorPanel
|
||||
super (parentDiv);
|
||||
|
||||
this.callbacks = null;
|
||||
this.nodeIdToItem = new Map ();
|
||||
this.meshInstanceIdToItem = new Map ();
|
||||
|
||||
this.treeView = new OV.TreeView (this.treeDiv);
|
||||
// TODO: delete
|
||||
this.navigatorItems = new OV.NavigatorItems ();
|
||||
}
|
||||
|
||||
GetIcon ()
|
||||
@ -282,7 +283,8 @@ OV.NavigatorMeshesPanel = class extends OV.NavigatorPanel
|
||||
Clear ()
|
||||
{
|
||||
super.Clear ();
|
||||
this.navigatorItems.Clear ();
|
||||
this.nodeIdToItem = new Map ();
|
||||
this.meshInstanceIdToItem = new Map ();
|
||||
}
|
||||
|
||||
Init (callbacks)
|
||||
@ -324,7 +326,7 @@ OV.NavigatorMeshesPanel = class extends OV.NavigatorPanel
|
||||
navigator.callbacks.onMeshSelected (selectedMeshId);
|
||||
}
|
||||
});
|
||||
navigator.navigatorItems.AddMeshItem (meshInstanceId, meshItem);
|
||||
navigator.meshInstanceIdToItem.set (meshInstanceId.GetKey (), meshItem);
|
||||
parentItem.AddChild (meshItem);
|
||||
}
|
||||
|
||||
@ -340,7 +342,7 @@ OV.NavigatorMeshesPanel = class extends OV.NavigatorPanel
|
||||
navigator.callbacks.onNodeFitToWindow (selectedNodeId);
|
||||
}
|
||||
});
|
||||
navigator.navigatorItems.AddNodeItem (nodeId, nodeItem);
|
||||
navigator.nodeIdToItem.set (nodeId, nodeItem);
|
||||
return nodeItem;
|
||||
}
|
||||
|
||||
@ -369,21 +371,40 @@ OV.NavigatorMeshesPanel = class extends OV.NavigatorPanel
|
||||
AddModelNodeToTree (this, model, rootNode, meshesItem, isFlat);
|
||||
}
|
||||
|
||||
GetNodeItem (nodeId)
|
||||
{
|
||||
return this.nodeIdToItem.get (nodeId);
|
||||
}
|
||||
|
||||
MeshItemCount ()
|
||||
{
|
||||
return this.navigatorItems.MeshItemCount ();
|
||||
return this.meshInstanceIdToItem.size;
|
||||
}
|
||||
|
||||
GetMeshItem (meshInstanceId)
|
||||
{
|
||||
return this.meshInstanceIdToItem.get (meshInstanceId.GetKey ());
|
||||
}
|
||||
|
||||
EnumerateMeshItems (processor)
|
||||
{
|
||||
for (const meshItem of this.meshInstanceIdToItem.values ()) {
|
||||
if (!processor (meshItem)) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
IsMeshVisible (meshInstanceId)
|
||||
{
|
||||
let meshItem = this.navigatorItems.GetMeshItem (meshInstanceId);
|
||||
let meshItem = this.GetMeshItem (meshInstanceId);
|
||||
return meshItem.IsVisible ();
|
||||
}
|
||||
|
||||
HasHiddenMesh ()
|
||||
{
|
||||
let hasHiddenMesh = false;
|
||||
this.navigatorItems.EnumerateMeshItems ((meshItem) => {
|
||||
this.EnumerateMeshItems ((meshItem) => {
|
||||
if (!meshItem.IsVisible ()) {
|
||||
hasHiddenMesh = true;
|
||||
return false;
|
||||
@ -393,10 +414,30 @@ OV.NavigatorMeshesPanel = class extends OV.NavigatorPanel
|
||||
return hasHiddenMesh;
|
||||
}
|
||||
|
||||
ShowAllMeshes ()
|
||||
{
|
||||
this.EnumerateMeshItems ((meshItem) => {
|
||||
meshItem.SetVisible (true);
|
||||
return true;
|
||||
});
|
||||
}
|
||||
|
||||
ToggleNodeVisibility (nodeId)
|
||||
{
|
||||
let nodeItem = this.GetNodeItem (nodeId);
|
||||
nodeItem.SetVisible (!nodeItem.IsVisible ());
|
||||
}
|
||||
|
||||
ToggleMeshVisibility (meshInstanceId)
|
||||
{
|
||||
let meshItem = this.GetMeshItem (meshInstanceId);
|
||||
meshItem.SetVisible (!meshItem.IsVisible ());
|
||||
}
|
||||
|
||||
IsMeshIsolated (meshInstanceId)
|
||||
{
|
||||
let isIsolated = true;
|
||||
this.navigatorItems.EnumerateMeshItems ((meshItem) => {
|
||||
this.EnumerateMeshItems ((meshItem) => {
|
||||
if (!meshItem.GetMeshInstanceId ().IsEqual (meshInstanceId) && meshItem.IsVisible ()) {
|
||||
isIsolated = false;
|
||||
return false;
|
||||
@ -409,7 +450,7 @@ OV.NavigatorMeshesPanel = class extends OV.NavigatorPanel
|
||||
IsolateMesh (meshInstanceId)
|
||||
{
|
||||
let isIsolated = this.IsMeshIsolated (meshInstanceId);
|
||||
this.navigatorItems.EnumerateMeshItems ((meshItem) => {
|
||||
this.EnumerateMeshItems ((meshItem) => {
|
||||
if (meshItem.GetMeshInstanceId ().IsEqual (meshInstanceId) || isIsolated) {
|
||||
meshItem.SetVisible (true);
|
||||
} else {
|
||||
@ -417,7 +458,6 @@ OV.NavigatorMeshesPanel = class extends OV.NavigatorPanel
|
||||
}
|
||||
return true;
|
||||
});
|
||||
this.callbacks.updateMeshesVisibility ();
|
||||
}
|
||||
|
||||
UpdatePopupButton ()
|
||||
|
||||
@ -55,20 +55,18 @@ OV.PanelSet = class
|
||||
|
||||
AddPanel (panel)
|
||||
{
|
||||
let panelIndex = this.panels.length;
|
||||
this.panels.push (panel);
|
||||
let button = OV.AddSvgIcon (this.menuDiv, panel.GetIcon (), 'ov_panel_set_menu_button');
|
||||
button.click (() => {
|
||||
this.ShowPanel (panelIndex);
|
||||
this.ShowPanel (panel);
|
||||
});
|
||||
}
|
||||
|
||||
ShowPanel (panelIndex)
|
||||
ShowPanel (panel)
|
||||
{
|
||||
for (let panel of this.panels) {
|
||||
panel.Show (false);
|
||||
for (let otherPanel of this.panels) {
|
||||
otherPanel.Show (false);
|
||||
}
|
||||
let panel = this.panels[panelIndex];
|
||||
panel.Show (true);
|
||||
panel.Resize ();
|
||||
}
|
||||
|
||||
Loading…
Reference in New Issue
Block a user