From 35786bfec967b2a9f1abc570bffe73530c053207 Mon Sep 17 00:00:00 2001 From: loudonclear Date: Fri, 14 Jun 2019 14:31:01 -0400 Subject: interpolation when there are no/one keyframe --- src/client/views/nodes/Timeline.tsx | 50 +++++++++++++++++++++++-------------- 1 file changed, 31 insertions(+), 19 deletions(-) (limited to 'src') diff --git a/src/client/views/nodes/Timeline.tsx b/src/client/views/nodes/Timeline.tsx index b42bc478e..b46bf2e75 100644 --- a/src/client/views/nodes/Timeline.tsx +++ b/src/client/views/nodes/Timeline.tsx @@ -95,15 +95,11 @@ export class Timeline extends CollectionSubView(Document) { if (!this._barMoved) { if (this._data.indexOf(node) !== -1 && this._keyframes.length < this._data.length) { let timeandpos = this.setTimeAndPos(node); - //change it to dictionary here............................................................................ - let dict = new Dictionary(); let info: List = new List(new Array(1000)); //kinda weird info[this._currentBarX] = timeandpos; this._keyframes.push(info); - console.log(this._keyframes.length); this._bars = []; this._bars.push({ x: this._currentBarX, doc: node }); - //................................................................................................... } else { let index = this._data.indexOf(node); console.log(index); @@ -156,6 +152,7 @@ export class Timeline extends CollectionSubView(Document) { @action timeChange = async (time: number) => { const docs = this._data; + console.log(docs.length + " from time change"); docs.forEach(async (oneDoc, i) => { let OD: Doc = await oneDoc; let leftKf!: TimeAndPosition; @@ -173,35 +170,49 @@ export class Timeline extends CollectionSubView(Document) { if (singleKf.time !== time) { //choose closest time neighbors leftMin = this.calcMinLeft(oneKf, time); if (leftMin !== Infinity) { + console.log("ran here"); let kf = this._keyframes[i][leftMin] as Doc; leftKf = TimeAndPosition(kf); } rightMin = this.calcMinRight(oneKf, time); if (rightMin !== Infinity) { + console.log("right here"); let kf = this._keyframes[i][rightMin] as Doc; rightKf = TimeAndPosition(kf); } } else { singleFrame = singleKf; + if (true || oneKf[i] !== undefined) { + console.log("hey"); + this._keys.map(key => { + let temp = OD[key]; + FieldValue(OD[key]); + }); + } } } }); - if (singleFrame) { - if (true || oneKf[i] !== undefined) { - this._keys.map(key => { - let temp = OD[key]; - FieldValue(OD[key]); - }); + if (!singleFrame) { + if (leftKf && rightKf) { + this.interpolate(OD, leftKf, rightKf, this._currentBarX); + } else if (leftKf){ + this._keys.map(async key => { + let pos = (await leftKf.position)!; + if (pos === undefined){ ///something is probably wrong here + return; + } + OD[key] = pos[key]; + }); + } else if (rightKf){ + this._keys.map(async key => { + let pos = (await rightKf.position)!; + if (pos === undefined){ //something is probably wrong here + return; + } + OD[key] = pos[key]; + }); } } - if (leftKf && rightKf) { - this.interpolate(OD, leftKf, rightKf, this._currentBarX); - } else if (leftKf){ - - this.interpolate(OD, leftKf, leftKf, this._currentBarX); - } else if (rightKf){ - this.interpolate(OD, rightKf, rightKf, this._currentBarX); - } }); } @@ -444,13 +455,14 @@ export class Timeline extends CollectionSubView(Document) { return views; } + @observable private _test: (string) = "undefined"; render() { return (
-
+
{SelectionManager.SelectedDocuments().map(dv => this.displayKeyFrames(dv.props.Document))} {this._bars.map((data) => { return this.createBar(5, data.x, "yellow"); -- cgit v1.2.3-70-g09d2