blob: 9342274ebb99d40370c6a910eed6a25baf802aae [file] [log] [blame]
/*
* Copyright 2014 The Chromium Authors. All rights reserved.
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
/**
* @unrestricted
*/
Timeline.TimelineLayersView = class extends UI.SplitWidget {
/**
* @param {!TimelineModel.TimelineModel} model
* @param {function(!SDK.PaintProfilerSnapshot)} showPaintProfilerCallback
*/
constructor(model, showPaintProfilerCallback) {
super(true, false, 'timelineLayersView');
this._model = model;
this._showPaintProfilerCallback = showPaintProfilerCallback;
this.element.classList.add('timeline-layers-view');
this._rightSplitWidget = new UI.SplitWidget(true, true, 'timelineLayersViewDetails');
this._rightSplitWidget.element.classList.add('timeline-layers-view-properties');
this.setMainWidget(this._rightSplitWidget);
const vbox = new UI.VBox();
this.setSidebarWidget(vbox);
this._layerViewHost = new LayerViewer.LayerViewHost();
const layerTreeOutline = new LayerViewer.LayerTreeOutline(this._layerViewHost);
vbox.element.appendChild(layerTreeOutline.element);
this._layers3DView = new LayerViewer.Layers3DView(this._layerViewHost);
this._layers3DView.addEventListener(
LayerViewer.Layers3DView.Events.PaintProfilerRequested, this._onPaintProfilerRequested, this);
this._rightSplitWidget.setMainWidget(this._layers3DView);
const layerDetailsView = new LayerViewer.LayerDetailsView(this._layerViewHost);
this._rightSplitWidget.setSidebarWidget(layerDetailsView);
layerDetailsView.addEventListener(
LayerViewer.LayerDetailsView.Events.PaintProfilerRequested, this._onPaintProfilerRequested, this);
}
/**
* @param {!TimelineModel.TracingFrameLayerTree} frameLayerTree
*/
showLayerTree(frameLayerTree) {
this._frameLayerTree = frameLayerTree;
if (this.isShowing()) {
this._update();
} else {
this._updateWhenVisible = true;
}
}
/**
* @override
*/
wasShown() {
if (this._updateWhenVisible) {
this._updateWhenVisible = false;
this._update();
}
}
/**
* @param {!Common.Event} event
*/
_onPaintProfilerRequested(event) {
const selection = /** @type {!LayerViewer.LayerView.Selection} */ (event.data);
this._layers3DView.snapshotForSelection(selection).then(snapshotWithRect => {
if (snapshotWithRect) {
this._showPaintProfilerCallback(snapshotWithRect.snapshot);
}
});
}
_update() {
this._frameLayerTree.layerTreePromise().then(layerTree => this._layerViewHost.setLayerTree(layerTree));
}
};