Refactor ReleaseEvent.

This commit is contained in:
2023-01-31 15:30:27 +08:00
parent 507b656eab
commit f9a1ea72fe
3 changed files with 18 additions and 23 deletions

View File

@@ -130,11 +130,11 @@ namespace Cryville.Crtr {
get { return Duration > 0; }
}
private InstantEvent relev = null;
private ReleaseEvent relev = null;
[JsonIgnore]
public InstantEvent ReleaseEvent {
public ReleaseEvent ReleaseEvent {
get {
if (relev == null) relev = new InstantEvent(this, true);
if (relev == null) relev = new ReleaseEvent(this);
return relev;
}
}
@@ -161,18 +161,12 @@ namespace Cryville.Crtr {
}
}
public class InstantEvent : ChartEvent {
public class ReleaseEvent : ChartEvent {
public readonly ChartEvent Original;
public bool IsRelease;
public InstantEvent(ChartEvent orig, bool release = false) {
IsRelease = release;
if (orig != null) {
Original = orig;
time = orig.time;
if (IsRelease)
BeatOffset = orig.Duration;
}
public ReleaseEvent(ChartEvent orig) {
Original = orig;
time = orig.endtime;
}
public override int Priority {
@@ -183,7 +177,7 @@ namespace Cryville.Crtr {
}
public abstract class EventContainer : ChartEvent {
public List<Chart.Motion> motions = new List<Chart.Motion>();
[JsonIgnore]
public Clip Clip { get; private set; }

View File

@@ -87,9 +87,11 @@ namespace Cryville.Crtr.Event {
stateMap[(EventContainer)ev].StampedContainer = sev;
}
if (ev is InstantEvent) {
var tev = (InstantEvent)ev;
var pev = map[tev.Original];
pev.Subevents.Add(sev);
if (ev is ReleaseEvent) {
var tev = (ReleaseEvent)ev;
var oev = tev.Original;
var pev = map[oev];
pev.ReleaseEvent = sev;
sev.Origin = pev;
}
if (con != null && coevents.Contains(ev)) {

View File

@@ -1,6 +1,5 @@
using System;
using System.Collections.Generic;
using System.Linq;
using CAnchor = Cryville.Crtr.Anchor;
namespace Cryville.Crtr {
@@ -9,9 +8,7 @@ namespace Cryville.Crtr {
public ChartEvent Unstamped;
public EventContainer Container;
public StampedEvent Origin;
public List<StampedEvent> Subevents = new List<StampedEvent>();
public List<StampedEvent> Coevents;
private StampedEvent relev = null;
public double Duration {
get {
@@ -47,10 +44,12 @@ namespace Cryville.Crtr {
}
}
StampedEvent relev = null;
public StampedEvent ReleaseEvent {
get {
if (relev == null) relev = Subevents.FirstOrDefault(ev => ((InstantEvent)ev.Unstamped).IsRelease);
return relev;
get { return relev; }
set {
if (relev != null) throw new InvalidOperationException("Release event already set");
relev = value;
}
}