OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2007, 2008 Apple Inc. All rights reserved. | 2 * Copyright (C) 2007, 2008 Apple Inc. All rights reserved. |
3 * Copyright (C) 2008, 2009 Anthony Ricaud <rik@webkit.org> | 3 * Copyright (C) 2008, 2009 Anthony Ricaud <rik@webkit.org> |
4 * Copyright (C) 2009 Google Inc. All rights reserved. | 4 * Copyright (C) 2009 Google Inc. All rights reserved. |
5 * | 5 * |
6 * Redistribution and use in source and binary forms, with or without | 6 * Redistribution and use in source and binary forms, with or without |
7 * modification, are permitted provided that the following conditions | 7 * modification, are permitted provided that the following conditions |
8 * are met: | 8 * are met: |
9 * | 9 * |
10 * 1. Redistributions of source code must retain the above copyright | 10 * 1. Redistributions of source code must retain the above copyright |
11 * notice, this list of conditions and the following disclaimer. | 11 * notice, this list of conditions and the following disclaimer. |
12 * 2. Redistributions in binary form must reproduce the above copyright | 12 * 2. Redistributions in binary form must reproduce the above copyright |
13 * notice, this list of conditions and the following disclaimer in the | 13 * notice, this list of conditions and the following disclaimer in the |
14 * documentation and/or other materials provided with the distribution. | 14 * documentation and/or other materials provided with the distribution. |
15 * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of | 15 * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of |
16 * its contributors may be used to endorse or promote products derived | 16 * its contributors may be used to endorse or promote products derived |
17 * from this software without specific prior written permission. | 17 * from this software without specific prior written permission. |
18 * | 18 * |
19 * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY | 19 * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY |
20 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | 20 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
21 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | 21 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
22 * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY | 22 * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY |
23 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | 23 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
24 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | 24 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | 25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
26 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 26 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
28 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 28 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
29 */ | 29 */ |
| 30 /** |
| 31 * @unrestricted |
| 32 */ |
| 33 WebInspector.TimelineGrid = class { |
| 34 constructor() { |
| 35 this.element = createElement('div'); |
| 36 WebInspector.appendStyle(this.element, 'ui_lazy/timelineGrid.css'); |
30 | 37 |
31 /** | 38 this._dividersElement = this.element.createChild('div', 'resources-dividers'
); |
32 * @constructor | |
33 */ | |
34 WebInspector.TimelineGrid = function() | |
35 { | |
36 this.element = createElement("div"); | |
37 WebInspector.appendStyle(this.element, "ui_lazy/timelineGrid.css"); | |
38 | 39 |
39 this._dividersElement = this.element.createChild("div", "resources-dividers"
); | 40 this._gridHeaderElement = createElement('div'); |
| 41 this._gridHeaderElement.classList.add('timeline-grid-header'); |
| 42 this._eventDividersElement = this._gridHeaderElement.createChild('div', 'res
ources-event-dividers'); |
| 43 this._dividersLabelBarElement = this._gridHeaderElement.createChild('div', '
resources-dividers-label-bar'); |
| 44 this.element.appendChild(this._gridHeaderElement); |
| 45 } |
40 | 46 |
41 this._gridHeaderElement = createElement("div"); | 47 /** |
42 this._gridHeaderElement.classList.add("timeline-grid-header"); | 48 * @param {!WebInspector.TimelineGrid.Calculator} calculator |
43 this._eventDividersElement = this._gridHeaderElement.createChild("div", "res
ources-event-dividers"); | 49 * @param {number=} freeZoneAtLeft |
44 this._dividersLabelBarElement = this._gridHeaderElement.createChild("div", "
resources-dividers-label-bar"); | 50 * @return {!{offsets: !Array.<number>, precision: number}} |
45 this.element.appendChild(this._gridHeaderElement); | 51 */ |
46 }; | 52 static calculateDividerOffsets(calculator, freeZoneAtLeft) { |
47 | 53 /** @const */ var minGridSlicePx = 64; // minimal distance between grid lin
es. |
48 /** | |
49 * @param {!WebInspector.TimelineGrid.Calculator} calculator | |
50 * @param {number=} freeZoneAtLeft | |
51 * @return {!{offsets: !Array.<number>, precision: number}} | |
52 */ | |
53 WebInspector.TimelineGrid.calculateDividerOffsets = function(calculator, freeZon
eAtLeft) | |
54 { | |
55 /** @const */ var minGridSlicePx = 64; // minimal distance between grid line
s. | |
56 | 54 |
57 var clientWidth = calculator.computePosition(calculator.maximumBoundary()); | 55 var clientWidth = calculator.computePosition(calculator.maximumBoundary()); |
58 var dividersCount = clientWidth / minGridSlicePx; | 56 var dividersCount = clientWidth / minGridSlicePx; |
59 var gridSliceTime = calculator.boundarySpan() / dividersCount; | 57 var gridSliceTime = calculator.boundarySpan() / dividersCount; |
60 var pixelsPerTime = clientWidth / calculator.boundarySpan(); | 58 var pixelsPerTime = clientWidth / calculator.boundarySpan(); |
61 | 59 |
62 // Align gridSliceTime to a nearest round value. | 60 // Align gridSliceTime to a nearest round value. |
63 // We allow spans that fit into the formula: span = (1|2|5)x10^n, | 61 // We allow spans that fit into the formula: span = (1|2|5)x10^n, |
64 // e.g.: ... .1 .2 .5 1 2 5 10 20 50 ... | 62 // e.g.: ... .1 .2 .5 1 2 5 10 20 50 ... |
65 // After a span has been chosen make grid lines at multiples of the span. | 63 // After a span has been chosen make grid lines at multiples of the span. |
66 | 64 |
67 var logGridSliceTime = Math.ceil(Math.log(gridSliceTime) / Math.LN10); | 65 var logGridSliceTime = Math.ceil(Math.log(gridSliceTime) / Math.LN10); |
68 gridSliceTime = Math.pow(10, logGridSliceTime); | 66 gridSliceTime = Math.pow(10, logGridSliceTime); |
69 if (gridSliceTime * pixelsPerTime >= 5 * minGridSlicePx) | 67 if (gridSliceTime * pixelsPerTime >= 5 * minGridSlicePx) |
70 gridSliceTime = gridSliceTime / 5; | 68 gridSliceTime = gridSliceTime / 5; |
71 if (gridSliceTime * pixelsPerTime >= 2 * minGridSlicePx) | 69 if (gridSliceTime * pixelsPerTime >= 2 * minGridSlicePx) |
72 gridSliceTime = gridSliceTime / 2; | 70 gridSliceTime = gridSliceTime / 2; |
73 | 71 |
74 var leftBoundaryTime = calculator.minimumBoundary() - calculator.paddingLeft
() / pixelsPerTime; | 72 var leftBoundaryTime = calculator.minimumBoundary() - calculator.paddingLeft
() / pixelsPerTime; |
75 var firstDividerTime = Math.ceil((leftBoundaryTime - calculator.zeroTime())
/ gridSliceTime) * gridSliceTime + calculator.zeroTime(); | 73 var firstDividerTime = |
| 74 Math.ceil((leftBoundaryTime - calculator.zeroTime()) / gridSliceTime) *
gridSliceTime + calculator.zeroTime(); |
76 var lastDividerTime = calculator.maximumBoundary(); | 75 var lastDividerTime = calculator.maximumBoundary(); |
77 // Add some extra space past the right boundary as the rightmost divider lab
el text | 76 // Add some extra space past the right boundary as the rightmost divider lab
el text |
78 // may be partially shown rather than just pop up when a new rightmost divid
er gets into the view. | 77 // may be partially shown rather than just pop up when a new rightmost divid
er gets into the view. |
79 lastDividerTime += minGridSlicePx / pixelsPerTime; | 78 lastDividerTime += minGridSlicePx / pixelsPerTime; |
80 dividersCount = Math.ceil((lastDividerTime - firstDividerTime) / gridSliceTi
me); | 79 dividersCount = Math.ceil((lastDividerTime - firstDividerTime) / gridSliceTi
me); |
81 | 80 |
82 if (!gridSliceTime) | 81 if (!gridSliceTime) |
83 dividersCount = 0; | 82 dividersCount = 0; |
84 | 83 |
85 var offsets = []; | 84 var offsets = []; |
86 for (var i = 0; i < dividersCount; ++i) { | 85 for (var i = 0; i < dividersCount; ++i) { |
87 var time = firstDividerTime + gridSliceTime * i; | 86 var time = firstDividerTime + gridSliceTime * i; |
88 if (calculator.computePosition(time) < freeZoneAtLeft) | 87 if (calculator.computePosition(time) < freeZoneAtLeft) |
89 continue; | 88 continue; |
90 offsets.push(time); | 89 offsets.push(time); |
91 } | 90 } |
92 | 91 |
93 return {offsets: offsets, precision: Math.max(0, -Math.floor(Math.log(gridSl
iceTime * 1.01) / Math.LN10))}; | 92 return {offsets: offsets, precision: Math.max(0, -Math.floor(Math.log(gridSl
iceTime * 1.01) / Math.LN10))}; |
94 }; | 93 } |
95 | 94 |
96 /** | 95 /** |
97 * @param {!CanvasRenderingContext2D} context | 96 * @param {!CanvasRenderingContext2D} context |
98 * @param {!WebInspector.TimelineGrid.Calculator} calculator | 97 * @param {!WebInspector.TimelineGrid.Calculator} calculator |
99 * @param {number} paddingTop | 98 * @param {number} paddingTop |
100 * @param {number=} freeZoneAtLeft | 99 * @param {number=} freeZoneAtLeft |
101 */ | 100 */ |
102 WebInspector.TimelineGrid.drawCanvasGrid = function(context, calculator, padding
Top, freeZoneAtLeft) | 101 static drawCanvasGrid(context, calculator, paddingTop, freeZoneAtLeft) { |
103 { | |
104 context.save(); | 102 context.save(); |
105 var ratio = window.devicePixelRatio; | 103 var ratio = window.devicePixelRatio; |
106 context.scale(ratio, ratio); | 104 context.scale(ratio, ratio); |
107 var width = context.canvas.width / window.devicePixelRatio; | 105 var width = context.canvas.width / window.devicePixelRatio; |
108 var height = context.canvas.height / window.devicePixelRatio; | 106 var height = context.canvas.height / window.devicePixelRatio; |
109 var dividersData = WebInspector.TimelineGrid.calculateDividerOffsets(calcula
tor); | 107 var dividersData = WebInspector.TimelineGrid.calculateDividerOffsets(calcula
tor); |
110 var dividerOffsets = dividersData.offsets; | 108 var dividerOffsets = dividersData.offsets; |
111 var precision = dividersData.precision; | 109 var precision = dividersData.precision; |
112 | 110 |
113 context.fillStyle = "rgba(255, 255, 255, 0.5)"; | 111 context.fillStyle = 'rgba(255, 255, 255, 0.5)'; |
114 context.fillRect(0, 0, width, 15); | 112 context.fillRect(0, 0, width, 15); |
115 | 113 |
116 context.fillStyle = "#333"; | 114 context.fillStyle = '#333'; |
117 context.strokeStyle = "rgba(0, 0, 0, 0.1)"; | 115 context.strokeStyle = 'rgba(0, 0, 0, 0.1)'; |
118 context.textBaseline = "hanging"; | 116 context.textBaseline = 'hanging'; |
119 context.font = "11px " + WebInspector.fontFamily(); | 117 context.font = '11px ' + WebInspector.fontFamily(); |
120 context.lineWidth = 1; | 118 context.lineWidth = 1; |
121 | 119 |
122 context.translate(0.5, 0.5); | 120 context.translate(0.5, 0.5); |
123 const paddingRight = 4; | 121 const paddingRight = 4; |
124 freeZoneAtLeft = freeZoneAtLeft || 0; | 122 freeZoneAtLeft = freeZoneAtLeft || 0; |
125 for (var i = 0; i < dividerOffsets.length; ++i) { | 123 for (var i = 0; i < dividerOffsets.length; ++i) { |
126 var time = dividerOffsets[i]; | 124 var time = dividerOffsets[i]; |
127 var position = calculator.computePosition(time); | 125 var position = calculator.computePosition(time); |
128 var text = calculator.formatValue(time, precision); | 126 var text = calculator.formatValue(time, precision); |
129 var textWidth = context.measureText(text).width; | 127 var textWidth = context.measureText(text).width; |
130 var textPosition = position - textWidth - paddingRight; | 128 var textPosition = position - textWidth - paddingRight; |
131 if (freeZoneAtLeft < textPosition) | 129 if (freeZoneAtLeft < textPosition) |
132 context.fillText(text, textPosition, paddingTop); | 130 context.fillText(text, textPosition, paddingTop); |
133 context.moveTo(position, 0); | 131 context.moveTo(position, 0); |
134 context.lineTo(position, height); | 132 context.lineTo(position, height); |
135 } | 133 } |
136 context.stroke(); | 134 context.stroke(); |
137 context.restore(); | 135 context.restore(); |
| 136 } |
| 137 |
| 138 get dividersElement() { |
| 139 return this._dividersElement; |
| 140 } |
| 141 |
| 142 get dividersLabelBarElement() { |
| 143 return this._dividersLabelBarElement; |
| 144 } |
| 145 |
| 146 removeDividers() { |
| 147 this._dividersElement.removeChildren(); |
| 148 this._dividersLabelBarElement.removeChildren(); |
| 149 } |
| 150 |
| 151 /** |
| 152 * @param {!WebInspector.TimelineGrid.Calculator} calculator |
| 153 * @param {number=} freeZoneAtLeft |
| 154 * @return {boolean} |
| 155 */ |
| 156 updateDividers(calculator, freeZoneAtLeft) { |
| 157 var dividersData = WebInspector.TimelineGrid.calculateDividerOffsets(calcula
tor, freeZoneAtLeft); |
| 158 var dividerOffsets = dividersData.offsets; |
| 159 var precision = dividersData.precision; |
| 160 |
| 161 var dividersElementClientWidth = this._dividersElement.clientWidth; |
| 162 |
| 163 // Reuse divider elements and labels. |
| 164 var divider = /** @type {?Element} */ (this._dividersElement.firstChild); |
| 165 var dividerLabelBar = /** @type {?Element} */ (this._dividersLabelBarElement
.firstChild); |
| 166 |
| 167 for (var i = 0; i < dividerOffsets.length; ++i) { |
| 168 if (!divider) { |
| 169 divider = createElement('div'); |
| 170 divider.className = 'resources-divider'; |
| 171 this._dividersElement.appendChild(divider); |
| 172 |
| 173 dividerLabelBar = createElement('div'); |
| 174 dividerLabelBar.className = 'resources-divider'; |
| 175 var label = createElement('div'); |
| 176 label.className = 'resources-divider-label'; |
| 177 dividerLabelBar._labelElement = label; |
| 178 dividerLabelBar.appendChild(label); |
| 179 this._dividersLabelBarElement.appendChild(dividerLabelBar); |
| 180 } |
| 181 |
| 182 var time = dividerOffsets[i]; |
| 183 var position = calculator.computePosition(time); |
| 184 dividerLabelBar._labelElement.textContent = calculator.formatValue(time, p
recision); |
| 185 |
| 186 var percentLeft = 100 * position / dividersElementClientWidth; |
| 187 divider.style.left = percentLeft + '%'; |
| 188 dividerLabelBar.style.left = percentLeft + '%'; |
| 189 |
| 190 divider = /** @type {?Element} */ (divider.nextSibling); |
| 191 dividerLabelBar = /** @type {?Element} */ (dividerLabelBar.nextSibling); |
| 192 } |
| 193 |
| 194 // Remove extras. |
| 195 while (divider) { |
| 196 var nextDivider = divider.nextSibling; |
| 197 this._dividersElement.removeChild(divider); |
| 198 divider = nextDivider; |
| 199 } |
| 200 while (dividerLabelBar) { |
| 201 var nextDivider = dividerLabelBar.nextSibling; |
| 202 this._dividersLabelBarElement.removeChild(dividerLabelBar); |
| 203 dividerLabelBar = nextDivider; |
| 204 } |
| 205 return true; |
| 206 } |
| 207 |
| 208 /** |
| 209 * @param {!Element} divider |
| 210 */ |
| 211 addEventDivider(divider) { |
| 212 this._eventDividersElement.appendChild(divider); |
| 213 } |
| 214 |
| 215 /** |
| 216 * @param {!Array.<!Element>} dividers |
| 217 */ |
| 218 addEventDividers(dividers) { |
| 219 this._gridHeaderElement.removeChild(this._eventDividersElement); |
| 220 for (var divider of dividers) |
| 221 this._eventDividersElement.appendChild(divider); |
| 222 this._gridHeaderElement.appendChild(this._eventDividersElement); |
| 223 } |
| 224 |
| 225 removeEventDividers() { |
| 226 this._eventDividersElement.removeChildren(); |
| 227 } |
| 228 |
| 229 hideEventDividers() { |
| 230 this._eventDividersElement.classList.add('hidden'); |
| 231 } |
| 232 |
| 233 showEventDividers() { |
| 234 this._eventDividersElement.classList.remove('hidden'); |
| 235 } |
| 236 |
| 237 hideDividers() { |
| 238 this._dividersElement.classList.add('hidden'); |
| 239 } |
| 240 |
| 241 showDividers() { |
| 242 this._dividersElement.classList.remove('hidden'); |
| 243 } |
| 244 |
| 245 /** |
| 246 * @param {number} scrollTop |
| 247 */ |
| 248 setScrollTop(scrollTop) { |
| 249 this._dividersLabelBarElement.style.top = scrollTop + 'px'; |
| 250 this._eventDividersElement.style.top = scrollTop + 'px'; |
| 251 } |
138 }; | 252 }; |
139 | 253 |
140 WebInspector.TimelineGrid.prototype = { | |
141 get dividersElement() | |
142 { | |
143 return this._dividersElement; | |
144 }, | |
145 | |
146 get dividersLabelBarElement() | |
147 { | |
148 return this._dividersLabelBarElement; | |
149 }, | |
150 | |
151 removeDividers: function() | |
152 { | |
153 this._dividersElement.removeChildren(); | |
154 this._dividersLabelBarElement.removeChildren(); | |
155 }, | |
156 | |
157 /** | |
158 * @param {!WebInspector.TimelineGrid.Calculator} calculator | |
159 * @param {number=} freeZoneAtLeft | |
160 * @return {boolean} | |
161 */ | |
162 updateDividers: function(calculator, freeZoneAtLeft) | |
163 { | |
164 var dividersData = WebInspector.TimelineGrid.calculateDividerOffsets(cal
culator, freeZoneAtLeft); | |
165 var dividerOffsets = dividersData.offsets; | |
166 var precision = dividersData.precision; | |
167 | |
168 var dividersElementClientWidth = this._dividersElement.clientWidth; | |
169 | |
170 // Reuse divider elements and labels. | |
171 var divider = /** @type {?Element} */ (this._dividersElement.firstChild)
; | |
172 var dividerLabelBar = /** @type {?Element} */ (this._dividersLabelBarEle
ment.firstChild); | |
173 | |
174 for (var i = 0; i < dividerOffsets.length; ++i) { | |
175 if (!divider) { | |
176 divider = createElement("div"); | |
177 divider.className = "resources-divider"; | |
178 this._dividersElement.appendChild(divider); | |
179 | |
180 dividerLabelBar = createElement("div"); | |
181 dividerLabelBar.className = "resources-divider"; | |
182 var label = createElement("div"); | |
183 label.className = "resources-divider-label"; | |
184 dividerLabelBar._labelElement = label; | |
185 dividerLabelBar.appendChild(label); | |
186 this._dividersLabelBarElement.appendChild(dividerLabelBar); | |
187 } | |
188 | |
189 var time = dividerOffsets[i]; | |
190 var position = calculator.computePosition(time); | |
191 dividerLabelBar._labelElement.textContent = calculator.formatValue(t
ime, precision); | |
192 | |
193 var percentLeft = 100 * position / dividersElementClientWidth; | |
194 divider.style.left = percentLeft + "%"; | |
195 dividerLabelBar.style.left = percentLeft + "%"; | |
196 | |
197 divider = /** @type {?Element} */ (divider.nextSibling); | |
198 dividerLabelBar = /** @type {?Element} */ (dividerLabelBar.nextSibli
ng); | |
199 } | |
200 | |
201 // Remove extras. | |
202 while (divider) { | |
203 var nextDivider = divider.nextSibling; | |
204 this._dividersElement.removeChild(divider); | |
205 divider = nextDivider; | |
206 } | |
207 while (dividerLabelBar) { | |
208 var nextDivider = dividerLabelBar.nextSibling; | |
209 this._dividersLabelBarElement.removeChild(dividerLabelBar); | |
210 dividerLabelBar = nextDivider; | |
211 } | |
212 return true; | |
213 }, | |
214 | |
215 /** | |
216 * @param {!Element} divider | |
217 */ | |
218 addEventDivider: function(divider) | |
219 { | |
220 this._eventDividersElement.appendChild(divider); | |
221 }, | |
222 | |
223 /** | |
224 * @param {!Array.<!Element>} dividers | |
225 */ | |
226 addEventDividers: function(dividers) | |
227 { | |
228 this._gridHeaderElement.removeChild(this._eventDividersElement); | |
229 for (var divider of dividers) | |
230 this._eventDividersElement.appendChild(divider); | |
231 this._gridHeaderElement.appendChild(this._eventDividersElement); | |
232 }, | |
233 | |
234 removeEventDividers: function() | |
235 { | |
236 this._eventDividersElement.removeChildren(); | |
237 }, | |
238 | |
239 hideEventDividers: function() | |
240 { | |
241 this._eventDividersElement.classList.add("hidden"); | |
242 }, | |
243 | |
244 showEventDividers: function() | |
245 { | |
246 this._eventDividersElement.classList.remove("hidden"); | |
247 }, | |
248 | |
249 hideDividers: function() | |
250 { | |
251 this._dividersElement.classList.add("hidden"); | |
252 }, | |
253 | |
254 showDividers: function() | |
255 { | |
256 this._dividersElement.classList.remove("hidden"); | |
257 }, | |
258 | |
259 /** | |
260 * @param {number} scrollTop | |
261 */ | |
262 setScrollTop: function(scrollTop) | |
263 { | |
264 this._dividersLabelBarElement.style.top = scrollTop + "px"; | |
265 this._eventDividersElement.style.top = scrollTop + "px"; | |
266 } | |
267 }; | |
268 | 254 |
269 /** | 255 /** |
270 * @interface | 256 * @interface |
271 */ | 257 */ |
272 WebInspector.TimelineGrid.Calculator = function() { }; | 258 WebInspector.TimelineGrid.Calculator = function() {}; |
273 | 259 |
274 WebInspector.TimelineGrid.Calculator.prototype = { | 260 WebInspector.TimelineGrid.Calculator.prototype = { |
275 /** | 261 /** |
276 * @return {number} | 262 * @return {number} |
277 */ | 263 */ |
278 paddingLeft: function() { }, | 264 paddingLeft: function() {}, |
279 | 265 |
280 /** | 266 /** |
281 * @param {number} time | 267 * @param {number} time |
282 * @return {number} | 268 * @return {number} |
283 */ | 269 */ |
284 computePosition: function(time) { }, | 270 computePosition: function(time) {}, |
285 | 271 |
286 /** | 272 /** |
287 * @param {number} time | 273 * @param {number} time |
288 * @param {number=} precision | 274 * @param {number=} precision |
289 * @return {string} | 275 * @return {string} |
290 */ | 276 */ |
291 formatValue: function(time, precision) { }, | 277 formatValue: function(time, precision) {}, |
292 | 278 |
293 /** @return {number} */ | 279 /** @return {number} */ |
294 minimumBoundary: function() { }, | 280 minimumBoundary: function() {}, |
295 | 281 |
296 /** @return {number} */ | 282 /** @return {number} */ |
297 zeroTime: function() { }, | 283 zeroTime: function() {}, |
298 | 284 |
299 /** @return {number} */ | 285 /** @return {number} */ |
300 maximumBoundary: function() { }, | 286 maximumBoundary: function() {}, |
301 | 287 |
302 /** @return {number} */ | 288 /** @return {number} */ |
303 boundarySpan: function() { } | 289 boundarySpan: function() {} |
304 }; | 290 }; |
OLD | NEW |