1 /*******************************************************************************
2 * Copyright (c) 2011, 2013 Ericsson
4 * All rights reserved. This program and the accompanying materials are
5 * made available under the terms of the Eclipse Public License v1.0 which
6 * accompanies this distribution, and is available at
7 * http://www.eclipse.org/legal/epl-v10.html
10 * Francois Chouinard - Initial API and implementation
11 * Bernd Hufmann - Changed to updated histogram data model
12 * Francois Chouinard - Moved from LTTng to TMF
13 * Patrick Tasse - Update for mouse wheel zoom
14 *******************************************************************************/
16 package org
.eclipse
.linuxtools
.tmf
.ui
.views
.histogram
;
18 import org
.eclipse
.swt
.widgets
.Composite
;
21 * A basic histogram widget that displays the event distribution of a specific time range of a trace.
22 * It has the following additional features:
24 * <li>zoom in: mouse wheel up (or forward)
25 * <li>zoom out: mouse wheel down (or backward)
29 * @author Francois Chouinard
31 public class TimeRangeHistogram
extends Histogram
{
33 // ------------------------------------------------------------------------
35 // ------------------------------------------------------------------------
37 private HistogramZoom fZoom
= null;
39 // ------------------------------------------------------------------------
41 // ------------------------------------------------------------------------
44 * @param view The parent histogram view
45 * @param parent The parent composite
47 public TimeRangeHistogram(HistogramView view
, Composite parent
) {
49 fZoom
= new HistogramZoom(this, getStartTime(), getTimeLimit());
50 addMouseWheelListener(fZoom
);
53 // ------------------------------------------------------------------------
55 // ------------------------------------------------------------------------
58 public void updateTimeRange(long startTime
, long endTime
) {
59 ((HistogramView
) fParentView
).updateTimeRange(startTime
, endTime
);
63 public synchronized void clear() {
65 fZoom
.setFullRange(0L, 0L);
66 fZoom
.setNewRange(0L, 0L);
72 * Sets the time range of the histogram
73 * @param startTime The start time
74 * @param duration The duration of the time range
76 public synchronized void setTimeRange(long startTime
, long duration
) {
77 fZoom
.setNewRange(startTime
, duration
);
78 if (getDataModel().getNbEvents() == 0) {
79 getDataModel().setTimeRange(startTime
, startTime
+ duration
);
84 * Sets the full time range of the whole trace.
85 * @param startTime The start time
86 * @param endTime The end time
88 public void setFullRange(long startTime
, long endTime
) {
89 long currentFirstEvent
= getStartTime();
90 fZoom
.setFullRange((currentFirstEvent
== 0) ? startTime
: currentFirstEvent
, endTime
);
This page took 0.033718 seconds and 5 git commands to generate.