Added beacon interval to node info panel
This commit is contained in:
parent
c522b9333c
commit
603a475584
|
@ -26,7 +26,7 @@
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* $Id: NodeInfoPanel.java,v 1.11 2010/10/14 06:45:45 nifi Exp $
|
* $Id: NodeInfoPanel.java,v 1.12 2010/10/14 16:49:34 nifi Exp $
|
||||||
*
|
*
|
||||||
* -----------------------------------------------------------------
|
* -----------------------------------------------------------------
|
||||||
*
|
*
|
||||||
|
@ -34,8 +34,8 @@
|
||||||
*
|
*
|
||||||
* Authors : Joakim Eriksson, Niclas Finne
|
* Authors : Joakim Eriksson, Niclas Finne
|
||||||
* Created : 6 sep 2010
|
* Created : 6 sep 2010
|
||||||
* Updated : $Date: 2010/10/14 06:45:45 $
|
* Updated : $Date: 2010/10/14 16:49:34 $
|
||||||
* $Revision: 1.11 $
|
* $Revision: 1.12 $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package se.sics.contiki.collect.gui;
|
package se.sics.contiki.collect.gui;
|
||||||
|
@ -109,17 +109,17 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
|
||||||
return node.getSensorDataAggregator().getEstimatedLostCount();
|
return node.getSensorDataAggregator().getEstimatedLostCount();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
new TableData("Average Hops", "Average Hops to Sink", Double.class) {
|
new TableData("Avg Hops", "Average Hops to Sink", Double.class) {
|
||||||
public Object getValue(Node node) {
|
public Object getValue(Node node) {
|
||||||
return node.getSensorDataAggregator().getAverageValue(SensorData.HOPS);
|
return node.getSensorDataAggregator().getAverageValue(SensorData.HOPS);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
new TableData("Average Rtmetric", "Average Routing Metric", Double.class) {
|
new TableData("Avg Rtmetric", "Average Routing Metric", Double.class) {
|
||||||
public Object getValue(Node node) {
|
public Object getValue(Node node) {
|
||||||
return node.getSensorDataAggregator().getAverageRtmetric();
|
return node.getSensorDataAggregator().getAverageRtmetric();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
new TableData("Average ETX", "Average ETX to Next Hop", Double.class) {
|
new TableData("Avg ETX", "Average ETX to Next Hop", Double.class) {
|
||||||
public Object getValue(Node node) {
|
public Object getValue(Node node) {
|
||||||
return node.getSensorDataAggregator().getAverageValue(SensorData.BEST_NEIGHBOR_ETX);
|
return node.getSensorDataAggregator().getAverageValue(SensorData.BEST_NEIGHBOR_ETX);
|
||||||
}
|
}
|
||||||
|
@ -129,6 +129,11 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
|
||||||
return node.getSensorDataAggregator().getNextHopChangeCount();
|
return node.getSensorDataAggregator().getNextHopChangeCount();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
new TableData("Beacon Interval", "Average Beacon Interval", Long.class) {
|
||||||
|
public Object getValue(Node node) {
|
||||||
|
return (long)(node.getSensorDataAggregator().getAverageValue(SensorData.BEACON_INTERVAL) * 1000);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
new TableData("Restarts", "Estimated Node Restart Count", Number.class) {
|
new TableData("Restarts", "Estimated Node Restart Count", Number.class) {
|
||||||
public Object getValue(Node node) {
|
public Object getValue(Node node) {
|
||||||
|
@ -180,17 +185,17 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
|
||||||
},
|
},
|
||||||
|
|
||||||
// Inter-packet times
|
// Inter-packet times
|
||||||
new TableData("Average Inter-packet Time", Long.class) {
|
new TableData("Avg Inter-packet Time", Long.class) {
|
||||||
public Object getValue(Node node) {
|
public Object getValue(Node node) {
|
||||||
return node.getSensorDataAggregator().getAveragePeriod();
|
return node.getSensorDataAggregator().getAveragePeriod();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
new TableData("Shortest Inter-packet Time", Long.class) {
|
new TableData("Min Inter-packet Time", Long.class) {
|
||||||
public Object getValue(Node node) {
|
public Object getValue(Node node) {
|
||||||
return node.getSensorDataAggregator().getShortestPeriod();
|
return node.getSensorDataAggregator().getShortestPeriod();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
new TableData("Longest Inter-packet Time", Long.class) {
|
new TableData("Max Inter-packet Time", Long.class) {
|
||||||
public Object getValue(Node node) {
|
public Object getValue(Node node) {
|
||||||
return node.getSensorDataAggregator().getLongestPeriod();
|
return node.getSensorDataAggregator().getLongestPeriod();
|
||||||
}
|
}
|
||||||
|
@ -263,6 +268,7 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
|
||||||
setText(time > 0 ? getTimeAsString(time) : null);
|
setText(time > 0 ? getTimeAsString(time) : null);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
renderer.setHorizontalAlignment(JLabel.RIGHT);
|
||||||
table.setDefaultRenderer(Long.class, renderer);
|
table.setDefaultRenderer(Long.class, renderer);
|
||||||
|
|
||||||
// Add renderer for double
|
// Add renderer for double
|
||||||
|
@ -399,7 +405,12 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
|
||||||
sb.append(hours).append(hours > 1 ? " hours, " : " hour, ");
|
sb.append(hours).append(hours > 1 ? " hours, " : " hour, ");
|
||||||
time -= hours * 60 * 60;
|
time -= hours * 60 * 60;
|
||||||
}
|
}
|
||||||
sb.append(time / 60).append(" min, ").append(time % 60).append(" sec");
|
long sec = time % 60;
|
||||||
|
sb.append(time / 60).append(" min, ");
|
||||||
|
if (sec < 9) {
|
||||||
|
sb.append('0');
|
||||||
|
}
|
||||||
|
sb.append(sec).append(" sec");
|
||||||
return sb.toString();
|
return sb.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -412,12 +423,12 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
|
||||||
}
|
}
|
||||||
Component c = columnRenderer.getTableCellRendererComponent(table, value, false, false, -1, columnIndex);
|
Component c = columnRenderer.getTableCellRendererComponent(table, value, false, false, -1, columnIndex);
|
||||||
int width = c.getPreferredSize().width + 6;
|
int width = c.getPreferredSize().width + 6;
|
||||||
|
int intercellSpacing = table.getIntercellSpacing().width;
|
||||||
for(int i = 0, n = table.getRowCount(); i < n; i++) {
|
for(int i = 0, n = table.getRowCount(); i < n; i++) {
|
||||||
TableCellRenderer cellRenderer = table.getCellRenderer(i, columnIndex);
|
TableCellRenderer cellRenderer = table.getCellRenderer(i, columnIndex);
|
||||||
value = table.getValueAt(i, columnIndex);
|
value = table.getValueAt(i, columnIndex);
|
||||||
c = cellRenderer.getTableCellRendererComponent(table, value, false, false, i, columnIndex);
|
c = cellRenderer.getTableCellRendererComponent(table, value, false, false, i, columnIndex);
|
||||||
int w = c.getPreferredSize().width + table.getIntercellSpacing().width;
|
int w = c.getPreferredSize().width + intercellSpacing + 2;
|
||||||
if (w > width) {
|
if (w > width) {
|
||||||
width = w;
|
width = w;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue