verify that visualizer skin is compatible with the current simulation before starting it,

set udgm/dgrm/mrm radio medium skins to be started as default
This commit is contained in:
Fredrik Osterlind 2012-06-01 12:24:30 +02:00
parent e96a375e33
commit f703965b67
2 changed files with 37 additions and 14 deletions

View File

@ -41,4 +41,10 @@ COMMAND_DATA_END = ^([0-9A-Fa-f]*)[ \t]A[ \t]_edata$
COMMAND_BSS_START = ^([0-9A-Fa-f]*)[ \t]A[ \t]__bss_start$
COMMAND_BSS_END = ^([0-9A-Fa-f]*)[ \t]A[ \t]_end$
VISUALIZER_DEFAULT_SKINS=se.sics.cooja.plugins.skins.IDVisualizerSkin;se.sics.cooja.plugins.skins.GridVisualizerSkin
VISUALIZER_DEFAULT_SKINS=\
se.sics.cooja.plugins.skins.IDVisualizerSkin;\
se.sics.cooja.plugins.skins.GridVisualizerSkin;\
se.sics.cooja.plugins.skins.DGRMVisualizerSkin;\
se.sics.cooja.plugins.skins.TrafficVisualizerSkin;\
se.sics.cooja.plugins.skins.UDGMVisualizerSkin;\
se.sics.mrm.MRMVisualizerSkin

View File

@ -494,6 +494,11 @@ public class Visualizer extends VisPlugin implements HasQuickHelp {
}
}
if (!isSkinCompatible(skinClass)) {
/*logger.warn("Skin is not compatible with current simulation: " + skinClass);*/
return;
}
/* Create and activate new skin */
try {
VisualizerSkin newSkin = skinClass.newInstance();
@ -707,6 +712,25 @@ public class Visualizer extends VisPlugin implements HasQuickHelp {
});
/* Should skin be enabled in this simulation? */
if (!isSkinCompatible(skinClass)) {
continue;
}
if (skinMenu instanceof JMenu) {
((JMenu)skinMenu).add(item);
}
if (skinMenu instanceof JPopupMenu) {
((JPopupMenu)skinMenu).add(item);
}
}
}
public boolean isSkinCompatible(Class<? extends VisualizerSkin> skinClass) {
if (skinClass == null) {
return false;
}
/* Check if skin depends on any particular radio medium */
boolean showMenuItem = true;
if (skinClass.getAnnotation(SupportedArguments.class) != null) {
@ -720,16 +744,9 @@ public class Visualizer extends VisPlugin implements HasQuickHelp {
}
}
if (!showMenuItem) {
continue;
}
if (skinMenu instanceof JMenu) {
((JMenu)skinMenu).add(item);
}
if (skinMenu instanceof JPopupMenu) {
((JPopupMenu)skinMenu).add(item);
}
return false;
}
return true;
}
private void handleMousePress(MouseEvent mouseEvent) {