Home | History | Annotate | Download | only in cc
      1 <!DOCTYPE html>
      2 <!--
      3 Copyright (c) 2013 The Chromium Authors. All rights reserved.
      4 Use of this source code is governed by a BSD-style license that can be
      5 found in the LICENSE file.
      6 -->
      7 
      8 <link rel="import" href="/tracing/ui/analysis/generic_object_view.html">
      9 
     10 <script>
     11 'use strict';
     12 
     13 tr.exportTo('tr.ui.e.chrome.cc', function() {
     14   function Selection() {
     15     this.selectionToSetIfClicked = undefined;
     16   };
     17   Selection.prototype = {
     18     /**
     19      * When two things are picked in the UI, one must occasionally tie-break
     20      * between them to decide what was really clicked. Things with higher
     21      * specicifity will win.
     22      */
     23     get specicifity() {
     24       throw new Error('Not implemented');
     25     },
     26 
     27     /**
     28      * If a selection is related to a specific layer, then this returns the
     29      * layerId of that layer. If the selection is not related to a layer, for
     30      * example if the device viewport is selected, then this returns undefined.
     31      */
     32     get associatedLayerId() {
     33       throw new Error('Not implemented');
     34     },
     35 
     36     /**
     37      * If a selection is related to a specific render pass, then this returns
     38      * the layerId of that layer. If the selection is not related to a layer,
     39      * for example if the device viewport is selected, then this returns
     40      * undefined.
     41      */
     42     get associatedRenderPassId() {
     43       throw new Error('Not implemented');
     44     },
     45 
     46 
     47     get highlightsByLayerId() {
     48       return {};
     49     },
     50 
     51     /**
     52      * Called when the selection is made active in the layer view. Must return
     53      * an HTMLElement that explains this selection in detail.
     54      */
     55     createAnalysis: function() {
     56       throw new Error('Not implemented');
     57     },
     58 
     59     /**
     60      * Should try to create the equivalent selection in the provided LTHI,
     61      * or undefined if it can't be done.
     62      */
     63     findEquivalent: function(lthi) {
     64       throw new Error('Not implemented');
     65     }
     66   };
     67 
     68   /**
     69    * @constructor
     70    */
     71   function RenderPassSelection(renderPass, renderPassId) {
     72     if (!renderPass || (renderPassId === undefined))
     73       throw new Error('Render pass (with id) is required');
     74     this.renderPass_ = renderPass;
     75     this.renderPassId_ = renderPassId;
     76   }
     77 
     78   RenderPassSelection.prototype = {
     79     __proto__: Selection.prototype,
     80 
     81     get specicifity() {
     82       return 1;
     83     },
     84 
     85     get associatedLayerId() {
     86       return undefined;
     87     },
     88 
     89     get associatedRenderPassId() {
     90       return this.renderPassId_;
     91     },
     92 
     93     get renderPass() {
     94       return this.renderPass_;
     95     },
     96 
     97     createAnalysis: function() {
     98       var dataView = document.createElement(
     99           'tr-ui-a-generic-object-view-with-label');
    100       dataView.label = 'RenderPass ' + this.renderPassId_;
    101       dataView.object = this.renderPass_.args;
    102       return dataView;
    103     },
    104 
    105     get title() {
    106       return this.renderPass_.objectInstance.typeName;
    107     }
    108   };
    109 
    110   /**
    111    * @constructor
    112    */
    113   function LayerSelection(layer) {
    114     if (!layer)
    115       throw new Error('Layer is required');
    116     this.layer_ = layer;
    117   }
    118 
    119   LayerSelection.prototype = {
    120     __proto__: Selection.prototype,
    121 
    122     get specicifity() {
    123       return 1;
    124     },
    125 
    126     get associatedLayerId() {
    127       return this.layer_.layerId;
    128     },
    129 
    130     get associatedRenderPassId() {
    131       return undefined;
    132     },
    133 
    134     get layer() {
    135       return this.layer_;
    136     },
    137 
    138     createAnalysis: function() {
    139       var dataView = document.createElement(
    140           'tr-ui-a-generic-object-view-with-label');
    141       dataView.label = 'Layer ' + this.layer_.layerId;
    142       if (this.layer_.usingGpuRasterization)
    143         dataView.label += ' (GPU-rasterized)';
    144       dataView.object = this.layer_.args;
    145       return dataView;
    146     },
    147 
    148     get title() {
    149       return this.layer_.objectInstance.typeName;
    150     },
    151 
    152     findEquivalent: function(lthi) {
    153       var layer = lthi.activeTree.findLayerWithId(this.layer_.layerId) ||
    154           lthi.pendingTree.findLayerWithId(this.layer_.layerId);
    155       if (!layer)
    156         return undefined;
    157       return new LayerSelection(layer);
    158     }
    159   };
    160 
    161   /**
    162    * @constructor
    163    */
    164   function TileSelection(tile, opt_data) {
    165     this.tile_ = tile;
    166     this.data_ = opt_data || {};
    167   }
    168 
    169   TileSelection.prototype = {
    170     __proto__: Selection.prototype,
    171 
    172     get specicifity() {
    173       return 2;
    174     },
    175 
    176     get associatedLayerId() {
    177       return this.tile_.layerId;
    178     },
    179 
    180     get highlightsByLayerId() {
    181       var highlights = {};
    182       highlights[this.tile_.layerId] = [
    183         {
    184           colorKey: this.tile_.objectInstance.typeName,
    185           rect: this.tile_.layerRect
    186         }
    187       ];
    188       return highlights;
    189     },
    190 
    191     createAnalysis: function() {
    192       var analysis = document.createElement(
    193           'tr-ui-a-generic-object-view-with-label');
    194       analysis.label = 'Tile ' + this.tile_.objectInstance.id + ' on layer ' +
    195           this.tile_.layerId;
    196       if (this.data_) {
    197         analysis.object = {
    198           moreInfo: this.data_,
    199           tileArgs: this.tile_.args
    200         };
    201       } else {
    202         analysis.object = this.tile_.args;
    203       }
    204       return analysis;
    205     },
    206 
    207     findEquivalent: function(lthi) {
    208       var tileInstance = this.tile_.tileInstance;
    209       if (lthi.ts < tileInstance.creationTs ||
    210           lthi.ts >= tileInstance.deletionTs)
    211         return undefined;
    212       var tileSnapshot = tileInstance.getSnapshotAt(lthi.ts);
    213       if (!tileSnapshot)
    214         return undefined;
    215       return new TileSelection(tileSnapshot);
    216     }
    217   };
    218 
    219   /**
    220    * @constructor
    221    */
    222   function LayerRectSelection(layer, rectType, rect, opt_data) {
    223     this.layer_ = layer;
    224     this.rectType_ = rectType;
    225     this.rect_ = rect;
    226     this.data_ = opt_data !== undefined ? opt_data : rect;
    227   }
    228 
    229   LayerRectSelection.prototype = {
    230     __proto__: Selection.prototype,
    231 
    232     get specicifity() {
    233       return 2;
    234     },
    235 
    236     get associatedLayerId() {
    237       return this.layer_.layerId;
    238     },
    239 
    240 
    241     get highlightsByLayerId() {
    242       var highlights = {};
    243       highlights[this.layer_.layerId] = [
    244         {
    245           colorKey: this.rectType_,
    246           rect: this.rect_
    247         }
    248       ];
    249       return highlights;
    250     },
    251 
    252     createAnalysis: function() {
    253       var analysis = document.createElement(
    254           'tr-ui-a-generic-object-view-with-label');
    255       analysis.label = this.rectType_ + ' on layer ' + this.layer_.layerId;
    256       analysis.object = this.data_;
    257       return analysis;
    258     },
    259 
    260     findEquivalent: function(lthi) {
    261       return undefined;
    262     }
    263   };
    264 
    265   /**
    266    * @constructor
    267    */
    268   function AnimationRectSelection(layer, rect) {
    269     this.layer_ = layer;
    270     this.rect_ = rect;
    271   }
    272 
    273   AnimationRectSelection.prototype = {
    274     __proto__: Selection.prototype,
    275 
    276     get specicifity() {
    277       return 0;
    278     },
    279 
    280     get associatedLayerId() {
    281       return this.layer_.layerId;
    282     },
    283 
    284     createAnalysis: function() {
    285       var analysis = document.createElement(
    286           'tr-ui-a-generic-object-view-with-label');
    287       analysis.label = 'Animation Bounds of layer ' + this.layer_.layerId;
    288       analysis.object = this.rect_;
    289       return analysis;
    290     }
    291   };
    292 
    293   return {
    294     Selection: Selection,
    295     RenderPassSelection: RenderPassSelection,
    296     LayerSelection: LayerSelection,
    297     TileSelection: TileSelection,
    298     LayerRectSelection: LayerRectSelection,
    299     AnimationRectSelection: AnimationRectSelection
    300   };
    301 });
    302 </script>
    303