Fixed editing lagginess when project window open, and fixed editing widget deadlock issue

This commit is contained in:
dexy 2018-12-17 00:07:20 +11:00
parent 37afa2335c
commit 439d10e23a
2 changed files with 339 additions and 429 deletions

View File

@ -4738,515 +4738,425 @@ namespace CodeWalker.Project
catch { } catch { }
} }
public void OnWorldSelectionModified(MapSelection sel, List<MapSelection> items) public void OnWorldSelectionModified(MapSelection sel, List<MapSelection> items)
{
if (sel.MultipleSelection)
{
//TODO!!
}
else if (sel.EntityDef != null)
{
OnWorldEntityModified(sel.EntityDef);
}
else if (sel.CarGenerator != null)
{
OnWorldCarGenModified(sel.CarGenerator);
}
else if (sel.PathNode != null)
{
OnWorldPathNodeModified(sel.PathNode, sel.PathLink);
}
else if (sel.NavPoly != null)
{
OnWorldNavPolyModified(sel.NavPoly);
}
else if (sel.NavPoint != null)
{
OnWorldNavPointModified(sel.NavPoint);
}
else if (sel.NavPortal != null)
{
OnWorldNavPortalModified(sel.NavPortal);
}
else if (sel.TrainTrackNode != null)
{
OnWorldTrainNodeModified(sel.TrainTrackNode);
}
else if (sel.ScenarioNode != null)
{
OnWorldScenarioNodeModified(sel.ScenarioNode);
}
else if (sel.Audio != null)
{
OnWorldAudioPlacementModified(sel.Audio);
}
}
private void OnWorldEntityModified(YmapEntityDef ent)
{ {
try try
{ {
if (InvokeRequired) if (InvokeRequired)
{ {
BeginInvoke(new Action(() => { OnWorldEntityModified(ent); })); BeginInvoke(new Action(() => { OnWorldSelectionModified(sel, items); }));
} }
else else
{ {
if ((ent.Ymap == null) && (ent.MloParent == null)) if (sel.MultipleSelection)
{ {
return;//TODO: properly handle interior entities! //TODO!!
} }
else if (sel.EntityDef != null)
if (CurrentProjectFile == null)
{ {
NewProject(); OnWorldEntityModified(sel.EntityDef);
} }
else if (sel.CarGenerator != null)
if (ent.MloParent == null && ent.Ymap != null)
{ {
if (!YmapExistsInProject(ent.Ymap)) OnWorldCarGenModified(sel.CarGenerator);
}
else if (sel.PathNode != null)
{
OnWorldPathNodeModified(sel.PathNode, sel.PathLink);
}
else if (sel.NavPoly != null)
{
OnWorldNavPolyModified(sel.NavPoly);
}
else if (sel.NavPoint != null)
{
OnWorldNavPointModified(sel.NavPoint);
}
else if (sel.NavPortal != null)
{
OnWorldNavPortalModified(sel.NavPortal);
}
else if (sel.TrainTrackNode != null)
{
OnWorldTrainNodeModified(sel.TrainTrackNode);
}
else if (sel.ScenarioNode != null)
{
OnWorldScenarioNodeModified(sel.ScenarioNode);
}
else if (sel.Audio != null)
{
OnWorldAudioPlacementModified(sel.Audio);
}
}
}
catch { }
}
private void OnWorldEntityModified(YmapEntityDef ent)
{
if ((ent.Ymap == null) && (ent.MloParent == null))
{
return;//TODO: properly handle interior entities!
}
if (CurrentProjectFile == null)
{
NewProject();
}
if (ent.MloParent == null && ent.Ymap != null)
{
if (!YmapExistsInProject(ent.Ymap))
{
ent.Ymap.HasChanged = true;
AddYmapToProject(ent.Ymap);
ProjectExplorer?.TrySelectEntityTreeNode(ent);
}
if (ent != CurrentEntity)
{
CurrentEntity = ent;
ProjectExplorer?.TrySelectEntityTreeNode(ent);
}
if (ent == CurrentEntity)
{
ShowEditYmapEntityPanel(false);
if (ent.Ymap != null)
{
SetYmapHasChanged(true);
}
}
}
else if (ent.MloParent != null && ent.Ymap == null)
{
MloInstanceData mloInstance = ent.MloParent?.MloInstance;
if (mloInstance != null)
{
var mcEntity = mloInstance.TryGetArchetypeEntity(ent);
if (mcEntity != null)
{
if (!YtypExistsInProject(ent.MloParent.Archetype.Ytyp))
{ {
ent.Ymap.HasChanged = true; ent.MloParent.Archetype.Ytyp.HasChanged = true;
AddYmapToProject(ent.Ymap); AddYtypToProject(ent.MloParent.Archetype.Ytyp);
ProjectExplorer?.TrySelectEntityTreeNode(ent); ProjectExplorer?.TrySelectMloEntityTreeNode(mcEntity);
} }
if (ent != CurrentEntity) if (ent != CurrentEntity)
{ {
CurrentEntity = ent; CurrentEntity = ent;
ProjectExplorer?.TrySelectEntityTreeNode(ent); ProjectExplorer?.TrySelectMloEntityTreeNode(mcEntity);
}
if (ent == CurrentEntity)
{
ShowEditYmapEntityPanel(false);
if (ent.Ymap != null)
{
SetYmapHasChanged(true);
}
}
}
else if (ent.MloParent != null && ent.Ymap == null)
{
MloInstanceData mloInstance = ent.MloParent?.MloInstance;
if (mloInstance != null)
{
var mcEntity = mloInstance.TryGetArchetypeEntity(ent);
if (mcEntity != null)
{
if (!YtypExistsInProject(ent.MloParent.Archetype.Ytyp))
{
ent.MloParent.Archetype.Ytyp.HasChanged = true;
AddYtypToProject(ent.MloParent.Archetype.Ytyp);
ProjectExplorer?.TrySelectMloEntityTreeNode(mcEntity);
}
if (ent != CurrentEntity)
{
CurrentEntity = ent;
ProjectExplorer?.TrySelectMloEntityTreeNode(mcEntity);
}
}
}
if (ent == CurrentEntity)
{
ShowEditYmapEntityPanel(false);
if (ent.MloParent.Archetype.Ytyp != null)
{
SetYtypHasChanged(true);
}
} }
} }
} }
if (ent == CurrentEntity)
{
ShowEditYmapEntityPanel(false);
if (ent.MloParent.Archetype.Ytyp != null)
{
SetYtypHasChanged(true);
}
}
} }
catch { }
} }
private void OnWorldCarGenModified(YmapCarGen cargen) private void OnWorldCarGenModified(YmapCarGen cargen)
{ {
try if (cargen?.Ymap == null) return;
if (CurrentProjectFile == null)
{ {
if (InvokeRequired) NewProject();
}
if (!YmapExistsInProject(cargen.Ymap))
{
cargen.Ymap.HasChanged = true;
AddYmapToProject(cargen.Ymap);
ProjectExplorer?.TrySelectCarGenTreeNode(cargen);
}
if (cargen != CurrentCarGen)
{
CurrentCarGen = cargen;
ProjectExplorer?.TrySelectCarGenTreeNode(cargen);
}
if (cargen == CurrentCarGen)
{
ShowEditYmapCarGenPanel(false);
ProjectExplorer?.UpdateCarGenTreeNode(cargen);
if (cargen.Ymap != null)
{ {
BeginInvoke(new Action(() => { OnWorldCarGenModified(cargen); })); SetYmapHasChanged(true);
}
else
{
if (cargen?.Ymap == null) return;
if (CurrentProjectFile == null)
{
NewProject();
}
if (!YmapExistsInProject(cargen.Ymap))
{
cargen.Ymap.HasChanged = true;
AddYmapToProject(cargen.Ymap);
ProjectExplorer?.TrySelectCarGenTreeNode(cargen);
}
if (cargen != CurrentCarGen)
{
CurrentCarGen = cargen;
ProjectExplorer?.TrySelectCarGenTreeNode(cargen);
}
if (cargen == CurrentCarGen)
{
ShowEditYmapCarGenPanel(false);
ProjectExplorer?.UpdateCarGenTreeNode(cargen);
if (cargen.Ymap != null)
{
SetYmapHasChanged(true);
}
}
} }
} }
catch { }
} }
private void OnWorldPathNodeModified(YndNode node, YndLink link) private void OnWorldPathNodeModified(YndNode node, YndLink link)
{ {
try if (node?.Ynd == null) return;
if (CurrentProjectFile == null)
{ {
if (InvokeRequired) NewProject();
}
if (!YndExistsInProject(node.Ynd))
{
node.Ynd.HasChanged = true;
AddYndToProject(node.Ynd);
ProjectExplorer?.TrySelectPathNodeTreeNode(node);
}
if (node != CurrentPathNode)
{
CurrentPathNode = node;
ProjectExplorer?.TrySelectPathNodeTreeNode(node);
}
//////if (link != CurrentPathLink)
//////{
////// CurrentPathLink = link;
////// ShowEditYndLinkPanel(false);
//////}
if (node == CurrentPathNode)
{
//////ShowEditYndPanel(false);
ShowEditYndNodePanel(false);
//////UpdatePathNodeTreeNode(node);
if (node.Ynd != null)
{ {
BeginInvoke(new Action(() => { OnWorldPathNodeModified(node, link); })); SetYndHasChanged(true);
}
else
{
if (node?.Ynd == null) return;
if (CurrentProjectFile == null)
{
NewProject();
}
if (!YndExistsInProject(node.Ynd))
{
node.Ynd.HasChanged = true;
AddYndToProject(node.Ynd);
ProjectExplorer?.TrySelectPathNodeTreeNode(node);
}
if (node != CurrentPathNode)
{
CurrentPathNode = node;
ProjectExplorer?.TrySelectPathNodeTreeNode(node);
}
//////if (link != CurrentPathLink)
//////{
////// CurrentPathLink = link;
////// ShowEditYndLinkPanel(false);
//////}
if (node == CurrentPathNode)
{
//////ShowEditYndPanel(false);
ShowEditYndNodePanel(false);
//////UpdatePathNodeTreeNode(node);
if (node.Ynd != null)
{
SetYndHasChanged(true);
}
}
} }
} }
catch { }
} }
private void OnWorldNavPolyModified(YnvPoly poly) private void OnWorldNavPolyModified(YnvPoly poly)
{ {
try if (poly?.Ynv == null) return;
if (CurrentProjectFile == null)
{ {
if (InvokeRequired) NewProject();
}
if (!YnvExistsInProject(poly.Ynv))
{
poly.Ynv.HasChanged = true;
AddYnvToProject(poly.Ynv);
ProjectExplorer?.TrySelectNavPolyTreeNode(poly);
}
if (poly != CurrentNavPoly)
{
CurrentNavPoly = poly;
ProjectExplorer?.TrySelectNavPolyTreeNode(poly);
}
if (poly == CurrentNavPoly)
{
ShowEditYnvPolyPanel(false);
//////UpdateNavPolyTreeNode(poly);
if (poly.Ynv != null)
{ {
BeginInvoke(new Action(() => { OnWorldNavPolyModified(poly); })); SetYnvHasChanged(true);
}
else
{
if (poly?.Ynv == null) return;
if (CurrentProjectFile == null)
{
NewProject();
}
if (!YnvExistsInProject(poly.Ynv))
{
poly.Ynv.HasChanged = true;
AddYnvToProject(poly.Ynv);
ProjectExplorer?.TrySelectNavPolyTreeNode(poly);
}
if (poly != CurrentNavPoly)
{
CurrentNavPoly = poly;
ProjectExplorer?.TrySelectNavPolyTreeNode(poly);
}
if (poly == CurrentNavPoly)
{
ShowEditYnvPolyPanel(false);
//////UpdateNavPolyTreeNode(poly);
if (poly.Ynv != null)
{
SetYnvHasChanged(true);
}
}
} }
} }
catch { }
} }
private void OnWorldNavPointModified(YnvPoint point) private void OnWorldNavPointModified(YnvPoint point)
{ {
try if (point?.Ynv == null) return;
if (CurrentProjectFile == null)
{ {
if (InvokeRequired) NewProject();
}
if (!YnvExistsInProject(point.Ynv))
{
point.Ynv.HasChanged = true;
AddYnvToProject(point.Ynv);
ProjectExplorer?.TrySelectNavPointTreeNode(point);
}
if (point != CurrentNavPoint)
{
CurrentNavPoint = point;
ProjectExplorer?.TrySelectNavPointTreeNode(point);
}
if (point == CurrentNavPoint)
{
ShowEditYnvPointPanel(false);
//////UpdateNavPointTreeNode(poly);
if (point.Ynv != null)
{ {
BeginInvoke(new Action(() => { OnWorldNavPointModified(point); })); SetYnvHasChanged(true);
}
else
{
if (point?.Ynv == null) return;
if (CurrentProjectFile == null)
{
NewProject();
}
if (!YnvExistsInProject(point.Ynv))
{
point.Ynv.HasChanged = true;
AddYnvToProject(point.Ynv);
ProjectExplorer?.TrySelectNavPointTreeNode(point);
}
if (point != CurrentNavPoint)
{
CurrentNavPoint = point;
ProjectExplorer?.TrySelectNavPointTreeNode(point);
}
if (point == CurrentNavPoint)
{
ShowEditYnvPointPanel(false);
//////UpdateNavPointTreeNode(poly);
if (point.Ynv != null)
{
SetYnvHasChanged(true);
}
}
} }
} }
catch { }
} }
private void OnWorldNavPortalModified(YnvPortal portal) private void OnWorldNavPortalModified(YnvPortal portal)
{ {
try if (portal?.Ynv == null) return;
if (CurrentProjectFile == null)
{ {
if (InvokeRequired) NewProject();
}
if (!YnvExistsInProject(portal.Ynv))
{
portal.Ynv.HasChanged = true;
AddYnvToProject(portal.Ynv);
ProjectExplorer?.TrySelectNavPortalTreeNode(portal);
}
if (portal != CurrentNavPortal)
{
CurrentNavPortal = portal;
ProjectExplorer?.TrySelectNavPortalTreeNode(portal);
}
if (portal == CurrentNavPortal)
{
ShowEditYnvPortalPanel(false);
//////UpdateNavPortalTreeNode(poly);
if (portal.Ynv != null)
{ {
BeginInvoke(new Action(() => { OnWorldNavPortalModified(portal); })); SetYnvHasChanged(true);
}
else
{
if (portal?.Ynv == null) return;
if (CurrentProjectFile == null)
{
NewProject();
}
if (!YnvExistsInProject(portal.Ynv))
{
portal.Ynv.HasChanged = true;
AddYnvToProject(portal.Ynv);
ProjectExplorer?.TrySelectNavPortalTreeNode(portal);
}
if (portal != CurrentNavPortal)
{
CurrentNavPortal = portal;
ProjectExplorer?.TrySelectNavPortalTreeNode(portal);
}
if (portal == CurrentNavPortal)
{
ShowEditYnvPortalPanel(false);
//////UpdateNavPortalTreeNode(poly);
if (portal.Ynv != null)
{
SetYnvHasChanged(true);
}
}
} }
} }
catch { }
} }
private void OnWorldTrainNodeModified(TrainTrackNode node) private void OnWorldTrainNodeModified(TrainTrackNode node)
{ {
try if (node?.Track == null) return;
if (CurrentProjectFile == null)
{ {
if (InvokeRequired) NewProject();
}
if (!TrainTrackExistsInProject(node.Track))
{
node.Track.HasChanged = true;
AddTrainTrackToProject(node.Track);
ProjectExplorer?.TrySelectTrainNodeTreeNode(node);
}
if (node != CurrentTrainNode)
{
CurrentTrainNode = node;
ProjectExplorer?.TrySelectTrainNodeTreeNode(node);
}
if (node == CurrentTrainNode)
{
ShowEditTrainNodePanel(false);
if (node.Track != null)
{ {
BeginInvoke(new Action(() => { OnWorldTrainNodeModified(node); })); SetTrainTrackHasChanged(true);
}
else
{
if (node?.Track == null) return;
if (CurrentProjectFile == null)
{
NewProject();
}
if (!TrainTrackExistsInProject(node.Track))
{
node.Track.HasChanged = true;
AddTrainTrackToProject(node.Track);
ProjectExplorer?.TrySelectTrainNodeTreeNode(node);
}
if (node != CurrentTrainNode)
{
CurrentTrainNode = node;
ProjectExplorer?.TrySelectTrainNodeTreeNode(node);
}
if (node == CurrentTrainNode)
{
ShowEditTrainNodePanel(false);
if (node.Track != null)
{
SetTrainTrackHasChanged(true);
}
}
} }
} }
catch { }
} }
private void OnWorldScenarioNodeModified(ScenarioNode node) private void OnWorldScenarioNodeModified(ScenarioNode node)
{ {
try if (node?.Ymt == null) return;
if (CurrentProjectFile == null)
{ {
if (InvokeRequired) NewProject();
}
if (!ScenarioExistsInProject(node.Ymt))
{
node.Ymt.HasChanged = true;
AddScenarioToProject(node.Ymt);
ProjectExplorer?.TrySelectScenarioNodeTreeNode(node);
}
if (node != CurrentScenarioNode)
{
CurrentScenarioNode = node;
ProjectExplorer?.TrySelectScenarioNodeTreeNode(node);
}
if (node == CurrentScenarioNode)
{
//ShowEditScenarioPanel(false);
ShowEditScenarioNodePanel(false);
if (node?.Ymt != null)
{ {
BeginInvoke(new Action(() => { OnWorldScenarioNodeModified(node); })); SetScenarioHasChanged(true);
}
else
{
if (node?.Ymt == null) return;
if (CurrentProjectFile == null)
{
NewProject();
}
if (!ScenarioExistsInProject(node.Ymt))
{
node.Ymt.HasChanged = true;
AddScenarioToProject(node.Ymt);
ProjectExplorer?.TrySelectScenarioNodeTreeNode(node);
}
if (node != CurrentScenarioNode)
{
CurrentScenarioNode = node;
ProjectExplorer?.TrySelectScenarioNodeTreeNode(node);
}
if (node == CurrentScenarioNode)
{
//ShowEditScenarioPanel(false);
ShowEditScenarioNodePanel(false);
if (node?.Ymt != null)
{
SetScenarioHasChanged(true);
}
}
} }
} }
catch { }
} }
private void OnWorldAudioPlacementModified(AudioPlacement audio) private void OnWorldAudioPlacementModified(AudioPlacement audio)
{ {
try if (audio?.RelFile == null) return;
if (CurrentProjectFile == null)
{ {
if (InvokeRequired) NewProject();
}
if (!AudioFileExistsInProject(audio.RelFile))
{
audio.RelFile.HasChanged = true;
AddAudioFileToProject(audio.RelFile);
if (audio.AudioZone != null)
{ {
BeginInvoke(new Action(() => { OnWorldAudioPlacementModified(audio); })); ProjectExplorer?.TrySelectAudioZoneTreeNode(audio);
} }
else if (audio.AudioEmitter != null)
{ {
if (audio?.RelFile == null) return; ProjectExplorer?.TrySelectAudioEmitterTreeNode(audio);
}
if (CurrentProjectFile == null) }
{
NewProject(); if ((audio.AudioZone != null) && (audio != CurrentAudioZone))
} {
CurrentAudioZone = audio;
if (!AudioFileExistsInProject(audio.RelFile)) ProjectExplorer?.TrySelectAudioZoneTreeNode(audio);
{ }
audio.RelFile.HasChanged = true; if ((audio.AudioEmitter != null) && (audio != CurrentAudioEmitter))
AddAudioFileToProject(audio.RelFile); {
if (audio.AudioZone != null) CurrentAudioEmitter = audio;
{ ProjectExplorer?.TrySelectAudioEmitterTreeNode(audio);
ProjectExplorer?.TrySelectAudioZoneTreeNode(audio); }
} if (audio == CurrentAudioZone)
if (audio.AudioEmitter != null) {
{ ShowEditAudioZonePanel(false);
ProjectExplorer?.TrySelectAudioEmitterTreeNode(audio); if (audio.RelFile != null)
} {
} SetAudioFileHasChanged(true);
}
if ((audio.AudioZone != null) && (audio != CurrentAudioZone)) }
{ else if (audio == CurrentAudioEmitter)
CurrentAudioZone = audio; {
ProjectExplorer?.TrySelectAudioZoneTreeNode(audio); ShowEditAudioEmitterPanel(false);
} if (audio.RelFile != null)
if ((audio.AudioEmitter != null) && (audio != CurrentAudioEmitter)) {
{ SetAudioFileHasChanged(true);
CurrentAudioEmitter = audio;
ProjectExplorer?.TrySelectAudioEmitterTreeNode(audio);
}
if (audio == CurrentAudioZone)
{
ShowEditAudioZonePanel(false);
if (audio.RelFile != null)
{
SetAudioFileHasChanged(true);
}
}
else if (audio == CurrentAudioEmitter)
{
ShowEditAudioEmitterPanel(false);
if (audio.RelFile != null)
{
SetAudioFileHasChanged(true);
}
}
} }
} }
catch { }
} }

View File

@ -3375,7 +3375,7 @@ namespace CodeWalker
if (mhit.HasValue) if (mhit.HasValue)
{ {
//make sure the path link gets changed (sub-selection!) //make sure the path link gets changed (sub-selection!)
lock (Renderer.RenderSyncRoot) //lock (Renderer.RenderSyncRoot)
{ {
SelectedItem.PathLink = mhitv.PathLink; SelectedItem.PathLink = mhitv.PathLink;
SelectedItem.ScenarioEdge = mhitv.ScenarioEdge; SelectedItem.ScenarioEdge = mhitv.ScenarioEdge;