VLab Issue #6222. Ensemble Tool Feature: 14.4.1 cosmetic and bug fix; fixes #6222

Change-Id: I0af8db16244969e80ed81b82e83544bb94188387

Former-commit-id: 026366fc59 [formerly 252765c247 [formerly 0235002dc0] [formerly 026366fc59 [formerly 24dee8480063cf90e5c261e848d9cbcddf6b9459]]]
Former-commit-id: 252765c247 [formerly 0235002dc0]
Former-commit-id: 252765c247
Former-commit-id: ae1bab442d
This commit is contained in:
Evan Polster 2015-01-28 23:29:26 +00:00
parent 01022c7e41
commit 944e7a5025
3 changed files with 73 additions and 94 deletions

View file

@ -7,7 +7,7 @@
point="org.eclipse.ui.commands">
<command
id="gov.noaa.gsd.viz.ensemble.activate.layer"
name="Ensembles Tool">
name="Ensemble Tool">
</command>
</extension>
@ -35,9 +35,9 @@
commandId="gov.noaa.gsd.viz.ensemble.activate.layer"
icon="icons/EnsembleTool.gif"
id="gov.noaa.gsd.viz.ensemble.tool.viewer"
label="Ensembles"
label="Ensemble Tool"
style="push"
tooltip="Ensemble Tools">
tooltip="Ensemble Tool">
</command>
<separator
name="gov.noaa.gsd.viz.ensemble.separator_post"

View file

@ -24,8 +24,8 @@ public enum Calculation {
COMBINED_ENS_REL_FREQ("Combined ERF"), //
DIFFERENCE("Diff"), //
ENSEMBLE_RELATIVE_FREQUENCY("Ens Rel Freq"), //
HISTOGRAM_SAMPLING("Histogram sampling"), //
HISTOGRAM_TEXT("Histogram text"), //
HISTOGRAM_SAMPLING("Sampling"), //
HISTOGRAM_TEXT("Histogram Sampling"), //
MAX("Max"), //
MEAN("Mean"), //
MIN("Min"), //

View file

@ -30,7 +30,6 @@ import org.eclipse.core.commands.ExecutionEvent;
import org.eclipse.jface.action.IMenuListener;
import org.eclipse.jface.action.IMenuManager;
import org.eclipse.jface.action.MenuManager;
import org.eclipse.jface.dialogs.IDialogConstants;
import org.eclipse.jface.dialogs.MessageDialog;
import org.eclipse.jface.viewers.ColumnLabelProvider;
import org.eclipse.jface.viewers.ITreeContentProvider;
@ -40,6 +39,7 @@ import org.eclipse.jface.viewers.TreeViewer;
import org.eclipse.jface.viewers.TreeViewerColumn;
import org.eclipse.jface.viewers.Viewer;
import org.eclipse.jface.viewers.ViewerSorter;
import org.eclipse.jface.window.Window;
import org.eclipse.swt.SWT;
import org.eclipse.swt.custom.CTabFolder;
import org.eclipse.swt.custom.CTabItem;
@ -267,7 +267,7 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
private Cursor selectionModeCursor = null;
private Cursor toggleVisibilityModeCursor = null;
private Cursor normalCursor = null;
private Cursor waitCursor = null;
@ -447,13 +447,13 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
selectionModeCursor = owner.getDisplay().getSystemCursor(
SWT.CURSOR_HAND);
toggleVisibilityModeCursor = owner.getDisplay().getSystemCursor(
SWT.CURSOR_ARROW);
normalCursor = owner.getDisplay().getSystemCursor(SWT.CURSOR_ARROW);
waitCursor = owner.getDisplay().getSystemCursor(SWT.CURSOR_WAIT);
ensembleTree.addKeyListener(new EnsembleTreeKeyListener());
ensembleTree.setCursor(toggleVisibilityModeCursor);
updateCursor(normalCursor);
}
@ -1524,7 +1524,7 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
if ((e.keyCode & SWT.CTRL) == SWT.CTRL) {
CTRL_KEY_DEPRESSED = true;
ensembleTree.setCursor(selectionModeCursor);
updateCursor(selectionModeCursor);
}
}
@ -1533,7 +1533,7 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
if ((e.keyCode & SWT.CTRL) == SWT.CTRL) {
CTRL_KEY_DEPRESSED = false;
ensembleTree.setCursor(toggleVisibilityModeCursor);
updateCursor(normalCursor);
}
}
@ -1554,7 +1554,7 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
// menu for either ensemble products or
// individual grid products ...
// if the enesemble tool isn't open then ignore
// if the ensemble tool isn't open then ignore
// user mouse clicks ...
if (!EnsembleToolManager.getInstance().isReady()) {
return;
@ -1600,17 +1600,14 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
public void handleEvent(Event event) {
final Cursor currCursor = ensembleTree
.getCursor();
VizApp.runAsync(new Runnable() {
@Override
public void run() {
ensembleTree.setCursor(waitCursor);
updateCursor(waitCursor);
startAddERFLayer(mousedEnsembleName);
ensembleTree.setCursor(currCursor);
updateCursor(normalCursor);
}
});
@ -1632,17 +1629,14 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
new Listener() {
public void handleEvent(Event event) {
final Cursor currCursor = ensembleTree
.getCursor();
VizApp.runAsync(new Runnable() {
@Override
public void run() {
ensembleTree.setCursor(waitCursor);
updateCursor(waitCursor);
updateColorsOnResource(mousedEnsembleName);
ensembleTree.setCursor(currCursor);
updateCursor(normalCursor);
}
});
@ -1666,21 +1660,16 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
if (proceed) {
final Cursor currCursor = ensembleTree
.getCursor();
VizApp.runAsync(new Runnable() {
@Override
public void run() {
ensembleTree
.setCursor(waitCursor);
updateCursor(waitCursor);
EnsembleToolManager
.getInstance()
.unloadResourcesByName(
item.getText());
ensembleTree
.setCursor(currCursor);
updateCursor(normalCursor);
}
});
@ -1699,19 +1688,16 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
public void handleEvent(Event event) {
final Cursor currCursor = ensembleTree
.getCursor();
VizApp.runAsync(new Runnable() {
@Override
public void run() {
ensembleTree.setCursor(waitCursor);
updateCursor(waitCursor);
setItemVisible(item,
toggleVisibilityMenuItem
.getSelection());
ensembleTree.setCursor(currCursor);
updateCursor(normalCursor);
}
});
@ -1977,21 +1963,19 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
// of all the resources in one ensemble
} else if (mousedItem instanceof GenericResourceHolder) {
final Cursor currCursor = ensembleTree.getCursor();
VizApp.runAsync(new Runnable() {
@Override
public void run() {
ensembleTree.setCursor(waitCursor);
updateCursor(waitCursor);
toggleItemVisible(userClickedTreeItem);
// if this was the last item to be toggled off,
// for example, in an ensemble group, then you
// need to toggle the parent tree item off also
matchParentToChildrenVisibility(userClickedTreeItem);
ensembleTree.setCursor(currCursor);
updateCursor(normalCursor);
}
});
@ -2014,12 +1998,11 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
final List<GenericResourceHolder> children = getEnsembleMemberGenericResources(ensembleName);
// TODO: poor-man's way of knowing what type of flavor this ensemble is
if (ensembleName.toLowerCase().indexOf("gfsensemble") >= 0) {
if ((ensembleName.indexOf("GEFS") >= 0)
|| (ensembleName.indexOf("GFS Ensemble") >= 0)) {
updateGEFSEnsembleColors(ensembleName, children);
} else if (ensembleName.toLowerCase().indexOf("sref") >= 0) {
} else if (ensembleName.indexOf("SREF") >= 0) {
updateSREFColors(ensembleName, children);
} else {
return;
}
}
@ -2027,23 +2010,17 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
private void updateSREFColors(String ensembleName,
final List<GenericResourceHolder> children) {
final Cursor currCursor = ensembleTree.getCursor();
VizApp.runAsync(new Runnable() {
VizApp.runSync(new Runnable() {
@Override
public void run() {
ensembleTree.setCursor(waitCursor);
updateCursor(waitCursor);
EnsembleSREFColorChooser cd = new EnsembleSREFColorChooser(
owner.getShell());
cd.create();
int result = cd.open();
if (result != IDialogConstants.OK_ID) {
return;
}
cd.setBlockOnOpen(true);
if (cd.open() == Window.OK) {
Color currColor = null;
for (GenericResourceHolder gRsc : children) {
if (gRsc instanceof GridResourceHolder) {
@ -2059,8 +2036,9 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
}
}
ensemblesTreeViewer.refresh();
}
ensembleTree.setCursor(currCursor);
updateCursor(normalCursor);
}
});
@ -2070,23 +2048,19 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
private void updateGEFSEnsembleColors(String ensembleName,
final List<GenericResourceHolder> children) {
final Cursor currCursor = ensembleTree.getCursor();
VizApp.runAsync(new Runnable() {
VizApp.runSync(new Runnable() {
@Override
public void run() {
ensembleTree.setCursor(waitCursor);
updateCursor(waitCursor);
EnsembleGEFSColorChooser cd = new EnsembleGEFSColorChooser(
owner.getShell());
cd.create();
int result = cd.open();
if (result != IDialogConstants.OK_ID) {
return;
}
cd.setBlockOnOpen(true);
if (cd.open() == Window.OK) {
// EditorUtil.getActiveEditor().
Color currColor = null;
int count = 0;
for (GenericResourceHolder gRsc : children) {
@ -2108,8 +2082,9 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
}
}
ensemblesTreeViewer.refresh();
}
ensembleTree.setCursor(currCursor);
updateCursor(normalCursor);
}
});
@ -3516,4 +3491,8 @@ public class EnsembleToolViewer extends ViewPart implements IRefreshListener {
}
}
private void updateCursor(Cursor c) {
ensembleTree.setCursor(c);
}
}