speechrecorderng 2.21.7 → 2.21.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -95,38 +95,50 @@ export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
95
95
  for (let ci = 0; ci < this.canvasLayers.length; ci++) {
96
96
  let cl = this.canvasLayers[ci];
97
97
  const leftStyle = bounds.position.left + 'px';
98
+ if (cl.style.left != leftStyle) {
99
+ cl.style.left = leftStyle;
100
+ }
98
101
  const topStyle = bounds.position.top + 'px';
99
- cl.style.left = leftStyle;
100
- cl.style.top = topStyle;
102
+ if (cl.style.top != topStyle) {
103
+ cl.style.top = topStyle;
104
+ }
101
105
  }
102
106
  if (bounds.dimension.width) {
103
- let intW = Math.round(bounds.dimension.width);
107
+ let intW = Math.floor(bounds.dimension.width);
104
108
  if (redraw) {
105
109
  // Do not set width of background canvas (causes flicker on start render)
106
110
  for (let ci = 1; ci < this.canvasLayers.length; ci++) {
107
111
  let cl = this.canvasLayers[ci];
108
- cl.width = intW;
112
+ if (cl.width != intW) {
113
+ cl.width = intW;
114
+ }
109
115
  }
110
116
  }
111
117
  let wStr = intW.toString() + 'px';
112
118
  for (let ci = 0; ci < this.canvasLayers.length; ci++) {
113
119
  let cl = this.canvasLayers[ci];
114
- cl.style.width = wStr;
120
+ if (cl.style.width != wStr) {
121
+ cl.style.width = wStr;
122
+ }
115
123
  }
116
124
  }
117
125
  if (bounds.dimension.height) {
118
- let intH = Math.round(bounds.dimension.height);
126
+ let intH = Math.floor(bounds.dimension.height);
119
127
  if (redraw) {
120
128
  // Do not set height of background canvas (causes flicker on start render)
121
129
  for (let ci = 1; ci < this.canvasLayers.length; ci++) {
122
130
  let cl = this.canvasLayers[ci];
123
- cl.height = intH;
131
+ if (cl.height != intH) {
132
+ cl.height = intH;
133
+ }
124
134
  }
125
135
  }
126
136
  let hStr = intH + 'px';
127
137
  for (let ci = 0; ci < this.canvasLayers.length; ci++) {
128
138
  let cl = this.canvasLayers[ci];
129
- cl.style.height = hStr;
139
+ if (cl.style.height != hStr) {
140
+ cl.style.height = hStr;
141
+ }
130
142
  }
131
143
  }
132
144
  //});
@@ -361,4 +373,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
361
373
  }], selectedEventEmitter: [{
362
374
  type: Output
363
375
  }] } });
364
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audio_canvas_layer_comp.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/ui/audio_canvas_layer_comp.ts"],"names":[],"mappings":"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","sourcesContent":["import {CanvasLayerComponent} from \"../../ui/canvas_layer_comp\";\r\nimport {Selection} from '../persistor'\r\nimport { ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, Directive } from \"@angular/core\";\r\nimport {Marker} from \"./common\";\r\nimport {Dimension, Rectangle} from \"../../math/2d/geometry\";\r\n\r\n\r\nexport class ViewSelection{\r\n  get startX(): number {\r\n    return this._startX;\r\n  }\r\n\r\n  get endX(): number {\r\n    return this._endX;\r\n  }\r\n\r\n  width():number{\r\n    return this._endX-this._startX\r\n  }\r\n\r\n  constructor(private _startX:number, private _endX:number){}\r\n}\r\n\r\n@Directive()\r\nexport abstract class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {\r\n  protected _audioData: AudioBuffer|null=null;\r\n  protected _bgColor:string|null='white';\r\n  protected _selectColor='rgba(0%,0%,100%,25%)';\r\n\r\n  /**\r\n   * Returns pixel position depending on current zoom setting.\r\n   * @param framePos audio frame (sample) position\r\n   */\r\n  frameToXPixelPosition(framePos: number): number | null {\r\n      let pixelPos=null;\r\n      if (this._audioData && this._audioData.numberOfChannels > 0) {\r\n          let ch0 = this._audioData.getChannelData(0);\r\n          let frameLength = ch0.length;\r\n          let vw;\r\n          if(this.bounds) {\r\n              vw = this.bounds.dimension.width;\r\n          }\r\n          if (this.virtualDimension) {\r\n              vw = this.virtualDimension.width;\r\n          }\r\n          if(vw !== undefined) {\r\n              pixelPos = framePos * vw / frameLength;\r\n          }\r\n      }\r\n    return pixelPos;\r\n}\r\n\r\n  /**\r\n   * Returns pixel position in view port (visible window of scroll pane).\r\n   * @param framePos audio frame (sample) position\r\n   */\r\n  frameToViewPortXPixelPosition(framePos: number): number | null {\r\n    let pixelPos=this.frameToXPixelPosition(framePos);\r\n    if(pixelPos!=null){\r\n      let vPixelPos = this.toXViewPortPixelPosition(pixelPos);\r\n      return vPixelPos;\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n\r\n    viewPortXPixelToFramePosition(xViewPortPixelPos: number): number | null {\r\n        let vpXramePos=null;\r\n        if (this._audioData && this._audioData.numberOfChannels > 0) {\r\n            let ch0 = this._audioData.getChannelData(0);\r\n            let frameLength = ch0.length;\r\n            let vw;\r\n            if (this.bounds) {\r\n                vw= this.bounds.dimension.width;\r\n            }\r\n            if (this.virtualDimension) {\r\n                vw = this.virtualDimension.width;\r\n            }\r\n            if(vw!== undefined) {\r\n                let xVirtualPixelPos = this.toXVirtualPixelPosition(xViewPortPixelPos)\r\n                let framesPerPixel = frameLength / vw;\r\n                let framePos = framesPerPixel * xVirtualPixelPos;\r\n                if (framePos < 0) {\r\n                    framePos = 0\r\n                }\r\n                if (framePos >= frameLength) {\r\n                    framePos = frameLength - 1\r\n                }\r\n                vpXramePos = Math.round(framePos);\r\n            }\r\n        }\r\n        return vpXramePos;\r\n    }\r\n\r\n    layoutBounds(bounds:Rectangle, virtualDimension:Dimension,redraw: boolean) {\r\n\r\n        this.bounds=bounds;\r\n        this.virtualDimension=virtualDimension;\r\n        //this.canvasLayers.forEach(cl=>{\r\n        for(let ci=0;ci<this.canvasLayers.length;ci++) {\r\n            let cl = this.canvasLayers[ci];\r\n            const leftStyle=bounds.position.left+ 'px';\r\n            const topStyle=bounds.position.top + 'px';\r\n            cl.style.left = leftStyle;\r\n            cl.style.top = topStyle;\r\n        }\r\n        if (bounds.dimension.width) {\r\n            let intW=Math.round(bounds.dimension.width);\r\n            if (redraw) {\r\n                // Do not set width of background canvas (causes flicker on start render)\r\n                for(let ci=1;ci<this.canvasLayers.length;ci++) {\r\n                    let cl = this.canvasLayers[ci];\r\n                    cl.width = intW;\r\n                }\r\n            }\r\n            let wStr = intW.toString() + 'px';\r\n            for(let ci=0;ci<this.canvasLayers.length;ci++) {\r\n                let cl = this.canvasLayers[ci];\r\n                cl.style.width = wStr;\r\n            }\r\n        }\r\n        if (bounds.dimension.height) {\r\n            let intH=Math.round(bounds.dimension.height)\r\n            if (redraw) {\r\n                // Do not set height of background canvas (causes flicker on start render)\r\n                for(let ci=1;ci<this.canvasLayers.length;ci++) {\r\n                    let cl = this.canvasLayers[ci];\r\n                    cl.height = intH;\r\n                }\r\n            }\r\n            let hStr = intH + 'px';\r\n            for(let ci=0;ci<this.canvasLayers.length;ci++) {\r\n                let cl = this.canvasLayers[ci];\r\n                cl.style.height = hStr;\r\n            }\r\n        }\r\n        //});\r\n\r\n\r\n    }\r\n}\r\n\r\n@Directive()\r\nexport abstract class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {\r\n    _pointerPosition:Marker|null=null;\r\n\r\n    protected selectStartX:number|null=null;\r\n\r\n    @ViewChild('bg', { static: true }) bgCanvasRef!: ElementRef;\r\n    bgCanvas!: HTMLCanvasElement;\r\n\r\n    @ViewChild('cursor', { static: true }) cursorCanvasRef!: ElementRef;\r\n    cursorCanvas!: HTMLCanvasElement;\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  onMouseup(me: MouseEvent) {\r\n    this.selectionCommit(me)\r\n  }\r\n\r\n    layoutBounds(bounds:Rectangle, virtualDimension:Dimension,redraw: boolean,clear:boolean=true) {\r\n        super.layoutBounds(bounds,virtualDimension,redraw)\r\n        if (redraw) {\r\n            this.startDraw(clear);\r\n        }\r\n    }\r\n\r\n    @Input() set pointerPosition(pointerPosition:Marker|null){\r\n        this._pointerPosition=pointerPosition\r\n        this.drawCursorLayer()\r\n    }\r\n\r\n    _selecting: Selection|null =null;\r\n    @Input() set selecting(selecting:Selection| null){\r\n        this._selecting=selecting\r\n        this.drawBg()\r\n        this.drawCursorLayer()\r\n    }\r\n\r\n    get selecting():Selection|null{\r\n        return this._selecting\r\n    }\r\n\r\n    _selection: Selection|null =null\r\n    @Input() set selection(selection:Selection|null){\r\n        this._selection=selection;\r\n        this.selecting=null;\r\n        this.drawBg()\r\n        this.drawCursorLayer()\r\n    }\r\n\r\n    get selection():Selection|null{\r\n        return this._selection\r\n    }\r\n\r\n    selectionStart(me:MouseEvent){\r\n        this.selectStartX=me.offsetX;\r\n    }\r\n\r\n    selectionCommit(me:MouseEvent){\r\n        let vs:ViewSelection|null=null;\r\n        if(this.selectStartX!=null) {\r\n          vs=new ViewSelection(this.selectStartX,me.offsetX)\r\n          this.selectStartX=null;\r\n          this.select(vs);\r\n        }\r\n    }\r\n\r\n    abstract startDraw(clear:boolean):void;\r\n\r\n    updateCursorCanvas(me:MouseEvent,showCursorPosition=true){\r\n\r\n        if (this.cursorCanvas) {\r\n\r\n            let w = this.cursorCanvas.width;\r\n            let h = this.cursorCanvas.height;\r\n            let g = this.cursorCanvas.getContext(\"2d\");\r\n\r\n            // if (!showCursorPosition) {\r\n            //     this.selectStartX = null\r\n            //     this.selectingChange(null)\r\n            // }\r\n            if (me) {\r\n                if (this.selectStartX) {\r\n                    this.pointerPositionChanged(null)\r\n                    this.selectingChange(new ViewSelection(this.selectStartX, me.offsetX));\r\n                } else {\r\n                    if (showCursorPosition) {\r\n                        this.pointerPositionChanged(me.offsetX)\r\n                    }else{\r\n                        this.pointerPositionChanged(null)\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    @Output() pointerPositionEventEmitter = new EventEmitter<Marker>();\r\n    @Output() selectingEventEmitter = new EventEmitter<Selection>();\r\n    @Output() selectedEventEmitter = new EventEmitter<Selection>();\r\n\r\n\r\n    pointerPositionChanged(xPosition:number| null){\r\n        let pointerPosition:Marker|undefined=undefined;\r\n        if(xPosition){\r\n            pointerPosition=new Marker();\r\n            let vpXPos=this.viewPortXPixelToFramePosition(xPosition);\r\n            if(vpXPos!=null) {\r\n                pointerPosition.framePosition =vpXPos;\r\n            }\r\n        }\r\n        this.pointerPositionEventEmitter.emit(pointerPosition);\r\n    }\r\n\r\n    selectingChange(viewSel:ViewSelection| null){\r\n        let ns:Selection|undefined=undefined;\r\n        if(viewSel) {\r\n            let frameStart = this.viewPortXPixelToFramePosition(viewSel.startX)\r\n            let frameEnd = this.viewPortXPixelToFramePosition(viewSel.endX)\r\n            if(this._audioData && frameStart!=null && frameEnd!=null) {\r\n                ns = new Selection(this._audioData.sampleRate, frameStart, frameEnd);\r\n            }\r\n        }\r\n        this.selectingEventEmitter.emit(ns)\r\n    }\r\n\r\n    select(viewSel:ViewSelection| null){\r\n        let ns:Selection|undefined=undefined;\r\n        if(viewSel) {\r\n          let frameStart = this.viewPortXPixelToFramePosition(viewSel.startX)\r\n          let frameEnd = this.viewPortXPixelToFramePosition(viewSel.endX)\r\n            if(this._audioData && frameStart!=null && frameEnd!=null) {\r\n                ns = new Selection(this._audioData.sampleRate, frameStart, frameEnd);\r\n            }\r\n        }\r\n        this.selectedEventEmitter.emit(ns)\r\n    }\r\n\r\n    viewSelection():ViewSelection|null{\r\n      let vs:ViewSelection|null=null;\r\n      let s:Selection|null=null;\r\n      if(this._selecting){\r\n        s=this._selecting\r\n      }else if(this._selection){\r\n        s=this._selection\r\n      }\r\n      if(s){\r\n        let sf=s.startFrame;\r\n        let ef=s.endFrame;\r\n        let xs=this.frameToViewPortXPixelPosition(sf)\r\n        let xe=this.frameToViewPortXPixelPosition(ef)\r\n          if(xs!=null && xe!=null) {\r\n              vs = new ViewSelection(xs, xe)\r\n          }\r\n      }\r\n      return vs;\r\n    }\r\n\r\n\r\n  drawBg(){\r\n      if(this.bgCanvas && this.bounds) {\r\n          this.bgCanvas.style.left = Math.round(this.bounds.position.left).toString() + 'px';\r\n          this.bgCanvas.width = Math.round(this.bounds.dimension.width);\r\n          this.bgCanvas.height = Math.round(this.bounds.dimension.height);\r\n        let g1 = this.bgCanvas.getContext(\"2d\");\r\n        if (g1) {\r\n          let w = this.bgCanvas.width;\r\n          let h = this.bgCanvas.height;\r\n          g1.clearRect(0, 0, w, h);\r\n          if(this._bgColor) {\r\n            g1.fillStyle = this._bgColor;\r\n            g1.fillRect(0, 0, w, h);\r\n          }\r\n          let vs = this.viewSelection()\r\n          if (vs) {\r\n            g1.fillStyle = this._selectColor;\r\n            g1.fillRect(vs.startX, 0, vs.width(), h);\r\n          }\r\n        }\r\n      }\r\n  }\r\n    drawCursorLayer(){\r\n        if (this.cursorCanvas) {\r\n            let w = this.cursorCanvas.width;\r\n            let h = this.cursorCanvas.height;\r\n            let g = this.cursorCanvas.getContext(\"2d\");\r\n            if(g) {\r\n                g.clearRect(0, 0, w, h);\r\n                // let s:Selection=null;\r\n                // if(this._selecting){\r\n                //     s=this._selecting\r\n                // }else if(this._selection){\r\n                //     s=this._selection\r\n                // }\r\n                // if(s){\r\n                //     let sf=s.startFrame\r\n                //     let ef=s.endFrame\r\n                //     let xs=this.frameToViewPortXPixelPosition(sf)\r\n                //     let xe=this.frameToViewPortXPixelPosition(ef)\r\n                //     let sw=xe-xs\r\n                //     g.fillStyle = 'rgba(0%,0%,100%,25%)';\r\n                //     g.fillRect(xs,0,sw,h);\r\n                // }\r\n\r\n                if(this._pointerPosition){\r\n\r\n                    let framePos=this._pointerPosition.framePosition\r\n                    if(framePos) {\r\n                        let xViewPortPixelpos = this.frameToViewPortXPixelPosition(framePos)\r\n                        if (xViewPortPixelpos) {\r\n\r\n                            g.fillStyle = 'yellow';\r\n                            g.strokeStyle = 'yellow';\r\n                            g.beginPath();\r\n                            g.moveTo(xViewPortPixelpos, 0);\r\n                            g.lineTo(xViewPortPixelpos, h);\r\n                            g.closePath();\r\n\r\n                            g.stroke();\r\n\r\n                            if (this._audioData) {\r\n                                g.font = '14px sans-serif';\r\n                                g.fillStyle = 'yellow';\r\n                                g.fillText(framePos.toString(), xViewPortPixelpos + 2, 50);\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n}\r\n\r\n\r\n\r\n"]}
376
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audio_canvas_layer_comp.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/ui/audio_canvas_layer_comp.ts"],"names":[],"mappings":"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","sourcesContent":["import {CanvasLayerComponent} from \"../../ui/canvas_layer_comp\";\r\nimport {Selection} from '../persistor'\r\nimport { ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, Directive } from \"@angular/core\";\r\nimport {Marker} from \"./common\";\r\nimport {Dimension, Rectangle} from \"../../math/2d/geometry\";\r\n\r\n\r\nexport class ViewSelection{\r\n  get startX(): number {\r\n    return this._startX;\r\n  }\r\n\r\n  get endX(): number {\r\n    return this._endX;\r\n  }\r\n\r\n  width():number{\r\n    return this._endX-this._startX\r\n  }\r\n\r\n  constructor(private _startX:number, private _endX:number){}\r\n}\r\n\r\n@Directive()\r\nexport abstract class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {\r\n  protected _audioData: AudioBuffer|null=null;\r\n  protected _bgColor:string|null='white';\r\n  protected _selectColor='rgba(0%,0%,100%,25%)';\r\n\r\n  /**\r\n   * Returns pixel position depending on current zoom setting.\r\n   * @param framePos audio frame (sample) position\r\n   */\r\n  frameToXPixelPosition(framePos: number): number | null {\r\n      let pixelPos=null;\r\n      if (this._audioData && this._audioData.numberOfChannels > 0) {\r\n          let ch0 = this._audioData.getChannelData(0);\r\n          let frameLength = ch0.length;\r\n          let vw;\r\n          if(this.bounds) {\r\n              vw = this.bounds.dimension.width;\r\n          }\r\n          if (this.virtualDimension) {\r\n              vw = this.virtualDimension.width;\r\n          }\r\n          if(vw !== undefined) {\r\n              pixelPos = framePos * vw / frameLength;\r\n          }\r\n      }\r\n    return pixelPos;\r\n}\r\n\r\n  /**\r\n   * Returns pixel position in view port (visible window of scroll pane).\r\n   * @param framePos audio frame (sample) position\r\n   */\r\n  frameToViewPortXPixelPosition(framePos: number): number | null {\r\n    let pixelPos=this.frameToXPixelPosition(framePos);\r\n    if(pixelPos!=null){\r\n      let vPixelPos = this.toXViewPortPixelPosition(pixelPos);\r\n      return vPixelPos;\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n\r\n    viewPortXPixelToFramePosition(xViewPortPixelPos: number): number | null {\r\n        let vpXramePos=null;\r\n        if (this._audioData && this._audioData.numberOfChannels > 0) {\r\n            let ch0 = this._audioData.getChannelData(0);\r\n            let frameLength = ch0.length;\r\n            let vw;\r\n            if (this.bounds) {\r\n                vw= this.bounds.dimension.width;\r\n            }\r\n            if (this.virtualDimension) {\r\n                vw = this.virtualDimension.width;\r\n            }\r\n            if(vw!== undefined) {\r\n                let xVirtualPixelPos = this.toXVirtualPixelPosition(xViewPortPixelPos)\r\n                let framesPerPixel = frameLength / vw;\r\n                let framePos = framesPerPixel * xVirtualPixelPos;\r\n                if (framePos < 0) {\r\n                    framePos = 0\r\n                }\r\n                if (framePos >= frameLength) {\r\n                    framePos = frameLength - 1\r\n                }\r\n                vpXramePos = Math.round(framePos);\r\n            }\r\n        }\r\n        return vpXramePos;\r\n    }\r\n\r\n    layoutBounds(bounds:Rectangle, virtualDimension:Dimension,redraw: boolean) {\r\n\r\n        this.bounds=bounds;\r\n        this.virtualDimension=virtualDimension;\r\n        //this.canvasLayers.forEach(cl=>{\r\n        for(let ci=0;ci<this.canvasLayers.length;ci++) {\r\n            let cl = this.canvasLayers[ci];\r\n            const leftStyle=bounds.position.left+ 'px';\r\n            if(cl.style.left!=leftStyle) {\r\n              cl.style.left = leftStyle;\r\n            }\r\n            const topStyle=bounds.position.top + 'px';\r\n            if(cl.style.top!=topStyle) {\r\n              cl.style.top = topStyle;\r\n            }\r\n        }\r\n        if (bounds.dimension.width) {\r\n            let intW=Math.floor(bounds.dimension.width);\r\n            if (redraw) {\r\n                // Do not set width of background canvas (causes flicker on start render)\r\n                for(let ci=1;ci<this.canvasLayers.length;ci++) {\r\n                    let cl = this.canvasLayers[ci];\r\n                    if(cl.width!=intW) {\r\n                      cl.width = intW;\r\n                    }\r\n                }\r\n            }\r\n            let wStr = intW.toString() + 'px';\r\n            for(let ci=0;ci<this.canvasLayers.length;ci++) {\r\n                let cl = this.canvasLayers[ci];\r\n                if(cl.style.width!=wStr) {\r\n                  cl.style.width = wStr;\r\n                }\r\n            }\r\n        }\r\n        if (bounds.dimension.height) {\r\n            let intH=Math.floor(bounds.dimension.height)\r\n            if (redraw) {\r\n                // Do not set height of background canvas (causes flicker on start render)\r\n                for(let ci=1;ci<this.canvasLayers.length;ci++) {\r\n                    let cl = this.canvasLayers[ci];\r\n                    if(cl.height!=intH) {\r\n                      cl.height = intH;\r\n                    }\r\n                }\r\n            }\r\n            let hStr = intH + 'px';\r\n            for(let ci=0;ci<this.canvasLayers.length;ci++) {\r\n                let cl = this.canvasLayers[ci];\r\n                if(cl.style.height!=hStr){\r\n                  cl.style.height = hStr;\r\n                }\r\n            }\r\n        }\r\n        //});\r\n\r\n\r\n    }\r\n}\r\n\r\n@Directive()\r\nexport abstract class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {\r\n    _pointerPosition:Marker|null=null;\r\n\r\n    protected selectStartX:number|null=null;\r\n\r\n    @ViewChild('bg', { static: true }) bgCanvasRef!: ElementRef;\r\n    bgCanvas!: HTMLCanvasElement;\r\n\r\n    @ViewChild('cursor', { static: true }) cursorCanvasRef!: ElementRef;\r\n    cursorCanvas!: HTMLCanvasElement;\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  onMouseup(me: MouseEvent) {\r\n    this.selectionCommit(me)\r\n  }\r\n\r\n    layoutBounds(bounds:Rectangle, virtualDimension:Dimension,redraw: boolean,clear:boolean=true) {\r\n        super.layoutBounds(bounds,virtualDimension,redraw)\r\n        if (redraw) {\r\n            this.startDraw(clear);\r\n        }\r\n    }\r\n\r\n    @Input() set pointerPosition(pointerPosition:Marker|null){\r\n        this._pointerPosition=pointerPosition\r\n        this.drawCursorLayer()\r\n    }\r\n\r\n    _selecting: Selection|null =null;\r\n    @Input() set selecting(selecting:Selection| null){\r\n        this._selecting=selecting\r\n        this.drawBg()\r\n        this.drawCursorLayer()\r\n    }\r\n\r\n    get selecting():Selection|null{\r\n        return this._selecting\r\n    }\r\n\r\n    _selection: Selection|null =null\r\n    @Input() set selection(selection:Selection|null){\r\n        this._selection=selection;\r\n        this.selecting=null;\r\n        this.drawBg()\r\n        this.drawCursorLayer()\r\n    }\r\n\r\n    get selection():Selection|null{\r\n        return this._selection\r\n    }\r\n\r\n    selectionStart(me:MouseEvent){\r\n        this.selectStartX=me.offsetX;\r\n    }\r\n\r\n    selectionCommit(me:MouseEvent){\r\n        let vs:ViewSelection|null=null;\r\n        if(this.selectStartX!=null) {\r\n          vs=new ViewSelection(this.selectStartX,me.offsetX)\r\n          this.selectStartX=null;\r\n          this.select(vs);\r\n        }\r\n    }\r\n\r\n    abstract startDraw(clear:boolean):void;\r\n\r\n    updateCursorCanvas(me:MouseEvent,showCursorPosition=true){\r\n\r\n        if (this.cursorCanvas) {\r\n\r\n            let w = this.cursorCanvas.width;\r\n            let h = this.cursorCanvas.height;\r\n            let g = this.cursorCanvas.getContext(\"2d\");\r\n\r\n            // if (!showCursorPosition) {\r\n            //     this.selectStartX = null\r\n            //     this.selectingChange(null)\r\n            // }\r\n            if (me) {\r\n                if (this.selectStartX) {\r\n                    this.pointerPositionChanged(null)\r\n                    this.selectingChange(new ViewSelection(this.selectStartX, me.offsetX));\r\n                } else {\r\n                    if (showCursorPosition) {\r\n                        this.pointerPositionChanged(me.offsetX)\r\n                    }else{\r\n                        this.pointerPositionChanged(null)\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    @Output() pointerPositionEventEmitter = new EventEmitter<Marker>();\r\n    @Output() selectingEventEmitter = new EventEmitter<Selection>();\r\n    @Output() selectedEventEmitter = new EventEmitter<Selection>();\r\n\r\n\r\n    pointerPositionChanged(xPosition:number| null){\r\n        let pointerPosition:Marker|undefined=undefined;\r\n        if(xPosition){\r\n            pointerPosition=new Marker();\r\n            let vpXPos=this.viewPortXPixelToFramePosition(xPosition);\r\n            if(vpXPos!=null) {\r\n                pointerPosition.framePosition =vpXPos;\r\n            }\r\n        }\r\n        this.pointerPositionEventEmitter.emit(pointerPosition);\r\n    }\r\n\r\n    selectingChange(viewSel:ViewSelection| null){\r\n        let ns:Selection|undefined=undefined;\r\n        if(viewSel) {\r\n            let frameStart = this.viewPortXPixelToFramePosition(viewSel.startX)\r\n            let frameEnd = this.viewPortXPixelToFramePosition(viewSel.endX)\r\n            if(this._audioData && frameStart!=null && frameEnd!=null) {\r\n                ns = new Selection(this._audioData.sampleRate, frameStart, frameEnd);\r\n            }\r\n        }\r\n        this.selectingEventEmitter.emit(ns)\r\n    }\r\n\r\n    select(viewSel:ViewSelection| null){\r\n        let ns:Selection|undefined=undefined;\r\n        if(viewSel) {\r\n          let frameStart = this.viewPortXPixelToFramePosition(viewSel.startX)\r\n          let frameEnd = this.viewPortXPixelToFramePosition(viewSel.endX)\r\n            if(this._audioData && frameStart!=null && frameEnd!=null) {\r\n                ns = new Selection(this._audioData.sampleRate, frameStart, frameEnd);\r\n            }\r\n        }\r\n        this.selectedEventEmitter.emit(ns)\r\n    }\r\n\r\n    viewSelection():ViewSelection|null{\r\n      let vs:ViewSelection|null=null;\r\n      let s:Selection|null=null;\r\n      if(this._selecting){\r\n        s=this._selecting\r\n      }else if(this._selection){\r\n        s=this._selection\r\n      }\r\n      if(s){\r\n        let sf=s.startFrame;\r\n        let ef=s.endFrame;\r\n        let xs=this.frameToViewPortXPixelPosition(sf)\r\n        let xe=this.frameToViewPortXPixelPosition(ef)\r\n          if(xs!=null && xe!=null) {\r\n              vs = new ViewSelection(xs, xe)\r\n          }\r\n      }\r\n      return vs;\r\n    }\r\n\r\n\r\n  drawBg(){\r\n      if(this.bgCanvas && this.bounds) {\r\n          this.bgCanvas.style.left = Math.round(this.bounds.position.left).toString() + 'px';\r\n          this.bgCanvas.width = Math.round(this.bounds.dimension.width);\r\n          this.bgCanvas.height = Math.round(this.bounds.dimension.height);\r\n        let g1 = this.bgCanvas.getContext(\"2d\");\r\n        if (g1) {\r\n          let w = this.bgCanvas.width;\r\n          let h = this.bgCanvas.height;\r\n          g1.clearRect(0, 0, w, h);\r\n          if(this._bgColor) {\r\n            g1.fillStyle = this._bgColor;\r\n            g1.fillRect(0, 0, w, h);\r\n          }\r\n          let vs = this.viewSelection()\r\n          if (vs) {\r\n            g1.fillStyle = this._selectColor;\r\n            g1.fillRect(vs.startX, 0, vs.width(), h);\r\n          }\r\n        }\r\n      }\r\n  }\r\n    drawCursorLayer(){\r\n        if (this.cursorCanvas) {\r\n            let w = this.cursorCanvas.width;\r\n            let h = this.cursorCanvas.height;\r\n            let g = this.cursorCanvas.getContext(\"2d\");\r\n            if(g) {\r\n                g.clearRect(0, 0, w, h);\r\n                // let s:Selection=null;\r\n                // if(this._selecting){\r\n                //     s=this._selecting\r\n                // }else if(this._selection){\r\n                //     s=this._selection\r\n                // }\r\n                // if(s){\r\n                //     let sf=s.startFrame\r\n                //     let ef=s.endFrame\r\n                //     let xs=this.frameToViewPortXPixelPosition(sf)\r\n                //     let xe=this.frameToViewPortXPixelPosition(ef)\r\n                //     let sw=xe-xs\r\n                //     g.fillStyle = 'rgba(0%,0%,100%,25%)';\r\n                //     g.fillRect(xs,0,sw,h);\r\n                // }\r\n\r\n                if(this._pointerPosition){\r\n\r\n                    let framePos=this._pointerPosition.framePosition\r\n                    if(framePos) {\r\n                        let xViewPortPixelpos = this.frameToViewPortXPixelPosition(framePos)\r\n                        if (xViewPortPixelpos) {\r\n\r\n                            g.fillStyle = 'yellow';\r\n                            g.strokeStyle = 'yellow';\r\n                            g.beginPath();\r\n                            g.moveTo(xViewPortPixelpos, 0);\r\n                            g.lineTo(xViewPortPixelpos, h);\r\n                            g.closePath();\r\n\r\n                            g.stroke();\r\n\r\n                            if (this._audioData) {\r\n                                g.font = '14px sans-serif';\r\n                                g.fillStyle = 'yellow';\r\n                                g.fillText(framePos.toString(), xViewPortPixelpos + 2, 50);\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n}\r\n\r\n\r\n\r\n"]}
@@ -233,17 +233,32 @@ export class AudioClipUIContainer extends BasicAudioCanvasLayerComponent {
233
233
  }
234
234
  // Divider
235
235
  // left position
236
- this.dc.style.left = vbLeft + 'px';
236
+ let vbLeftStyl = vbLeft + 'px';
237
+ if (this.dc.style.left != vbLeftStyl) {
238
+ this.dc.style.left = vbLeftStyl;
239
+ }
237
240
  // top position
238
241
  const dTop = asH;
239
242
  const dTopStr = dTop + 'px';
240
- this.dc.style.top = dTopStr;
243
+ if (this.dc.style.top != dTopStr) {
244
+ this.dc.style.top = dTopStr;
245
+ }
241
246
  // width
242
- this.dc.style.width = vbWidth + 'px';
243
- this.dc.width = vbWidth;
247
+ let vbWidthStyle = vbWidth + 'px';
248
+ if (this.dc.style.width != vbWidthStyle) {
249
+ this.dc.style.width = vbWidthStyle;
250
+ }
251
+ if (this.dc.width != vbWidth) {
252
+ this.dc.width = vbWidth;
253
+ }
244
254
  // height
245
- this.dc.height = AudioClipUIContainer.DIVIDER_PIXEL_SIZE;
246
- this.dc.style.height = AudioClipUIContainer.DIVIDER_PIXEL_SIZE.toString() + 'px';
255
+ if (this.dc.height != AudioClipUIContainer.DIVIDER_PIXEL_SIZE) {
256
+ this.dc.height = AudioClipUIContainer.DIVIDER_PIXEL_SIZE;
257
+ }
258
+ let divPixelSizeStyle = AudioClipUIContainer.DIVIDER_PIXEL_SIZE.toString() + 'px';
259
+ if (this.dc.style.height != divPixelSizeStyle) {
260
+ this.dc.style.height = divPixelSizeStyle;
261
+ }
247
262
  this.drawDivider();
248
263
  // Virtual dimension, only width is used
249
264
  let virtualDim = new Dimension(ceBcrIntW, 0);
@@ -269,7 +284,10 @@ export class AudioClipUIContainer extends BasicAudioCanvasLayerComponent {
269
284
  if (this._audioData) {
270
285
  if (this._fixFitToPanel) {
271
286
  // Set the virtual canvas width to the visible width
272
- this.ce.style.width = '100%';
287
+ if (this.ce.style.width != '100%') {
288
+ //console.log("set width to 100%");
289
+ this.ce.style.width = '100%';
290
+ }
273
291
  }
274
292
  else {
275
293
  if (this._xZoom) {
@@ -334,7 +352,7 @@ AudioClipUIContainer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
334
352
  <audio-signal [pointerPosition]="pointer" [selecting]="selecting" [selection]="selection" (pointerPositionEventEmitter)="pointerPositionChanged($event)" (selectingEventEmitter)="selectingChanged($event)" (selectedEventEmitter)="selectionChanged($event)"></audio-signal>
335
353
  <audio-sonagram [pointerPosition]="pointer" [selecting]="selecting" [selection]="selection" (pointerPositionEventEmitter)="pointerPositionChanged($event)" (selectingEventEmitter)="selectingChanged($event)" (selectedEventEmitter)="selectionChanged($event)"></audio-sonagram>
336
354
  </div>
337
- `, isInline: true, styles: ["div{margin:0;padding:0;top:0;left:0;width:100%;height:100%;position:relative;box-sizing:border-box;transform:none}\n", "canvas{top:0;left:0;width:0;height:0;cursor:ns-resize;position:absolute;zIndex:1;transform:none}\n", "audio-signal{top:0;left:0;position:absolute;zIndex:1;transform:none}\n", "audio-sonagram{top:0;left:0;position:absolute;zIndex:1;transform:none}\n"], components: [{ type: i1.AudioSignal, selector: "audio-signal" }, { type: i2.Sonagram, selector: "audio-sonagram" }] });
355
+ `, isInline: true, styles: ["div{margin:0;padding:0;top:0;left:0;width:100%;height:100%;position:relative;box-sizing:border-box;transform:none;overflow:hidden}\n", "canvas{top:0;left:0;width:0;height:0;cursor:ns-resize;position:absolute;zIndex:1;transform:none}\n", "audio-signal{top:0;left:0;position:absolute;zIndex:1;transform:none}\n", "audio-sonagram{top:0;left:0;position:absolute;zIndex:1;transform:none}\n"], components: [{ type: i1.AudioSignal, selector: "audio-signal" }, { type: i2.Sonagram, selector: "audio-sonagram" }] });
338
356
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: AudioClipUIContainer, decorators: [{
339
357
  type: Component,
340
358
  args: [{
@@ -358,6 +376,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
358
376
  position: relative; /* TODO container div position must not be 'static' (default) to act as reference for the canvases */
359
377
  box-sizing: border-box;
360
378
  transform: none;
379
+ overflow: hidden;
361
380
  }`, `canvas{
362
381
  top: 0;
363
382
  left: 0;
@@ -409,4 +428,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
409
428
  }], audioClip: [{
410
429
  type: Input
411
430
  }] } });
412
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/ui/container.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ElementRef, AfterViewInit, HostListener, Input, OnInit, Output, EventEmitter\r\n} from '@angular/core'\r\nimport {AudioSignal} from './audiosignal'\r\nimport {Sonagram} from './sonagram'\r\nimport {Marker, Point} from './common'\r\n\r\nimport {Component, ViewChild} from '@angular/core';\r\nimport {Position,Dimension, Rectangle} from \"../../math/2d/geometry\";\r\nimport {AudioClip,Selection} from \"../persistor\";\r\nimport {BasicAudioCanvasLayerComponent} from \"./audio_canvas_layer_comp\";\r\nimport {Element} from \"@angular/compiler\";\r\n\r\n/*\r\n  ResizeObserver not yet available in official Typescript declaration\r\n  Crreated declaration from IDL until its available.\r\n  See specs:\r\n  https://www.w3.org/TR/resize-observer\r\n\r\n */\r\n\r\ninterface ResizeObserverSize {\r\n  readonly inlineSize:number;\r\n  readonly blockSize:number;\r\n};\r\n\r\ndeclare interface ResizeObserverEntry{\r\n  readonly target: Element;\r\n  readonly contentRect: DOMRectReadOnly ;\r\n  readonly borderBoxSize: Array<ResizeObserverSize> ;\r\n  readonly contentBoxSize: Array<ResizeObserverSize> ;\r\n  readonly devicePixelContentBoxSize: Array<ResizeObserverSize> ;\r\n}\r\n\r\ndeclare interface ResizeObserverCallback {\r\n  (entries: Array<ResizeObserverEntry>, observer: ResizeObserver):void;\r\n}\r\n\r\ndeclare enum ResizeObserverBoxOptions {\r\n  \"border-box\", \"content-box\", \"device-pixel-content-box\"\r\n};\r\n\r\n// // Declare Resizeobserver\r\n// declare class ResizeObserver{\r\n//   constructor(callback: ResizeObserverCallback);\r\n//   observe: (el:Element,opts: ResizeObserverBoxOptions | null)=>void;\r\n//   unobserve: (el:Element)=>void;\r\n//   disconnect: ()=>void;\r\n// }\r\n\r\n/*\r\n * Container component for audio display.\r\n * The display elements are children of a virtual canvas. The virtual canvas makes it possible to have high zoom factors with very wide virtual audio displays.\r\n * Only the visible part of the virtual canvas is implemented as a browser canvas and therefore consuming memory.\r\n * The visible part has the same width as the viewport of the scroll pane parent.\r\n * The virtual canvas itself is implemented as a HTML div element.\r\n * The layout of the component is updated on resize of the parent or changes of the zoom factor.\r\n */\r\n@Component({\r\n\r\n  selector: 'app-audio',\r\n  template: `\r\n    <div #virtualCanvas>\r\n    <canvas #divider (mousedown)=\"mousedown($event)\" (mouseover)=\"mouseover($event)\"\r\n            (mouseleave)=\"mouseleave($event)\" height=\"10\"></canvas>\r\n    <audio-signal [pointerPosition]=\"pointer\" [selecting]=\"selecting\" [selection]=\"selection\" (pointerPositionEventEmitter)=\"pointerPositionChanged($event)\" (selectingEventEmitter)=\"selectingChanged($event)\" (selectedEventEmitter)=\"selectionChanged($event)\"></audio-signal>\r\n    <audio-sonagram [pointerPosition]=\"pointer\" [selecting]=\"selecting\" [selection]=\"selection\" (pointerPositionEventEmitter)=\"pointerPositionChanged($event)\" (selectingEventEmitter)=\"selectingChanged($event)\" (selectedEventEmitter)=\"selectionChanged($event)\"></audio-sonagram>\r\n    </div>\r\n  `,\r\n  styles: [`div {\r\n\r\n    margin: 0;\r\n    padding: 0;\r\n    top: 0;\r\n    left: 0;\r\n    width: 100%;\r\n    height: 100%;\r\n    position: relative; /* TODO container div position must not be 'static' (default) to act as reference for the canvases */\r\n    box-sizing: border-box;\r\n    transform: none;\r\n  }`, `canvas{\r\n    top: 0;\r\n    left: 0;\r\n    width: 0;\r\n    height: 0;\r\n    cursor: ns-resize;\r\n    position: absolute;\r\n    zIndex: 1;\r\n    transform: none;\r\n  }`, `audio-signal {\r\n    top: 0;\r\n    left: 0;\r\n    position: absolute;\r\n    zIndex: 1;\r\n    transform: none;\r\n  }`, `audio-sonagram {\r\n    top: 0;\r\n    left: 0;\r\n    position: absolute;\r\n    zIndex: 1;\r\n    transform: none;\r\n  }`]\r\n\r\n})\r\nexport class AudioClipUIContainer extends BasicAudioCanvasLayerComponent implements OnInit,AfterViewInit{\r\n\r\n  private static DIVIDER_PIXEL_SIZE = 10;\r\n\r\n  parentE: HTMLElement;\r\n\r\n  // Divider canvas\r\n  @ViewChild('divider', { static: true }) canvasRef!: ElementRef;\r\n  dc!: HTMLCanvasElement;\r\n\r\n  // Virtual container\r\n  @ViewChild('virtualCanvas', { static: true }) ceRef!: ElementRef;\r\n  ce!: HTMLDivElement;\r\n\r\n  @ViewChild(AudioSignal, { static: true }) as!: AudioSignal;\r\n  @ViewChild(Sonagram, { static: true }) so!: Sonagram;\r\n\r\n  private _audioClip:AudioClip | null=null;\r\n  pointer: Marker|null=null;\r\n  selecting: Selection|null=null;\r\n  selection: Selection|null=null;\r\n  @Output() selectionEventEmitter = new EventEmitter<Selection>();\r\n  private _playFramePosition: number|null=null;\r\n  private dragStartMouseY: number | null = null;\r\n  private dragStartY: number | null = null;\r\n  private dividerPosition = 0.5;\r\n\r\n  userAction=false;\r\n\r\n  private _xZoom: number | null = null; // pixels per second\r\n\r\n  get xZoom(): number | null {\r\n    return this._xZoom;\r\n  }\r\n\r\n  set xZoom(value: number | null) {\r\n    this.userAction=true;\r\n    this._xZoom = value;\r\n    this.layout()\r\n    this.userAction=false;\r\n  }\r\n\r\n  // if true the complete audio file is shown, the display fits to the visible panel, the x-zoom factor is variable, this is the default\r\n  private _fixFitToPanel = true;\r\n\r\n  set fixFitToPanel(value: boolean) {\r\n    this._fixFitToPanel = value;\r\n    if (value) {\r\n      // we don't need  clip bounds\r\n      this.bounds=null;\r\n      this._xZoom = null;\r\n    } else {\r\n      // hold current zoom value\r\n      //this._xZoom=this.ce.offsetWidth/this._audioData.duration;\r\n    }\r\n    this.layout()\r\n  }\r\n\r\n  constructor(private ref: ElementRef) {\r\n    super()\r\n    this.parentE = this.ref.nativeElement;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.ce = this.ceRef.nativeElement;\r\n    this.dc = this.canvasRef.nativeElement;\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.layout();\r\n    let heightListener = new MutationObserver((mrs: Array<MutationRecord>, mo: MutationObserver) => {\r\n\r\n      let layout=false;\r\n      mrs.forEach((mr: MutationRecord) => {\r\n        if (!this.userAction && 'attributes' === mr.type && ('class' === mr.attributeName || 'style' === mr.attributeName)) {\r\n          layout=true;\r\n        }\r\n      });\r\n      if(layout){\r\n        // re-layout required\r\n        this.layout(false);\r\n      }\r\n    });\r\n\r\n    heightListener.observe(this.ce, {attributes: true, childList: true, characterData: true});\r\n    heightListener.observe(this.dc, {attributes: true, childList: true, characterData: true});\r\n\r\n    let resizeObserver = new ResizeObserver((entries,obs) => {\r\n      //console.log(\"Resize observed:\");\r\n      entries.forEach((e)=>{\r\n        //console.log(e.contentRect.width+\"x\"+e.contentRect.height);\r\n        this.layout();\r\n      })\r\n    });\r\n\r\n    resizeObserver.observe(this.ce);\r\n\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize(event: Event): void {\r\n    this.layout();\r\n  }\r\n\r\n  mouseover(me: MouseEvent) {\r\n    this.dividerCursorPosition(me, true);\r\n  }\r\n\r\n  mouseleave(me: MouseEvent) {\r\n    this.dividerCursorPosition(me, false);\r\n  }\r\n\r\n  mousedown(me: MouseEvent) {\r\n    this.dragStartMouseY = me.clientY;\r\n    this.dragStartY = this.dc.offsetTop;\r\n    this.dragStartMouseY = me.clientY;\r\n  }\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  onMouseup(me: MouseEvent) {\r\n    if (this.dragStartY != null) {\r\n      this.userAction=true;\r\n      this.dividerDrag(me);\r\n      this.layout(false);\r\n      this.dragStartY = null;\r\n      this.userAction=false;\r\n    }\r\n  }\r\n\r\n  @HostListener('document:mousemove', ['$event'])\r\n  onMousemove(me: MouseEvent) {\r\n    if (this.dragStartY != null) {\r\n      this.userAction=true;\r\n      this.dividerDrag(me);\r\n      this.layoutScaled();\r\n      this.userAction=true;\r\n    }\r\n  }\r\n\r\n  pointerPositionChanged(pp:Marker){\r\n    this.pointer=pp\r\n  }\r\n\r\n  selectingChanged(s:Selection| null){\r\n    this.selecting=s\r\n  }\r\n\r\n  selectionChanged(s:Selection){\r\n    this.selection=s\r\n    if(this._audioClip){\r\n      this._audioClip.selection=s\r\n    }\r\n    this.selectionEventEmitter.emit(this.selection)\r\n  }\r\n\r\n  private canvasMousePos(c: HTMLCanvasElement, e: MouseEvent): Point {\r\n    const cr = c.getBoundingClientRect();\r\n    const x = e.x - cr.left;\r\n    const y = e.y - cr.top;\r\n    return new Point(x,y);\r\n  }\r\n\r\n  dividerCursorPosition(e: MouseEvent, show: boolean) {\r\n    if (this.dc) {\r\n\r\n      const w = this.dc.width;\r\n      const h = this.dc.height;\r\n      const g = this.dc.getContext('2d');\r\n\r\n      const pp = this.canvasMousePos(this.dc, e);\r\n      const offX = e.offsetX - this.dc.offsetLeft;\r\n      const offY = e.offsetY - this.dc.offsetTop;\r\n\r\n    }\r\n  }\r\n\r\n  dividerDrag(e: MouseEvent) {\r\n    if (this.dc && this.dragStartMouseY && this.dragStartY) {\r\n\r\n      const dragOffset = e.clientY - this.dragStartMouseY;\r\n      const ceHeight = this.ce.offsetHeight;\r\n\r\n      let newTop = (this.dragStartY + dragOffset);\r\n      if (newTop < 0) {\r\n        newTop = 0;\r\n      }\r\n      if (newTop > ceHeight - AudioClipUIContainer.DIVIDER_PIXEL_SIZE) {\r\n        newTop = ceHeight - AudioClipUIContainer.DIVIDER_PIXEL_SIZE;\r\n      }\r\n      this.dc.style.top = newTop.toString() + 'px';\r\n      this.dividerPosition = (this.dc.offsetTop + AudioClipUIContainer.DIVIDER_PIXEL_SIZE / 2) / ceHeight;\r\n      if (this.dividerPosition > 1.0) {\r\n        this.dividerPosition = 1.0;\r\n      }\r\n      if (this.dividerPosition < 0.0) {\r\n        this.dividerPosition = 0.0;\r\n      }\r\n      this.drawDivider();\r\n    }\r\n  }\r\n\r\n\r\n  drawDivider() {\r\n    const w = this.dc.width;\r\n    const h = this.dc.height;\r\n    const g = this.dc.getContext('2d');\r\n    if (g && w>10 && h>=1) {\r\n      g.fillStyle = 'white';\r\n      g.fillRect(0, 0, w, h);\r\n      g.fillStyle = 'black';\r\n      g.fillRect(5, 5, w - 10, 1);\r\n    }\r\n  }\r\n\r\n  clipBounds(clipBounds: Rectangle) {\r\n    this.bounds = clipBounds;\r\n    this.layout();\r\n  }\r\n\r\n  currentXZoom(): number | null {\r\n    let xz = this._xZoom;\r\n    if (xz==null && this._audioData) {\r\n      let ow = this.ce.offsetWidth;\r\n      if (ow < 1) {\r\n        // at least one pixel width to avoid x-zoom zero values\r\n        ow = 1;\r\n      }\r\n      xz = ow / this._audioData.duration;\r\n    }\r\n    return xz;\r\n  }\r\n\r\n  private _layout(clear: boolean, redraw: boolean) {\r\n    let ceBcr = this.ce.getBoundingClientRect();\r\n\r\n    const ceBcrIntW = Math.floor(ceBcr.width);\r\n    const ceBcrIntH = Math.floor(ceBcr.height);\r\n\r\n    // height available for plugins (audiosignal and sonagram)\r\n    let psH = ceBcrIntH - AudioClipUIContainer.DIVIDER_PIXEL_SIZE;\r\n    if (psH < 0) {\r\n      psH = 0;\r\n    }\r\n    // audio signal height\r\n    const asH = Math.round(psH * this.dividerPosition);\r\n\r\n    // sonagram height (rest: available height minus divider height minus audiosignal height)\r\n    let soH = ceBcrIntH - AudioClipUIContainer.DIVIDER_PIXEL_SIZE - asH;\r\n    if (soH < 0) {\r\n      soH = 0;\r\n    }\r\n\r\n  // sonagram top position\r\n    const soTop = asH + AudioClipUIContainer.DIVIDER_PIXEL_SIZE;\r\n\r\n    // Visible bounds\r\n    // left position\r\n    let vbLeft = 0;\r\n    // width\r\n    let vbWidth = ceBcrIntW;\r\n    if (!this._fixFitToPanel && this.bounds) {\r\n      vbLeft = Math.round(this.bounds.position.left);\r\n      vbWidth = Math.round(this.bounds.dimension.width);\r\n    }\r\n\r\n    // Divider\r\n    // left position\r\n    this.dc.style.left = vbLeft + 'px';\r\n    // top position\r\n    const dTop = asH;\r\n    const dTopStr = dTop + 'px';\r\n    this.dc.style.top = dTopStr;\r\n    // width\r\n    this.dc.style.width = vbWidth + 'px';\r\n    this.dc.width = vbWidth;\r\n    // height\r\n    this.dc.height = AudioClipUIContainer.DIVIDER_PIXEL_SIZE;\r\n    this.dc.style.height = AudioClipUIContainer.DIVIDER_PIXEL_SIZE.toString() + 'px';\r\n\r\n    this.drawDivider();\r\n\r\n\r\n    // Virtual dimension, only width is used\r\n    let virtualDim = new Dimension(ceBcrIntW, 0)\r\n\r\n    // Visible bounds of container\r\n    let br = new Rectangle(new Position(vbLeft, 0), new Dimension(vbWidth, ceBcrIntH));\r\n\r\n    // Set container bounds\r\n    this.layoutBounds(br, virtualDim, false);\r\n\r\n    // Visible bounds of audiosignal\r\n    let asR = new Rectangle(new Position(vbLeft, 0), new Dimension(vbWidth, asH));\r\n\r\n    // Set audiosignal bounds\r\n    this.as.layoutBounds(asR, virtualDim, redraw, clear);\r\n\r\n    // Visible bounds of sonagram\r\n    let soR = new Rectangle(new Position(vbLeft, soTop), new Dimension(vbWidth, soH));\r\n\r\n    // Set sonagram bounds\r\n    this.so.layoutBounds(soR, virtualDim, redraw, clear);\r\n  }\r\n\r\n  layoutScaled() {\r\n    this._layout(false, false);\r\n  }\r\n\r\n  layout(clear=true) {\r\n\r\n    if(this.ce && this.dc) {\r\n      const clientW=this.ce.clientWidth;\r\n      if(this._audioData){\r\n        if(this._fixFitToPanel) {\r\n          // Set the virtual canvas width to the visible width\r\n          this.ce.style.width = '100%';\r\n        }else{\r\n          if (this._xZoom) {\r\n            // Set the virtual canvas width according to the value of the user selected xZoom value\r\n            const newClW = Math.round( this._xZoom*this._audioData.duration );\r\n            this.ce.style.width = newClW + 'px';\r\n          } else {\r\n            // Set the virtual canvas width to the visible width only\r\n            this.ce.style.width = clientW + 'px';\r\n          }\r\n        }\r\n      }\r\n      this._layout(clear,true);\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  set audioData(audioData: AudioBuffer | null) {\r\n    this._audioClip=null\r\n    this._audioData=audioData;\r\n    this.as.setData(audioData);\r\n    this.so.setData(audioData);\r\n    this.layout();\r\n  }\r\n\r\n  get audioData():AudioBuffer|null{\r\n    return this._audioData\r\n  }\r\n\r\n  @Input()\r\n  set audioClip(audioClip: AudioClip | null) {\r\n    this._audioClip=audioClip\r\n      let audioData:AudioBuffer|null=null;\r\n    let sel:Selection|null=null;\r\n      if(audioClip) {\r\n        audioData = audioClip.buffer;\r\n        if (this._audioClip) {\r\n          this._audioClip.addSelectionObserver((clip) => {\r\n            this.selection = clip.selection\r\n          });\r\n        }\r\n        sel=audioClip.selection;\r\n      }\r\n      this._audioData = audioData;\r\n      this.as.setData(this._audioData);\r\n      this.so.setData(this._audioData);\r\n      this.selecting=null\r\n      this.selection=sel\r\n    this.layout();\r\n  }\r\n\r\n  get playFramePosition(): number |null {\r\n    return this._playFramePosition;\r\n  }\r\n\r\n  set playFramePosition(playFramePosition: number|null) {\r\n    this._playFramePosition = playFramePosition;\r\n    this.as.playFramePosition = playFramePosition;\r\n    this.so.playFramePosition = playFramePosition;\r\n  }\r\n}\r\n\r\n"]}
431
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/ui/container.ts"],"names":[],"mappings":"AAAA,OAAO,EACsB,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,YAAY,EAC7E,MAAM,eAAe,CAAA;AACtB,OAAO,EAAC,WAAW,EAAC,MAAM,eAAe,CAAA;AACzC,OAAO,EAAC,QAAQ,EAAC,MAAM,YAAY,CAAA;AACnC,OAAO,EAAS,KAAK,EAAC,MAAM,UAAU,CAAA;AAEtC,OAAO,EAAC,SAAS,EAAE,SAAS,EAAC,MAAM,eAAe,CAAC;AACnD,OAAO,EAAC,QAAQ,EAAC,SAAS,EAAE,SAAS,EAAC,MAAM,wBAAwB,CAAC;AAErE,OAAO,EAAC,8BAA8B,EAAC,MAAM,2BAA2B,CAAC;;;;AAcxE,CAAC;AAgBD,CAAC;AAEF,4BAA4B;AAC5B,gCAAgC;AAChC,mDAAmD;AACnD,uEAAuE;AACvE,mCAAmC;AACnC,0BAA0B;AAC1B,IAAI;AAEJ;;;;;;;GAOG;AAgDH,MAAM,OAAO,oBAAqB,SAAQ,8BAA8B;IA0DtE,YAAoB,GAAe;QACjC,KAAK,EAAE,CAAA;QADW,QAAG,GAAH,GAAG,CAAY;QAzC3B,eAAU,GAAkB,IAAI,CAAC;QACzC,YAAO,GAAc,IAAI,CAAC;QAC1B,cAAS,GAAiB,IAAI,CAAC;QAC/B,cAAS,GAAiB,IAAI,CAAC;QACrB,0BAAqB,GAAG,IAAI,YAAY,EAAa,CAAC;QACxD,uBAAkB,GAAc,IAAI,CAAC;QACrC,oBAAe,GAAkB,IAAI,CAAC;QACtC,eAAU,GAAkB,IAAI,CAAC;QACjC,oBAAe,GAAG,GAAG,CAAC;QAE9B,eAAU,GAAC,KAAK,CAAC;QAET,WAAM,GAAkB,IAAI,CAAC,CAAC,oBAAoB;QAa1D,sIAAsI;QAC9H,mBAAc,GAAG,IAAI,CAAC;QAiB5B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC;IACxC,CAAC;IA9BD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAI,KAAK,CAAC,KAAoB;QAC5B,IAAI,CAAC,UAAU,GAAC,IAAI,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,MAAM,EAAE,CAAA;QACb,IAAI,CAAC,UAAU,GAAC,KAAK,CAAC;IACxB,CAAC;IAKD,IAAI,aAAa,CAAC,KAAc;QAC9B,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,KAAK,EAAE;YACT,6BAA6B;YAC7B,IAAI,CAAC,MAAM,GAAC,IAAI,CAAC;YACjB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACpB;aAAM;YACL,0BAA0B;YAC1B,2DAA2D;SAC5D;QACD,IAAI,CAAC,MAAM,EAAE,CAAA;IACf,CAAC;IAOD,QAAQ;QACN,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC;QACnC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;IACzC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,IAAI,cAAc,GAAG,IAAI,gBAAgB,CAAC,CAAC,GAA0B,EAAE,EAAoB,EAAE,EAAE;YAE7F,IAAI,MAAM,GAAC,KAAK,CAAC;YACjB,GAAG,CAAC,OAAO,CAAC,CAAC,EAAkB,EAAE,EAAE;gBACjC,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,YAAY,KAAK,EAAE,CAAC,IAAI,IAAI,CAAC,OAAO,KAAK,EAAE,CAAC,aAAa,IAAI,OAAO,KAAK,EAAE,CAAC,aAAa,CAAC,EAAE;oBAClH,MAAM,GAAC,IAAI,CAAC;iBACb;YACH,CAAC,CAAC,CAAC;YACH,IAAG,MAAM,EAAC;gBACR,qBAAqB;gBACrB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;aACpB;QACH,CAAC,CAAC,CAAC;QAEH,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAC,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAC,CAAC,CAAC;QAC1F,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAC,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAC,CAAC,CAAC;QAE1F,IAAI,cAAc,GAAG,IAAI,cAAc,CAAC,CAAC,OAAO,EAAC,GAAG,EAAE,EAAE;YACtD,kCAAkC;YAClC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAC,EAAE;gBACnB,4DAA4D;gBAC5D,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAC;QAEH,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAElC,CAAC;IAGD,QAAQ,CAAC,KAAY;QACnB,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,SAAS,CAAC,EAAc;QACtB,IAAI,CAAC,qBAAqB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,UAAU,CAAC,EAAc;QACvB,IAAI,CAAC,qBAAqB,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,SAAS,CAAC,EAAc;QACtB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC,OAAO,CAAC;QAClC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC;QACpC,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC,OAAO,CAAC;IACpC,CAAC;IAGD,SAAS,CAAC,EAAc;QACtB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,EAAE;YAC3B,IAAI,CAAC,UAAU,GAAC,IAAI,CAAC;YACrB,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;YACrB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACnB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,UAAU,GAAC,KAAK,CAAC;SACvB;IACH,CAAC;IAGD,WAAW,CAAC,EAAc;QACxB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,EAAE;YAC3B,IAAI,CAAC,UAAU,GAAC,IAAI,CAAC;YACrB,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;YACrB,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,GAAC,IAAI,CAAC;SACtB;IACH,CAAC;IAED,sBAAsB,CAAC,EAAS;QAC9B,IAAI,CAAC,OAAO,GAAC,EAAE,CAAA;IACjB,CAAC;IAED,gBAAgB,CAAC,CAAiB;QAChC,IAAI,CAAC,SAAS,GAAC,CAAC,CAAA;IAClB,CAAC;IAED,gBAAgB,CAAC,CAAW;QAC1B,IAAI,CAAC,SAAS,GAAC,CAAC,CAAA;QAChB,IAAG,IAAI,CAAC,UAAU,EAAC;YACjB,IAAI,CAAC,UAAU,CAAC,SAAS,GAAC,CAAC,CAAA;SAC5B;QACD,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IACjD,CAAC;IAEO,cAAc,CAAC,CAAoB,EAAE,CAAa;QACxD,MAAM,EAAE,GAAG,CAAC,CAAC,qBAAqB,EAAE,CAAC;QACrC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;QACxB,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC;QACvB,OAAO,IAAI,KAAK,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC;IACxB,CAAC;IAED,qBAAqB,CAAC,CAAa,EAAE,IAAa;QAChD,IAAI,IAAI,CAAC,EAAE,EAAE;YAEX,MAAM,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YACxB,MAAM,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC;YACzB,MAAM,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEnC,MAAM,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;YAC3C,MAAM,IAAI,GAAG,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC;YAC5C,MAAM,IAAI,GAAG,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC;SAE5C;IACH,CAAC;IAED,WAAW,CAAC,CAAa;QACvB,IAAI,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,UAAU,EAAE;YAEtD,MAAM,UAAU,GAAG,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC;YACpD,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC;YAEtC,IAAI,MAAM,GAAG,CAAC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,CAAC;YAC5C,IAAI,MAAM,GAAG,CAAC,EAAE;gBACd,MAAM,GAAG,CAAC,CAAC;aACZ;YACD,IAAI,MAAM,GAAG,QAAQ,GAAG,oBAAoB,CAAC,kBAAkB,EAAE;gBAC/D,MAAM,GAAG,QAAQ,GAAG,oBAAoB,CAAC,kBAAkB,CAAC;aAC7D;YACD,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,GAAG,MAAM,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC;YAC7C,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,GAAG,oBAAoB,CAAC,kBAAkB,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC;YACpG,IAAI,IAAI,CAAC,eAAe,GAAG,GAAG,EAAE;gBAC9B,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC;aAC5B;YACD,IAAI,IAAI,CAAC,eAAe,GAAG,GAAG,EAAE;gBAC9B,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC;aAC5B;YACD,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;IACH,CAAC;IAGD,WAAW;QACT,MAAM,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;QACxB,MAAM,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC;QACzB,MAAM,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACnC,IAAI,CAAC,IAAI,CAAC,GAAC,EAAE,IAAI,CAAC,IAAE,CAAC,EAAE;YACrB,CAAC,CAAC,SAAS,GAAG,OAAO,CAAC;YACtB,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YACvB,CAAC,CAAC,SAAS,GAAG,OAAO,CAAC;YACtB,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC;SAC7B;IACH,CAAC;IAED,UAAU,CAAC,UAAqB;QAC9B,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC;QACzB,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,YAAY;QACV,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;QACrB,IAAI,EAAE,IAAE,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE;YAC/B,IAAI,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC;YAC7B,IAAI,EAAE,GAAG,CAAC,EAAE;gBACV,uDAAuD;gBACvD,EAAE,GAAG,CAAC,CAAC;aACR;YACD,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;SACpC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAEO,OAAO,CAAC,KAAc,EAAE,MAAe;QAC7C,IAAI,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,qBAAqB,EAAE,CAAC;QAE5C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC1C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAE3C,0DAA0D;QAC1D,IAAI,GAAG,GAAG,SAAS,GAAG,oBAAoB,CAAC,kBAAkB,CAAC;QAC9D,IAAI,GAAG,GAAG,CAAC,EAAE;YACX,GAAG,GAAG,CAAC,CAAC;SACT;QACD,sBAAsB;QACtB,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC;QAEnD,yFAAyF;QACzF,IAAI,GAAG,GAAG,SAAS,GAAG,oBAAoB,CAAC,kBAAkB,GAAG,GAAG,CAAC;QACpE,IAAI,GAAG,GAAG,CAAC,EAAE;YACX,GAAG,GAAG,CAAC,CAAC;SACT;QAEH,wBAAwB;QACtB,MAAM,KAAK,GAAG,GAAG,GAAG,oBAAoB,CAAC,kBAAkB,CAAC;QAE5D,iBAAiB;QACjB,gBAAgB;QAChB,IAAI,MAAM,GAAG,CAAC,CAAC;QACf,QAAQ;QACR,IAAI,OAAO,GAAG,SAAS,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,MAAM,EAAE;YACvC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC/C,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SACnD;QAED,UAAU;QACV,gBAAgB;QAChB,IAAI,UAAU,GAAG,MAAM,GAAG,IAAI,CAAC;QAC/B,IAAI,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,IAAI,UAAU,EAAE;YACpC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,GAAG,UAAU,CAAC;SACjC;QACD,eAAe;QACf,MAAM,IAAI,GAAG,GAAG,CAAC;QACjB,MAAM,OAAO,GAAG,IAAI,GAAG,IAAI,CAAC;QAC5B,IAAI,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,IAAI,OAAO,EAAE;YAChC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,GAAG,OAAO,CAAC;SAC7B;QACD,QAAQ;QACR,IAAI,YAAY,GAAG,OAAO,GAAG,IAAI,CAAC;QAClC,IAAI,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,IAAI,YAAY,EAAE;YACvC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,GAAG,YAAY,CAAC;SACpC;QACD,IAAI,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,OAAO,EAAE;YAC5B,IAAI,CAAC,EAAE,CAAC,KAAK,GAAG,OAAO,CAAC;SACzB;QACD,SAAS;QACT,IAAG,IAAI,CAAC,EAAE,CAAC,MAAM,IAAE,oBAAoB,CAAC,kBAAkB,EAAE;YAC1D,IAAI,CAAC,EAAE,CAAC,MAAM,GAAG,oBAAoB,CAAC,kBAAkB,CAAC;SAE1D;QACD,IAAI,iBAAiB,GAAC,oBAAoB,CAAC,kBAAkB,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC;QAChF,IAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,IAAE,iBAAiB,EAAE;YAC1C,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC;SAC1C;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;QAGnB,wCAAwC;QACxC,IAAI,UAAU,GAAG,IAAI,SAAS,CAAC,SAAS,EAAE,CAAC,CAAC,CAAA;QAE5C,8BAA8B;QAC9B,IAAI,EAAE,GAAG,IAAI,SAAS,CAAC,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,IAAI,SAAS,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC;QAEnF,uBAAuB;QACvB,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;QAEzC,gCAAgC;QAChC,IAAI,GAAG,GAAG,IAAI,SAAS,CAAC,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,IAAI,SAAS,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC;QAE9E,yBAAyB;QACzB,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;QAErD,6BAA6B;QAC7B,IAAI,GAAG,GAAG,IAAI,SAAS,CAAC,IAAI,QAAQ,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,IAAI,SAAS,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC;QAElF,sBAAsB;QACtB,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;IACvD,CAAC;IAED,YAAY;QACV,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,MAAM,CAAC,KAAK,GAAC,IAAI;QAEf,IAAG,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,EAAE,EAAE;YACrB,MAAM,OAAO,GAAC,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC;YAClC,IAAG,IAAI,CAAC,UAAU,EAAC;gBACjB,IAAG,IAAI,CAAC,cAAc,EAAE;oBACtB,oDAAoD;oBACpD,IAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,IAAE,MAAM,EAAE;wBAC9B,mCAAmC;wBACnC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC;qBAC9B;iBACF;qBAAI;oBACH,IAAI,IAAI,CAAC,MAAM,EAAE;wBACf,uFAAuF;wBACvF,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAE,IAAI,CAAC,MAAM,GAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAE,CAAC;wBAClE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,GAAG,IAAI,CAAC;qBACrC;yBAAM;wBACL,yDAAyD;wBACzD,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,GAAG,OAAO,GAAG,IAAI,CAAC;qBACtC;iBACF;aACF;YACD,IAAI,CAAC,OAAO,CAAC,KAAK,EAAC,IAAI,CAAC,CAAC;SAC1B;IACH,CAAC;IAED,IACI,SAAS,CAAC,SAA6B;QACzC,IAAI,CAAC,UAAU,GAAC,IAAI,CAAA;QACpB,IAAI,CAAC,UAAU,GAAC,SAAS,CAAC;QAC1B,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAC3B,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAC3B,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAA;IACxB,CAAC;IAED,IACI,SAAS,CAAC,SAA2B;QACvC,IAAI,CAAC,UAAU,GAAC,SAAS,CAAA;QACvB,IAAI,SAAS,GAAkB,IAAI,CAAC;QACtC,IAAI,GAAG,GAAgB,IAAI,CAAC;QAC1B,IAAG,SAAS,EAAE;YACZ,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC;YAC7B,IAAI,IAAI,CAAC,UAAU,EAAE;gBACnB,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC,IAAI,EAAE,EAAE;oBAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAA;gBACjC,CAAC,CAAC,CAAC;aACJ;YACD,GAAG,GAAC,SAAS,CAAC,SAAS,CAAC;SACzB;QACD,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjC,IAAI,CAAC,SAAS,GAAC,IAAI,CAAA;QACnB,IAAI,CAAC,SAAS,GAAC,GAAG,CAAA;QACpB,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IAED,IAAI,iBAAiB,CAAC,iBAA8B;QAClD,IAAI,CAAC,kBAAkB,GAAG,iBAAiB,CAAC;QAC5C,IAAI,CAAC,EAAE,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;QAC9C,IAAI,CAAC,EAAE,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;IAChD,CAAC;;AAvYc,uCAAkB,GAAG,EAAG,CAAA;iHAF5B,oBAAoB;qGAApB,oBAAoB,8iBAcpB,WAAW,mFACX,QAAQ,qFA3DT;;;;;;;GAOT;2FAqCU,oBAAoB;kBA/ChC,SAAS;mBAAC;oBAET,QAAQ,EAAE,WAAW;oBACrB,QAAQ,EAAE;;;;;;;GAOT;oBACD,MAAM,EAAE,CAAC;;;;;;;;;;;;IAYP,EAAE;;;;;;;;;IASF,EAAE;;;;;;IAMF,EAAE;;;;;;IAMF,CAAC;iBAEJ;iGAQyC,SAAS;sBAAhD,SAAS;uBAAC,SAAS,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAIQ,KAAK;sBAAlD,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAGF,EAAE;sBAA3C,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACD,EAAE;sBAAxC,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAM3B,qBAAqB;sBAA9B,MAAM;gBA+EP,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC;gBAoBzC,SAAS;sBADR,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC;gBAY5C,WAAW;sBADV,YAAY;uBAAC,oBAAoB,EAAE,CAAC,QAAQ,CAAC;gBA8N1C,SAAS;sBADZ,KAAK;gBAcF,SAAS;sBADZ,KAAK","sourcesContent":["import {\r\n  ElementRef, AfterViewInit, HostListener, Input, OnInit, Output, EventEmitter\r\n} from '@angular/core'\r\nimport {AudioSignal} from './audiosignal'\r\nimport {Sonagram} from './sonagram'\r\nimport {Marker, Point} from './common'\r\n\r\nimport {Component, ViewChild} from '@angular/core';\r\nimport {Position,Dimension, Rectangle} from \"../../math/2d/geometry\";\r\nimport {AudioClip,Selection} from \"../persistor\";\r\nimport {BasicAudioCanvasLayerComponent} from \"./audio_canvas_layer_comp\";\r\nimport {Element} from \"@angular/compiler\";\r\n\r\n/*\r\n  ResizeObserver not yet available in official Typescript declaration\r\n  Crreated declaration from IDL until its available.\r\n  See specs:\r\n  https://www.w3.org/TR/resize-observer\r\n\r\n */\r\n\r\ninterface ResizeObserverSize {\r\n  readonly inlineSize:number;\r\n  readonly blockSize:number;\r\n};\r\n\r\ndeclare interface ResizeObserverEntry{\r\n  readonly target: Element;\r\n  readonly contentRect: DOMRectReadOnly ;\r\n  readonly borderBoxSize: Array<ResizeObserverSize> ;\r\n  readonly contentBoxSize: Array<ResizeObserverSize> ;\r\n  readonly devicePixelContentBoxSize: Array<ResizeObserverSize> ;\r\n}\r\n\r\ndeclare interface ResizeObserverCallback {\r\n  (entries: Array<ResizeObserverEntry>, observer: ResizeObserver):void;\r\n}\r\n\r\ndeclare enum ResizeObserverBoxOptions {\r\n  \"border-box\", \"content-box\", \"device-pixel-content-box\"\r\n};\r\n\r\n// // Declare Resizeobserver\r\n// declare class ResizeObserver{\r\n//   constructor(callback: ResizeObserverCallback);\r\n//   observe: (el:Element,opts: ResizeObserverBoxOptions | null)=>void;\r\n//   unobserve: (el:Element)=>void;\r\n//   disconnect: ()=>void;\r\n// }\r\n\r\n/*\r\n * Container component for audio display.\r\n * The display elements are children of a virtual canvas. The virtual canvas makes it possible to have high zoom factors with very wide virtual audio displays.\r\n * Only the visible part of the virtual canvas is implemented as a browser canvas and therefore consuming memory.\r\n * The visible part has the same width as the viewport of the scroll pane parent.\r\n * The virtual canvas itself is implemented as a HTML div element.\r\n * The layout of the component is updated on resize of the parent or changes of the zoom factor.\r\n */\r\n@Component({\r\n\r\n  selector: 'app-audio',\r\n  template: `\r\n    <div #virtualCanvas>\r\n    <canvas #divider (mousedown)=\"mousedown($event)\" (mouseover)=\"mouseover($event)\"\r\n            (mouseleave)=\"mouseleave($event)\" height=\"10\"></canvas>\r\n    <audio-signal [pointerPosition]=\"pointer\" [selecting]=\"selecting\" [selection]=\"selection\" (pointerPositionEventEmitter)=\"pointerPositionChanged($event)\" (selectingEventEmitter)=\"selectingChanged($event)\" (selectedEventEmitter)=\"selectionChanged($event)\"></audio-signal>\r\n    <audio-sonagram [pointerPosition]=\"pointer\" [selecting]=\"selecting\" [selection]=\"selection\" (pointerPositionEventEmitter)=\"pointerPositionChanged($event)\" (selectingEventEmitter)=\"selectingChanged($event)\" (selectedEventEmitter)=\"selectionChanged($event)\"></audio-sonagram>\r\n    </div>\r\n  `,\r\n  styles: [`div {\r\n\r\n    margin: 0;\r\n    padding: 0;\r\n    top: 0;\r\n    left: 0;\r\n    width: 100%;\r\n    height: 100%;\r\n    position: relative; /* TODO container div position must not be 'static' (default) to act as reference for the canvases */\r\n    box-sizing: border-box;\r\n    transform: none;\r\n    overflow: hidden;\r\n  }`, `canvas{\r\n    top: 0;\r\n    left: 0;\r\n    width: 0;\r\n    height: 0;\r\n    cursor: ns-resize;\r\n    position: absolute;\r\n    zIndex: 1;\r\n    transform: none;\r\n  }`, `audio-signal {\r\n    top: 0;\r\n    left: 0;\r\n    position: absolute;\r\n    zIndex: 1;\r\n    transform: none;\r\n  }`, `audio-sonagram {\r\n    top: 0;\r\n    left: 0;\r\n    position: absolute;\r\n    zIndex: 1;\r\n    transform: none;\r\n  }`]\r\n\r\n})\r\nexport class AudioClipUIContainer extends BasicAudioCanvasLayerComponent implements OnInit,AfterViewInit{\r\n\r\n  private static DIVIDER_PIXEL_SIZE = 10;\r\n\r\n  parentE: HTMLElement;\r\n\r\n  // Divider canvas\r\n  @ViewChild('divider', { static: true }) canvasRef!: ElementRef;\r\n  dc!: HTMLCanvasElement;\r\n\r\n  // Virtual container\r\n  @ViewChild('virtualCanvas', { static: true }) ceRef!: ElementRef;\r\n  ce!: HTMLDivElement;\r\n\r\n  @ViewChild(AudioSignal, { static: true }) as!: AudioSignal;\r\n  @ViewChild(Sonagram, { static: true }) so!: Sonagram;\r\n\r\n  private _audioClip:AudioClip | null=null;\r\n  pointer: Marker|null=null;\r\n  selecting: Selection|null=null;\r\n  selection: Selection|null=null;\r\n  @Output() selectionEventEmitter = new EventEmitter<Selection>();\r\n  private _playFramePosition: number|null=null;\r\n  private dragStartMouseY: number | null = null;\r\n  private dragStartY: number | null = null;\r\n  private dividerPosition = 0.5;\r\n\r\n  userAction=false;\r\n\r\n  private _xZoom: number | null = null; // pixels per second\r\n\r\n  get xZoom(): number | null {\r\n    return this._xZoom;\r\n  }\r\n\r\n  set xZoom(value: number | null) {\r\n    this.userAction=true;\r\n    this._xZoom = value;\r\n    this.layout()\r\n    this.userAction=false;\r\n  }\r\n\r\n  // if true the complete audio file is shown, the display fits to the visible panel, the x-zoom factor is variable, this is the default\r\n  private _fixFitToPanel = true;\r\n\r\n  set fixFitToPanel(value: boolean) {\r\n    this._fixFitToPanel = value;\r\n    if (value) {\r\n      // we don't need  clip bounds\r\n      this.bounds=null;\r\n      this._xZoom = null;\r\n    } else {\r\n      // hold current zoom value\r\n      //this._xZoom=this.ce.offsetWidth/this._audioData.duration;\r\n    }\r\n    this.layout()\r\n  }\r\n\r\n  constructor(private ref: ElementRef) {\r\n    super()\r\n    this.parentE = this.ref.nativeElement;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.ce = this.ceRef.nativeElement;\r\n    this.dc = this.canvasRef.nativeElement;\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.layout();\r\n    let heightListener = new MutationObserver((mrs: Array<MutationRecord>, mo: MutationObserver) => {\r\n\r\n      let layout=false;\r\n      mrs.forEach((mr: MutationRecord) => {\r\n        if (!this.userAction && 'attributes' === mr.type && ('class' === mr.attributeName || 'style' === mr.attributeName)) {\r\n          layout=true;\r\n        }\r\n      });\r\n      if(layout){\r\n        // re-layout required\r\n        this.layout(false);\r\n      }\r\n    });\r\n\r\n    heightListener.observe(this.ce, {attributes: true, childList: true, characterData: true});\r\n    heightListener.observe(this.dc, {attributes: true, childList: true, characterData: true});\r\n\r\n    let resizeObserver = new ResizeObserver((entries,obs) => {\r\n      //console.log(\"Resize observed:\");\r\n      entries.forEach((e)=>{\r\n        //console.log(e.contentRect.width+\"x\"+e.contentRect.height);\r\n        this.layout();\r\n      })\r\n    });\r\n\r\n    resizeObserver.observe(this.ce);\r\n\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize(event: Event): void {\r\n    this.layout();\r\n  }\r\n\r\n  mouseover(me: MouseEvent) {\r\n    this.dividerCursorPosition(me, true);\r\n  }\r\n\r\n  mouseleave(me: MouseEvent) {\r\n    this.dividerCursorPosition(me, false);\r\n  }\r\n\r\n  mousedown(me: MouseEvent) {\r\n    this.dragStartMouseY = me.clientY;\r\n    this.dragStartY = this.dc.offsetTop;\r\n    this.dragStartMouseY = me.clientY;\r\n  }\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  onMouseup(me: MouseEvent) {\r\n    if (this.dragStartY != null) {\r\n      this.userAction=true;\r\n      this.dividerDrag(me);\r\n      this.layout(false);\r\n      this.dragStartY = null;\r\n      this.userAction=false;\r\n    }\r\n  }\r\n\r\n  @HostListener('document:mousemove', ['$event'])\r\n  onMousemove(me: MouseEvent) {\r\n    if (this.dragStartY != null) {\r\n      this.userAction=true;\r\n      this.dividerDrag(me);\r\n      this.layoutScaled();\r\n      this.userAction=true;\r\n    }\r\n  }\r\n\r\n  pointerPositionChanged(pp:Marker){\r\n    this.pointer=pp\r\n  }\r\n\r\n  selectingChanged(s:Selection| null){\r\n    this.selecting=s\r\n  }\r\n\r\n  selectionChanged(s:Selection){\r\n    this.selection=s\r\n    if(this._audioClip){\r\n      this._audioClip.selection=s\r\n    }\r\n    this.selectionEventEmitter.emit(this.selection)\r\n  }\r\n\r\n  private canvasMousePos(c: HTMLCanvasElement, e: MouseEvent): Point {\r\n    const cr = c.getBoundingClientRect();\r\n    const x = e.x - cr.left;\r\n    const y = e.y - cr.top;\r\n    return new Point(x,y);\r\n  }\r\n\r\n  dividerCursorPosition(e: MouseEvent, show: boolean) {\r\n    if (this.dc) {\r\n\r\n      const w = this.dc.width;\r\n      const h = this.dc.height;\r\n      const g = this.dc.getContext('2d');\r\n\r\n      const pp = this.canvasMousePos(this.dc, e);\r\n      const offX = e.offsetX - this.dc.offsetLeft;\r\n      const offY = e.offsetY - this.dc.offsetTop;\r\n\r\n    }\r\n  }\r\n\r\n  dividerDrag(e: MouseEvent) {\r\n    if (this.dc && this.dragStartMouseY && this.dragStartY) {\r\n\r\n      const dragOffset = e.clientY - this.dragStartMouseY;\r\n      const ceHeight = this.ce.offsetHeight;\r\n\r\n      let newTop = (this.dragStartY + dragOffset);\r\n      if (newTop < 0) {\r\n        newTop = 0;\r\n      }\r\n      if (newTop > ceHeight - AudioClipUIContainer.DIVIDER_PIXEL_SIZE) {\r\n        newTop = ceHeight - AudioClipUIContainer.DIVIDER_PIXEL_SIZE;\r\n      }\r\n      this.dc.style.top = newTop.toString() + 'px';\r\n      this.dividerPosition = (this.dc.offsetTop + AudioClipUIContainer.DIVIDER_PIXEL_SIZE / 2) / ceHeight;\r\n      if (this.dividerPosition > 1.0) {\r\n        this.dividerPosition = 1.0;\r\n      }\r\n      if (this.dividerPosition < 0.0) {\r\n        this.dividerPosition = 0.0;\r\n      }\r\n      this.drawDivider();\r\n    }\r\n  }\r\n\r\n\r\n  drawDivider() {\r\n    const w = this.dc.width;\r\n    const h = this.dc.height;\r\n    const g = this.dc.getContext('2d');\r\n    if (g && w>10 && h>=1) {\r\n      g.fillStyle = 'white';\r\n      g.fillRect(0, 0, w, h);\r\n      g.fillStyle = 'black';\r\n      g.fillRect(5, 5, w - 10, 1);\r\n    }\r\n  }\r\n\r\n  clipBounds(clipBounds: Rectangle) {\r\n    this.bounds = clipBounds;\r\n    this.layout();\r\n  }\r\n\r\n  currentXZoom(): number | null {\r\n    let xz = this._xZoom;\r\n    if (xz==null && this._audioData) {\r\n      let ow = this.ce.offsetWidth;\r\n      if (ow < 1) {\r\n        // at least one pixel width to avoid x-zoom zero values\r\n        ow = 1;\r\n      }\r\n      xz = ow / this._audioData.duration;\r\n    }\r\n    return xz;\r\n  }\r\n\r\n  private _layout(clear: boolean, redraw: boolean) {\r\n    let ceBcr = this.ce.getBoundingClientRect();\r\n\r\n    const ceBcrIntW = Math.floor(ceBcr.width);\r\n    const ceBcrIntH = Math.floor(ceBcr.height);\r\n\r\n    // height available for plugins (audiosignal and sonagram)\r\n    let psH = ceBcrIntH - AudioClipUIContainer.DIVIDER_PIXEL_SIZE;\r\n    if (psH < 0) {\r\n      psH = 0;\r\n    }\r\n    // audio signal height\r\n    const asH = Math.round(psH * this.dividerPosition);\r\n\r\n    // sonagram height (rest: available height minus divider height minus audiosignal height)\r\n    let soH = ceBcrIntH - AudioClipUIContainer.DIVIDER_PIXEL_SIZE - asH;\r\n    if (soH < 0) {\r\n      soH = 0;\r\n    }\r\n\r\n  // sonagram top position\r\n    const soTop = asH + AudioClipUIContainer.DIVIDER_PIXEL_SIZE;\r\n\r\n    // Visible bounds\r\n    // left position\r\n    let vbLeft = 0;\r\n    // width\r\n    let vbWidth = ceBcrIntW;\r\n    if (!this._fixFitToPanel && this.bounds) {\r\n      vbLeft = Math.round(this.bounds.position.left);\r\n      vbWidth = Math.round(this.bounds.dimension.width);\r\n    }\r\n\r\n    // Divider\r\n    // left position\r\n    let vbLeftStyl = vbLeft + 'px';\r\n    if (this.dc.style.left != vbLeftStyl) {\r\n      this.dc.style.left = vbLeftStyl;\r\n    }\r\n    // top position\r\n    const dTop = asH;\r\n    const dTopStr = dTop + 'px';\r\n    if (this.dc.style.top != dTopStr) {\r\n      this.dc.style.top = dTopStr;\r\n    }\r\n    // width\r\n    let vbWidthStyle = vbWidth + 'px';\r\n    if (this.dc.style.width != vbWidthStyle) {\r\n      this.dc.style.width = vbWidthStyle;\r\n    }\r\n    if (this.dc.width != vbWidth) {\r\n      this.dc.width = vbWidth;\r\n    }\r\n    // height\r\n    if(this.dc.height!=AudioClipUIContainer.DIVIDER_PIXEL_SIZE) {\r\n      this.dc.height = AudioClipUIContainer.DIVIDER_PIXEL_SIZE;\r\n\r\n    }\r\n    let divPixelSizeStyle=AudioClipUIContainer.DIVIDER_PIXEL_SIZE.toString() + 'px';\r\n    if(this.dc.style.height!=divPixelSizeStyle) {\r\n      this.dc.style.height = divPixelSizeStyle;\r\n    }\r\n\r\n    this.drawDivider();\r\n\r\n\r\n    // Virtual dimension, only width is used\r\n    let virtualDim = new Dimension(ceBcrIntW, 0)\r\n\r\n    // Visible bounds of container\r\n    let br = new Rectangle(new Position(vbLeft, 0), new Dimension(vbWidth, ceBcrIntH));\r\n\r\n    // Set container bounds\r\n    this.layoutBounds(br, virtualDim, false);\r\n\r\n    // Visible bounds of audiosignal\r\n    let asR = new Rectangle(new Position(vbLeft, 0), new Dimension(vbWidth, asH));\r\n\r\n    // Set audiosignal bounds\r\n    this.as.layoutBounds(asR, virtualDim, redraw, clear);\r\n\r\n    // Visible bounds of sonagram\r\n    let soR = new Rectangle(new Position(vbLeft, soTop), new Dimension(vbWidth, soH));\r\n\r\n    // Set sonagram bounds\r\n    this.so.layoutBounds(soR, virtualDim, redraw, clear);\r\n  }\r\n\r\n  layoutScaled() {\r\n    this._layout(false, false);\r\n  }\r\n\r\n  layout(clear=true) {\r\n\r\n    if(this.ce && this.dc) {\r\n      const clientW=this.ce.clientWidth;\r\n      if(this._audioData){\r\n        if(this._fixFitToPanel) {\r\n          // Set the virtual canvas width to the visible width\r\n          if(this.ce.style.width!='100%') {\r\n            //console.log(\"set width to 100%\");\r\n            this.ce.style.width = '100%';\r\n          }\r\n        }else{\r\n          if (this._xZoom) {\r\n            // Set the virtual canvas width according to the value of the user selected xZoom value\r\n            const newClW = Math.round( this._xZoom*this._audioData.duration );\r\n            this.ce.style.width = newClW + 'px';\r\n          } else {\r\n            // Set the virtual canvas width to the visible width only\r\n            this.ce.style.width = clientW + 'px';\r\n          }\r\n        }\r\n      }\r\n      this._layout(clear,true);\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  set audioData(audioData: AudioBuffer | null) {\r\n    this._audioClip=null\r\n    this._audioData=audioData;\r\n    this.as.setData(audioData);\r\n    this.so.setData(audioData);\r\n    this.layout();\r\n  }\r\n\r\n  get audioData():AudioBuffer|null{\r\n    return this._audioData\r\n  }\r\n\r\n  @Input()\r\n  set audioClip(audioClip: AudioClip | null) {\r\n    this._audioClip=audioClip\r\n      let audioData:AudioBuffer|null=null;\r\n    let sel:Selection|null=null;\r\n      if(audioClip) {\r\n        audioData = audioClip.buffer;\r\n        if (this._audioClip) {\r\n          this._audioClip.addSelectionObserver((clip) => {\r\n            this.selection = clip.selection\r\n          });\r\n        }\r\n        sel=audioClip.selection;\r\n      }\r\n      this._audioData = audioData;\r\n      this.as.setData(this._audioData);\r\n      this.so.setData(this._audioData);\r\n      this.selecting=null\r\n      this.selection=sel\r\n    this.layout();\r\n  }\r\n\r\n  get playFramePosition(): number |null {\r\n    return this._playFramePosition;\r\n  }\r\n\r\n  set playFramePosition(playFramePosition: number|null) {\r\n    this._playFramePosition = playFramePosition;\r\n    this.as.playFramePosition = playFramePosition;\r\n    this.so.playFramePosition = playFramePosition;\r\n  }\r\n}\r\n\r\n"]}
@@ -1,2 +1,2 @@
1
- export const VERSION = '2.21.7';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ByLm1vZHVsZS52ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL3Nwci5tb2R1bGUudmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUMsUUFBUSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFZFUlNJT049JzIuMjEuNyciXX0=
1
+ export const VERSION = '2.21.8';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ByLm1vZHVsZS52ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL3Nwci5tb2R1bGUudmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUMsUUFBUSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFZFUlNJT049JzIuMjEuOCciXX0=
@@ -3185,38 +3185,50 @@ class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
3185
3185
  for (let ci = 0; ci < this.canvasLayers.length; ci++) {
3186
3186
  let cl = this.canvasLayers[ci];
3187
3187
  const leftStyle = bounds.position.left + 'px';
3188
+ if (cl.style.left != leftStyle) {
3189
+ cl.style.left = leftStyle;
3190
+ }
3188
3191
  const topStyle = bounds.position.top + 'px';
3189
- cl.style.left = leftStyle;
3190
- cl.style.top = topStyle;
3192
+ if (cl.style.top != topStyle) {
3193
+ cl.style.top = topStyle;
3194
+ }
3191
3195
  }
3192
3196
  if (bounds.dimension.width) {
3193
- let intW = Math.round(bounds.dimension.width);
3197
+ let intW = Math.floor(bounds.dimension.width);
3194
3198
  if (redraw) {
3195
3199
  // Do not set width of background canvas (causes flicker on start render)
3196
3200
  for (let ci = 1; ci < this.canvasLayers.length; ci++) {
3197
3201
  let cl = this.canvasLayers[ci];
3198
- cl.width = intW;
3202
+ if (cl.width != intW) {
3203
+ cl.width = intW;
3204
+ }
3199
3205
  }
3200
3206
  }
3201
3207
  let wStr = intW.toString() + 'px';
3202
3208
  for (let ci = 0; ci < this.canvasLayers.length; ci++) {
3203
3209
  let cl = this.canvasLayers[ci];
3204
- cl.style.width = wStr;
3210
+ if (cl.style.width != wStr) {
3211
+ cl.style.width = wStr;
3212
+ }
3205
3213
  }
3206
3214
  }
3207
3215
  if (bounds.dimension.height) {
3208
- let intH = Math.round(bounds.dimension.height);
3216
+ let intH = Math.floor(bounds.dimension.height);
3209
3217
  if (redraw) {
3210
3218
  // Do not set height of background canvas (causes flicker on start render)
3211
3219
  for (let ci = 1; ci < this.canvasLayers.length; ci++) {
3212
3220
  let cl = this.canvasLayers[ci];
3213
- cl.height = intH;
3221
+ if (cl.height != intH) {
3222
+ cl.height = intH;
3223
+ }
3214
3224
  }
3215
3225
  }
3216
3226
  let hStr = intH + 'px';
3217
3227
  for (let ci = 0; ci < this.canvasLayers.length; ci++) {
3218
3228
  let cl = this.canvasLayers[ci];
3219
- cl.style.height = hStr;
3229
+ if (cl.style.height != hStr) {
3230
+ cl.style.height = hStr;
3231
+ }
3220
3232
  }
3221
3233
  }
3222
3234
  //});
@@ -4946,17 +4958,32 @@ class AudioClipUIContainer extends BasicAudioCanvasLayerComponent {
4946
4958
  }
4947
4959
  // Divider
4948
4960
  // left position
4949
- this.dc.style.left = vbLeft + 'px';
4961
+ let vbLeftStyl = vbLeft + 'px';
4962
+ if (this.dc.style.left != vbLeftStyl) {
4963
+ this.dc.style.left = vbLeftStyl;
4964
+ }
4950
4965
  // top position
4951
4966
  const dTop = asH;
4952
4967
  const dTopStr = dTop + 'px';
4953
- this.dc.style.top = dTopStr;
4968
+ if (this.dc.style.top != dTopStr) {
4969
+ this.dc.style.top = dTopStr;
4970
+ }
4954
4971
  // width
4955
- this.dc.style.width = vbWidth + 'px';
4956
- this.dc.width = vbWidth;
4972
+ let vbWidthStyle = vbWidth + 'px';
4973
+ if (this.dc.style.width != vbWidthStyle) {
4974
+ this.dc.style.width = vbWidthStyle;
4975
+ }
4976
+ if (this.dc.width != vbWidth) {
4977
+ this.dc.width = vbWidth;
4978
+ }
4957
4979
  // height
4958
- this.dc.height = AudioClipUIContainer.DIVIDER_PIXEL_SIZE;
4959
- this.dc.style.height = AudioClipUIContainer.DIVIDER_PIXEL_SIZE.toString() + 'px';
4980
+ if (this.dc.height != AudioClipUIContainer.DIVIDER_PIXEL_SIZE) {
4981
+ this.dc.height = AudioClipUIContainer.DIVIDER_PIXEL_SIZE;
4982
+ }
4983
+ let divPixelSizeStyle = AudioClipUIContainer.DIVIDER_PIXEL_SIZE.toString() + 'px';
4984
+ if (this.dc.style.height != divPixelSizeStyle) {
4985
+ this.dc.style.height = divPixelSizeStyle;
4986
+ }
4960
4987
  this.drawDivider();
4961
4988
  // Virtual dimension, only width is used
4962
4989
  let virtualDim = new Dimension(ceBcrIntW, 0);
@@ -4982,7 +5009,10 @@ class AudioClipUIContainer extends BasicAudioCanvasLayerComponent {
4982
5009
  if (this._audioData) {
4983
5010
  if (this._fixFitToPanel) {
4984
5011
  // Set the virtual canvas width to the visible width
4985
- this.ce.style.width = '100%';
5012
+ if (this.ce.style.width != '100%') {
5013
+ //console.log("set width to 100%");
5014
+ this.ce.style.width = '100%';
5015
+ }
4986
5016
  }
4987
5017
  else {
4988
5018
  if (this._xZoom) {
@@ -5047,7 +5077,7 @@ AudioClipUIContainer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
5047
5077
  <audio-signal [pointerPosition]="pointer" [selecting]="selecting" [selection]="selection" (pointerPositionEventEmitter)="pointerPositionChanged($event)" (selectingEventEmitter)="selectingChanged($event)" (selectedEventEmitter)="selectionChanged($event)"></audio-signal>
5048
5078
  <audio-sonagram [pointerPosition]="pointer" [selecting]="selecting" [selection]="selection" (pointerPositionEventEmitter)="pointerPositionChanged($event)" (selectingEventEmitter)="selectingChanged($event)" (selectedEventEmitter)="selectionChanged($event)"></audio-sonagram>
5049
5079
  </div>
5050
- `, isInline: true, styles: ["div{margin:0;padding:0;top:0;left:0;width:100%;height:100%;position:relative;box-sizing:border-box;transform:none}\n", "canvas{top:0;left:0;width:0;height:0;cursor:ns-resize;position:absolute;zIndex:1;transform:none}\n", "audio-signal{top:0;left:0;position:absolute;zIndex:1;transform:none}\n", "audio-sonagram{top:0;left:0;position:absolute;zIndex:1;transform:none}\n"], components: [{ type: AudioSignal, selector: "audio-signal" }, { type: Sonagram, selector: "audio-sonagram" }] });
5080
+ `, isInline: true, styles: ["div{margin:0;padding:0;top:0;left:0;width:100%;height:100%;position:relative;box-sizing:border-box;transform:none;overflow:hidden}\n", "canvas{top:0;left:0;width:0;height:0;cursor:ns-resize;position:absolute;zIndex:1;transform:none}\n", "audio-signal{top:0;left:0;position:absolute;zIndex:1;transform:none}\n", "audio-sonagram{top:0;left:0;position:absolute;zIndex:1;transform:none}\n"], components: [{ type: AudioSignal, selector: "audio-signal" }, { type: Sonagram, selector: "audio-sonagram" }] });
5051
5081
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: AudioClipUIContainer, decorators: [{
5052
5082
  type: Component,
5053
5083
  args: [{
@@ -5071,6 +5101,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
5071
5101
  position: relative; /* TODO container div position must not be 'static' (default) to act as reference for the canvases */
5072
5102
  box-sizing: border-box;
5073
5103
  transform: none;
5104
+ overflow: hidden;
5074
5105
  }`, `canvas{
5075
5106
  top: 0;
5076
5107
  left: 0;
@@ -10397,7 +10428,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
10397
10428
  }]
10398
10429
  }] });
10399
10430
 
10400
- const VERSION = '2.21.7';
10431
+ const VERSION = '2.21.8';
10401
10432
 
10402
10433
  /*
10403
10434
  * Public API Surface of speechrecorderng