|
|
1d3aae |
using System;
|
|
|
1d3aae |
using System.Diagnostics;
|
|
|
1d3aae |
using System.Collections.Generic;
|
|
|
1d3aae |
|
|
|
1d3aae |
namespace Assistance {
|
|
|
1d3aae |
public class InputModifierAssistants: InputModifierTangents {
|
|
|
1d3aae |
public readonly Workarea workarea;
|
|
|
1d3aae |
public readonly bool interpolate;
|
|
|
1d3aae |
|
|
|
1d3aae |
public InputModifierAssistants(Workarea workarea, bool interpolate = false, double precision = 1.0):
|
|
|
1d3aae |
base(precision)
|
|
|
1d3aae |
{
|
|
|
1d3aae |
this.workarea = workarea;
|
|
|
1d3aae |
this.interpolate = interpolate;
|
|
|
1d3aae |
}
|
|
|
1d3aae |
|
|
|
1d3aae |
public class Modifier: Track.Modifier {
|
|
|
1d3aae |
public Modifier(Track.Handler handler):
|
|
|
1d3aae |
base(handler) { }
|
|
|
1d3aae |
|
|
|
1d3aae |
public InputManager.KeyPoint.Holder holder = null;
|
|
|
1d3aae |
public List<guideline> guidelines = new List<guideline>();</guideline></guideline>
|
|
|
1d3aae |
|
|
|
1d3aae |
public override Track.WayPoint calcWayPoint(double originalIndex) {
|
|
|
1d3aae |
Track.WayPoint p = original.calcWayPoint(originalIndex);
|
|
|
1d3aae |
return guidelines.Count > 0 ? guidelines[0].transformPoint(p) : p;
|
|
|
1d3aae |
}
|
|
|
1d3aae |
}
|
|
|
1d3aae |
|
|
|
1d3aae |
public override List<track> modify(Track track, InputManager.KeyPoint keyPoint, List<track> outTracks) {
|
|
|
1d3aae |
Track subTrack;
|
|
|
1d3aae |
Modifier modifier;
|
|
|
1d3aae |
|
|
|
1d3aae |
if (track.handler == null) {
|
|
|
1d3aae |
if (track.points.Count == 0)
|
|
|
1d3aae |
return;
|
|
|
1d3aae |
|
|
|
1d3aae |
Track.Handler handler = new Track.Handler(this, track);
|
|
|
1d3aae |
modifier = new Track.Modifier(track.handler);
|
|
|
1d3aae |
workarea.getGuidelines(modifier.guidelines, track.points[0].point.position);
|
|
|
1d3aae |
if (interpolate && modifier.guidelines.Count == 0)
|
|
|
1d3aae |
{ base.modify(track, keyPoint, outTracks); return; }
|
|
|
1d3aae |
|
|
|
1d3aae |
track.handler = handler;
|
|
|
1d3aae |
subTrack = new Track(modifier);
|
|
|
1d3aae |
track.handler.tracks.Add(subTrack);
|
|
|
1d3aae |
|
|
|
1d3aae |
if (modifier.guidelines.Count > 1) {
|
|
|
1d3aae |
modifier.holder = keyPoint.hold();
|
|
|
1d3aae |
outTracks.Add(subTrack);
|
|
|
1d3aae |
return;
|
|
|
1d3aae |
}
|
|
|
1d3aae |
}
|
|
|
1d3aae |
|
|
|
1d3aae |
subTrack = track.handler.tracks[0];
|
|
|
1d3aae |
if (subTrack.modifier is InputModifierTangents.Modifier)
|
|
|
1d3aae |
{ base.modify(track, keyPoint, outTracks); return; }
|
|
|
1d3aae |
|
|
|
1d3aae |
modifier = (Modifier)subTrack.modifier;
|
|
|
1d3aae |
outTracks.Add(subTrack);
|
|
|
1d3aae |
|
|
|
1d3aae |
if (!track.isChanged)
|
|
|
1d3aae |
return;
|
|
|
1d3aae |
|
|
|
1d3aae |
// remove points
|
|
|
1d3aae |
int start = track.points.Count - track.wayPointsAdded;
|
|
|
1d3aae |
if (start < 0) start = 0;
|
|
|
1d3aae |
if (subTrack.points.Count < start) {
|
|
|
1d3aae |
subTrack.points.RemoveRange(start, subTrack.points.Count - start);
|
|
|
1d3aae |
subTrack.wayPointsRemoved += subTrack.points.Count - start;
|
|
|
1d3aae |
}
|
|
|
1d3aae |
|
|
|
1d3aae |
bool trackIsLong = track.points.Count > 0 && track.getLast().length > 2.0*Guideline.snapLenght;
|
|
|
1d3aae |
if (!trackIsLong && modifier.holder != null && !modifier.holder.isHolded && modifier.holder.available)
|
|
|
1d3aae |
modifier.holder.reuse();
|
|
|
1d3aae |
|
|
|
1d3aae |
// select guideline
|
|
|
1d3aae |
if (modifier.holder != null && modifier.holder.isHolded) {
|
|
|
1d3aae |
Guideline guideline = Guideline.findBest(modifier.guidelines, track);
|
|
|
1d3aae |
if (guideline != modifier.guidelines[0]) {
|
|
|
1d3aae |
modifier.guidelines[ modifier.guidelines.IndexOf(guideline) ] = modifier.guidelines[0];
|
|
|
1d3aae |
modifier.guidelines[0] = guideline;
|
|
|
1d3aae |
start = 0;
|
|
|
1d3aae |
subTrack.wayPointsRemoved += subTrack.points.Count;
|
|
|
1d3aae |
subTrack.points.Clear;
|
|
|
1d3aae |
}
|
|
|
1d3aae |
if (trackIsLong)
|
|
|
1d3aae |
modifier.holder.release();
|
|
|
1d3aae |
}
|
|
|
1d3aae |
|
|
|
1d3aae |
// add points
|
|
|
1d3aae |
for(int i = start; i < track.points.Count; ++i)
|
|
|
1d3aae |
subTrack.points.Add(modifier.calcWayPoint(i));
|
|
|
1d3aae |
subTrack.wayPointsAdded = subTrack.points.Count - start;
|
|
|
1d3aae |
}
|
|
|
1d3aae |
}
|
|
|
1d3aae |
}
|
|
|
1d3aae |
|