diff options
Diffstat (limited to 'src/client/views/nodes/Timeline.tsx')
-rw-r--r-- | src/client/views/nodes/Timeline.tsx | 131 |
1 files changed, 38 insertions, 93 deletions
diff --git a/src/client/views/nodes/Timeline.tsx b/src/client/views/nodes/Timeline.tsx index 037caacbd..006e24721 100644 --- a/src/client/views/nodes/Timeline.tsx +++ b/src/client/views/nodes/Timeline.tsx @@ -75,47 +75,45 @@ export class Timeline extends CollectionSubView(Document) { return this._keys.map(key => FieldValue(node[key])); }, async data => { if (this._inner.current) { - if (this._data.indexOf(node) === -1) { - const kf = new List(); - this._data.push(node); - let index = this._data.indexOf(node); + if (!this._barMoved){ + console.log("running"); + if (this._data.indexOf(node) === -1) { + + const kf = new List(); + this._data.push(node); + let index = this._data.indexOf(node); - let timeandpos = this.setTimeAndPos(node); - - let info: Doc[] = new Array(1000); //////////////////////////////////////////////////// do something - info[this._currentBarX] = timeandpos; - - this._keyframes[index] = info; + let timeandpos = this.setTimeAndPos(node); - //graphcial yellow bar - let bar: HTMLDivElement = this.createBar(5, this._currentBarX, "yellow"); - this._inner.current.appendChild(bar); + let info: Doc[] = new Array(1000); //////////////////////////////////////////////////// do something + info[this._currentBarX] = timeandpos; - this._keys.forEach((key, index) => { + this._keyframes[index] = info; - }); - } else { - let index = this._data.indexOf(node); - if (this._keyframes[index][this._currentBarX] !== undefined) { //when node is in data, but doesn't have data for this specific time. - let timeandpos = this.setTimeAndPos(node); + //graphcial yellow bar let bar: HTMLDivElement = this.createBar(5, this._currentBarX, "yellow"); this._inner.current.appendChild(bar); + this._keys.forEach((key, index) => { - this._keyframes[index][this._currentBarX] = timeandpos; - } else { //when node is in data, and has data for this specific time - let timeandpos = this.setTimeAndPos(node); - this._keyframes[index][this._currentBarX] = timeandpos; + }); + } else { + let index = this._data.indexOf(node); + if (this._keyframes[index][this._currentBarX] !== undefined) { //when node is in data, but doesn't have data for this specific time. + let timeandpos = this.setTimeAndPos(node); + let bar: HTMLDivElement = this.createBar(5, this._currentBarX, "yellow"); + this._inner.current.appendChild(bar); + this._keyframes[index][this._currentBarX] = timeandpos; + } else { //when node is in data, and has data for this specific time + let timeandpos = this.setTimeAndPos(node); + this._keyframes[index][this._currentBarX] = timeandpos; + } } } + } - // console.log(this._keyframes[this._data.indexOf(node)]); - }); }; - - - observe(childrenList as IObservableArray<Doc>, change => { if (change.type === "update") { this._reactionDisposers[change.index](); @@ -171,53 +169,13 @@ export class Timeline extends CollectionSubView(Document) { if (leftKf && rightKf) { this.interpolate(oneDoc, leftKf, rightKf, this._currentBarX); } - }); - - - - // for (let i in docs) { - // let oneDoc = docs[i]; - // //let oneKf: TimeAndPosition[] = list[i].map(TimeAndPosition); - // let oneKf = this._keyframes[i] - // let leftKf!: TimeAndPosition; - // let rightKf!: TimeAndPosition; - // for (let j in oneKf) { - // let singleKf: TimeAndPosition = oneKf[j]; - // let leftMin: Number = Infinity; - // let rightMin: Number = Infinity; - // if (singleKf.time !== time) { //choose closest time neighbors - // for (let k in oneKf) { - // if (oneKf[k].time < time) { - // const diff: Number = Math.abs(oneKf[k].time - time); - // if (diff < leftMin) { - // leftMin = diff; - // leftKf = oneKf[k]; - // } - // } else { - // const diff: Number = Math.abs(oneKf[k].time - time); - // if (diff < rightMin) { - // rightMin = diff; - // rightKf = oneKf[k]; - // } - // } - // } - // } else { - // isFrame = true; - // } - // } - // this.interpolate(oneDoc, leftKf, rightKf, time); - // if (isFrame) { - // oneDoc.X = oneKf[i].X; - // oneDoc.Y = oneKf[i].Y; - // } - // isFrame = false; - // } + }); } - calcMinLeft = (kfList: Doc[], time: Number): Number => { - let leftMin: Number = Infinity; + calcMinLeft = (kfList: Doc[], time: number): number => { + let leftMin: number = Infinity; kfList.forEach((kf) => { - const diff: Number = Math.abs(kf.time! - time); + const diff:number = Math.abs(NumCast(kf.time) - time); if (diff < leftMin) { leftMin = diff; } @@ -225,10 +183,10 @@ export class Timeline extends CollectionSubView(Document) { return leftMin; } - calcMinRight = (kfList: Doc[]): Number => { - let rightMin: Number = Infinity; + calcMinRight = (kfList: Doc[], time:number): number => { + let rightMin: number = Infinity; kfList.forEach((kf) => { - const diff: Number = Math.abs(kf.time! - time); + const diff: number = Math.abs(NumCast(kf.time!) - time); if (diff < rightMin) { rightMin = diff; } @@ -258,22 +216,11 @@ export class Timeline extends CollectionSubView(Document) { } - /** - * TEMPORARY - */ - @action - onInterpolate = (e: React.MouseEvent) => { - this.timeChange(this._currentBarX); - } - - @action - displayKeyFrames = (dv: DocumentView) => { - dv.props.Document; - } - + private _barMoved:boolean = false; @action onInnerPointerUp = (e: React.PointerEvent) => { if (this._inner.current) { + this._barMoved = false; this._inner.current.removeEventListener("pointermove", this.onInnerPointerMove); } } @@ -284,6 +231,7 @@ export class Timeline extends CollectionSubView(Document) { e.stopPropagation(); if (this._isRecording) { if (this._inner.current) { + this._barMoved = true; let mouse = e.nativeEvent; let offsetX = Math.round(mouse.offsetX); this._currentBarX = offsetX; @@ -299,6 +247,7 @@ export class Timeline extends CollectionSubView(Document) { onInnerPointerMove = (e: PointerEvent) => { e.preventDefault(); e.stopPropagation(); + this._barMoved = true; let offsetX = Math.round(e.offsetX); this._currentBarX = offsetX; this._currentBar.style.transform = `translate(${offsetX}px)`; //styling should not have to be done this way...maybe done through react?? @@ -348,11 +297,7 @@ export class Timeline extends CollectionSubView(Document) { <div className="timeline-container"> <div className="timeline"> <div className="inner" ref={this._inner} onPointerDown={this.onInnerPointerDown} onPointerUp={this.onInnerPointerUp}> - { - SelectionManager.SelectedDocuments().map((dv) => { - this.displayKeyFrames(dv); - }) - } + </div> </div> <button onClick={this.onRecord}>Record</button> |