public code v1
This commit is contained in:
@@ -0,0 +1,7 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.8"/>
|
||||
<classpathentry kind="con" path="org.eclipse.pde.core.requiredPlugins"/>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
@@ -0,0 +1,14 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<parent>
|
||||
<groupId>flintstones.group</groupId>
|
||||
<artifactId>flintstones.bundles</artifactId>
|
||||
<version>1.0.0-SNAPSHOT</version>
|
||||
</parent>
|
||||
<artifactId>flintstones.method.promethee.phase.gathering.ui</artifactId>
|
||||
<version>1.0.0-SNAPSHOT</version>
|
||||
<packaging>eclipse-plugin</packaging>
|
||||
<name>[bundle] Ui</name>
|
||||
</project>
|
||||
@@ -0,0 +1,45 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>flintstones.method.promethee.phase.gathering.ui</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.pde.ManifestBuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.pde.SchemaBuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.m2e.core.maven2Builder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.m2e.core.maven2Nature</nature>
|
||||
<nature>org.eclipse.pde.PluginNature</nature>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
<filteredResources>
|
||||
<filter>
|
||||
<id>1779484362693</id>
|
||||
<name></name>
|
||||
<type>30</type>
|
||||
<matcher>
|
||||
<id>org.eclipse.core.resources.regexFilterMatcher</id>
|
||||
<arguments>node_modules|\.git|__CREATED_BY_JAVA_LANGUAGE_SERVER__</arguments>
|
||||
</matcher>
|
||||
</filter>
|
||||
</filteredResources>
|
||||
</projectDescription>
|
||||
+2
@@ -0,0 +1,2 @@
|
||||
eclipse.preferences.version=1
|
||||
encoding/<project>=UTF-8
|
||||
+7
@@ -0,0 +1,7 @@
|
||||
eclipse.preferences.version=1
|
||||
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
|
||||
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8
|
||||
org.eclipse.jdt.core.compiler.compliance=1.8
|
||||
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
|
||||
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
|
||||
org.eclipse.jdt.core.compiler.source=1.8
|
||||
+4
@@ -0,0 +1,4 @@
|
||||
activeProfiles=
|
||||
eclipse.preferences.version=1
|
||||
resolveWorkspaceProjects=true
|
||||
version=1
|
||||
@@ -0,0 +1,21 @@
|
||||
Manifest-Version: 1.0
|
||||
Bundle-ManifestVersion: 2
|
||||
Bundle-Name: Ui
|
||||
Bundle-SymbolicName: flintstones.method.promethee.phase.gathering.ui;singleton:=true
|
||||
Bundle-Version: 1.0.0.qualifier
|
||||
Automatic-Module-Name: flintstones.method.promethee.phase.gathering.ui
|
||||
Bundle-RequiredExecutionEnvironment: JavaSE-11
|
||||
Require-Bundle: org.eclipse.e4.core.contexts,
|
||||
flintstones.model.problemelement.service,
|
||||
flintstones.entity.method.phase.ui,
|
||||
org.eclipse.swt,
|
||||
flintstones.model.ui.service,
|
||||
org.eclipse.jface,
|
||||
flintstones.model.method.phase.service,
|
||||
flintstones.helper.data,
|
||||
javax.inject,
|
||||
flintstones.entity.problemelement,
|
||||
flintstones.application.perspective.framework.ui,
|
||||
flintstones.method.promethee.phase.gathering,
|
||||
flintstones.entity.method.phase
|
||||
Export-Package: flintstones.method.promethee.phase.gathering.ui
|
||||
@@ -0,0 +1,5 @@
|
||||
source.. = src/
|
||||
output.. = bin/
|
||||
bin.includes = META-INF/,\
|
||||
.,\
|
||||
plugin.xml
|
||||
@@ -0,0 +1,13 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<?eclipse version="3.4"?>
|
||||
<plugin>
|
||||
<extension
|
||||
point="flintstones.phasemethod.ui">
|
||||
<phasemethod_ui
|
||||
uid="flintstones.method.promethee.phase.gathering.ui"
|
||||
implementation="flintstones.method.promethee.phase.gathering.ui.PrometheeGatheringUI"
|
||||
phasemethod="flintstones.method.promethee.phase.gathering">
|
||||
</phasemethod_ui>
|
||||
</extension>
|
||||
|
||||
</plugin>
|
||||
+76
@@ -0,0 +1,76 @@
|
||||
package flintstones.method.promethee.phase.gathering.provider;
|
||||
|
||||
import javax.inject.Inject;
|
||||
|
||||
import org.eclipse.jface.resource.ImageDescriptor;
|
||||
import org.eclipse.jface.viewers.LabelProvider;
|
||||
import org.eclipse.jface.viewers.StyledString;
|
||||
import org.eclipse.jface.viewers.DelegatingStyledCellLabelProvider.IStyledLabelProvider;
|
||||
import org.eclipse.swt.graphics.Color;
|
||||
import org.eclipse.swt.graphics.Image;
|
||||
|
||||
import flintstones.entity.problemelement.entities.ProblemElement;
|
||||
import flintstones.model.method.phase.IPhaseMethodService;
|
||||
import flintstones.model.ui.service.UiService;
|
||||
import flintstones.model.ui.service.style.ForegroundStyler;
|
||||
|
||||
public class ProblemElementLabelProvider extends LabelProvider implements IStyledLabelProvider {
|
||||
|
||||
@Inject
|
||||
IPhaseMethodService phaseService;
|
||||
|
||||
/** The group image. */
|
||||
private final ImageDescriptor groupImage;
|
||||
|
||||
/** The individual image. */
|
||||
private final ImageDescriptor individualImage;
|
||||
|
||||
/**
|
||||
* Instantiates a new problem element name label provider.
|
||||
*
|
||||
* @param individualImage the individual image
|
||||
* @param groupImage the group image
|
||||
*/
|
||||
public ProblemElementLabelProvider(ImageDescriptor individualImage, ImageDescriptor groupImage) {
|
||||
this.groupImage = groupImage;
|
||||
this.individualImage = individualImage;
|
||||
}
|
||||
|
||||
@Override
|
||||
public StyledString getStyledText(Object element) {
|
||||
if (element instanceof ProblemElement) {
|
||||
ProblemElement pe = (ProblemElement) element;
|
||||
StyledString styledString;
|
||||
styledString = paint(pe.getName(), "");
|
||||
|
||||
return styledString;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
*
|
||||
* @see org.eclipse.jface.viewers.LabelProvider#getImage(java.lang.Object) */
|
||||
@Override
|
||||
public Image getImage(Object element) {
|
||||
if (element instanceof ProblemElement) {
|
||||
if (((ProblemElement) element).hasChildren())
|
||||
return this.groupImage.createImage();
|
||||
|
||||
return this.individualImage.createImage();
|
||||
}
|
||||
|
||||
return super.getImage(element);
|
||||
}
|
||||
|
||||
private StyledString paint(String leftText, String rightText) {
|
||||
|
||||
Color foregroundColorLeft = UiService.COLOR_FG_NORMAL;
|
||||
Color foregroundColorRight = UiService.COLOR_FG_SECONDARY;
|
||||
|
||||
StyledString leftT = new StyledString(leftText, new ForegroundStyler(foregroundColorLeft));
|
||||
StyledString rightT = new StyledString(rightText, new ForegroundStyler(foregroundColorRight));
|
||||
return leftT.append(" ")
|
||||
.append(rightT);
|
||||
}
|
||||
}
|
||||
+61
@@ -0,0 +1,61 @@
|
||||
package flintstones.method.promethee.phase.gathering.ui;
|
||||
|
||||
public class PrometheeData {
|
||||
|
||||
int typeFunc;
|
||||
int MinMax;
|
||||
double p;
|
||||
double q;
|
||||
double s;
|
||||
|
||||
public PrometheeData() {
|
||||
this.p = 0.0;
|
||||
this.q = 0.0;
|
||||
this.s = 0.0;
|
||||
this.typeFunc = 1;
|
||||
}
|
||||
|
||||
public int getTypeFunc() {
|
||||
return typeFunc;
|
||||
}
|
||||
|
||||
public void setTypeFunc(int typeFunc) {
|
||||
this.typeFunc = typeFunc;
|
||||
this.p = 0.0;
|
||||
this.q = 0.0;
|
||||
this.s = 0.0;
|
||||
}
|
||||
|
||||
public int getMinMax() {
|
||||
return MinMax;
|
||||
}
|
||||
|
||||
public void setMinMax(int minmax) {
|
||||
this.MinMax = minmax;
|
||||
}
|
||||
|
||||
public double getP() {
|
||||
return p;
|
||||
}
|
||||
|
||||
public void setP(double p) {
|
||||
this.p = p;
|
||||
}
|
||||
|
||||
public double getQ() {
|
||||
return q;
|
||||
}
|
||||
|
||||
public void setQ(double q) {
|
||||
this.q = q;
|
||||
}
|
||||
|
||||
public double getS() {
|
||||
return s;
|
||||
}
|
||||
|
||||
public void setS(double s) {
|
||||
this.s = s;
|
||||
}
|
||||
|
||||
}
|
||||
+511
@@ -0,0 +1,511 @@
|
||||
package flintstones.method.promethee.phase.gathering.ui;
|
||||
|
||||
import java.util.ArrayList;
|
||||
|
||||
import javax.inject.Inject;
|
||||
|
||||
import org.eclipse.e4.core.contexts.ContextInjectionFactory;
|
||||
import org.eclipse.e4.core.contexts.IEclipseContext;
|
||||
import org.eclipse.jface.viewers.CheckStateChangedEvent;
|
||||
import org.eclipse.jface.viewers.ICheckStateListener;
|
||||
import org.eclipse.swt.SWT;
|
||||
import org.eclipse.swt.events.ModifyEvent;
|
||||
import org.eclipse.swt.events.ModifyListener;
|
||||
import org.eclipse.swt.events.SelectionEvent;
|
||||
import org.eclipse.swt.events.SelectionListener;
|
||||
import org.eclipse.swt.widgets.Combo;
|
||||
import org.eclipse.swt.widgets.Composite;
|
||||
import org.eclipse.swt.widgets.Label;
|
||||
import org.eclipse.swt.widgets.Spinner;
|
||||
//import org.rosuda.JRI.Rengine;
|
||||
|
||||
import flintstones.application.perspective.framework.ui.interfaces.IProblemElementViewerOnSingleClick;
|
||||
import flintstones.application.perspective.framework.ui.viewer.ProblemElementViewer;
|
||||
//import flintstones.engine.R.R;
|
||||
//import flintstones.engine.R.provider.internal.REngineDefaultProvider;
|
||||
import flintstones.entity.method.phase.ui.PhaseMethodUI;
|
||||
import flintstones.entity.problemelement.entities.Criterion;
|
||||
import flintstones.entity.problemelement.entities.FakeProblemElement;
|
||||
import flintstones.entity.problemelement.entities.ProblemElement;
|
||||
import flintstones.helper.DoubleHelper;
|
||||
import flintstones.method.promethee.phase.gathering.PrometheeGathering;
|
||||
import flintstones.method.promethee.phase.gathering.viewer.ProblemElementViewerLabel;
|
||||
import flintstones.model.problemelement.service.IProblemElementService;
|
||||
import flintstones.model.ui.service.UiService;
|
||||
|
||||
public class PrometheeGatheringUI extends PhaseMethodUI
|
||||
implements IProblemElementViewerOnSingleClick, ICheckStateListener {
|
||||
|
||||
@Inject
|
||||
IEclipseContext context;
|
||||
|
||||
@Inject
|
||||
IProblemElementService problemService;
|
||||
|
||||
ProblemElementViewer criterionViewer;
|
||||
Label titleLabelParametersCriterion;
|
||||
Spinner spinnerQ;
|
||||
Spinner spinnerP;
|
||||
Spinner spinnerS;
|
||||
|
||||
Composite rowLabelPp;
|
||||
Composite rowLabelQq;
|
||||
Composite rowLabelS;
|
||||
|
||||
Combo comboBox;
|
||||
|
||||
Composite rowTypeData;
|
||||
int selectedIndex;
|
||||
boolean nextPhase;
|
||||
|
||||
ArrayList<PrometheeData> prometheeData;
|
||||
PrometheeGathering model;
|
||||
|
||||
@Override
|
||||
public void init() {
|
||||
model = (PrometheeGathering) this.getModel();
|
||||
model.loadData();
|
||||
|
||||
initData();
|
||||
|
||||
Composite base = this.getBaseComposite();
|
||||
UiService.setGridData(base, 9, 9, true, true);
|
||||
UiService.setGridLayout(base, 1);
|
||||
|
||||
Composite row1 = new Composite(base, 0);
|
||||
UiService.setGridData(row1, 9, 0, true, false);
|
||||
UiService.setGridLayout(row1, 1);
|
||||
|
||||
Label titleLabel = new Label(row1, SWT.NONE);
|
||||
titleLabel.setText("PROMETHEE GATHERING");
|
||||
UiService.setGridData(titleLabel, 9 ,9, true, false);
|
||||
UiService.setFont(titleLabel, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
Composite row2 = new Composite(base, 0);
|
||||
UiService.setGridData(row2, 9, 9, true, true);
|
||||
UiService.setGridLayout(row2, 1);
|
||||
|
||||
createRowImages(row2);
|
||||
|
||||
initBody(row2);
|
||||
|
||||
nextPhase();
|
||||
|
||||
}
|
||||
|
||||
public void initData() {
|
||||
selectedIndex = 0;
|
||||
nextPhase = true;
|
||||
prometheeData = new ArrayList<PrometheeData>();
|
||||
for (int i = 0; i < model.numberCriterions(); i++)
|
||||
prometheeData.add(new PrometheeData());
|
||||
}
|
||||
|
||||
public void createRowImages(Composite base) {
|
||||
Composite fotoRow = new Composite(base, 0);
|
||||
UiService.setGridData(fotoRow, 9, 9, true, true);
|
||||
UiService.setGridLayout(fotoRow, 6, true);
|
||||
|
||||
Label foto1 = new Label(fotoRow, 0);
|
||||
foto1.setImage(UiService.getIcon("promethee\\promethee_type1").createImage());
|
||||
UiService.setGridData(foto1, 9, 9, true, false);
|
||||
|
||||
Label foto2 = new Label(fotoRow, 0);
|
||||
foto2.setImage(UiService.getIcon("promethee\\promethee_type2").createImage());
|
||||
UiService.setGridData(foto2, 9, 9, true, false);
|
||||
|
||||
Label foto3 = new Label(fotoRow, 0);
|
||||
foto3.setImage(UiService.getIcon("promethee\\promethee_type3").createImage());
|
||||
UiService.setGridData(foto3, 9, 9, true, false);
|
||||
|
||||
Label foto4 = new Label(fotoRow, 0);
|
||||
foto4.setImage(UiService.getIcon("promethee\\promethee_type4").createImage());
|
||||
UiService.setGridData(foto4, 9, 9, true, false);
|
||||
|
||||
Label foto5 = new Label(fotoRow, 0);
|
||||
foto5.setImage(UiService.getIcon("promethee\\promethee_type5").createImage());
|
||||
UiService.setGridData(foto5, 9, 9, true, false);
|
||||
|
||||
Label foto6 = new Label(fotoRow, 0);
|
||||
foto6.setImage(UiService.getIcon("promethee\\promethee_type6").createImage());
|
||||
UiService.setGridData(foto6, 9, 9, true, false);
|
||||
|
||||
createTitleImages(fotoRow);
|
||||
}
|
||||
|
||||
public void createTitleImages(Composite base) {
|
||||
|
||||
Label title1Label = new Label(base, SWT.NONE);
|
||||
title1Label.setText("Type 1");
|
||||
UiService.setGridData(title1Label, 0, 9, false, false);
|
||||
UiService.setFont(title1Label, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
Label title2Label = new Label(base, SWT.NONE);
|
||||
title2Label.setText("Type 2");
|
||||
UiService.setGridData(title2Label, 0, 9, false, false);
|
||||
UiService.setFont(title2Label, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
Label title3Label = new Label(base, SWT.NONE);
|
||||
title3Label.setText("Type 3");
|
||||
UiService.setGridData(title3Label, 0, 9, false, false);
|
||||
UiService.setFont(title3Label, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
Label title4Label = new Label(base, SWT.NONE);
|
||||
title4Label.setText("Type 4");
|
||||
UiService.setGridData(title4Label, 0, 9, false, false);
|
||||
UiService.setFont(title4Label, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
Label title5Label = new Label(base, SWT.NONE);
|
||||
title5Label.setText("Type 5");
|
||||
UiService.setGridData(title5Label, 0, 9, false, false);
|
||||
UiService.setFont(title5Label, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
Label title6Label = new Label(base, SWT.NONE);
|
||||
title6Label.setText("Type 6");
|
||||
UiService.setGridData(title6Label, 0, 9, false, false);
|
||||
UiService.setFont(title6Label, UiService.FONT_SECTION_TITLE);
|
||||
}
|
||||
|
||||
public void initBody(Composite base) {
|
||||
// La otra mitad
|
||||
Composite rowMitadAbajo = new Composite(base, 0);
|
||||
UiService.setGridData(rowMitadAbajo, 9, 0, true, true);
|
||||
UiService.setGridLayout(rowMitadAbajo, 2);
|
||||
|
||||
// Criterions y datos.
|
||||
createColTreeView(rowMitadAbajo);
|
||||
|
||||
createColParametersPromethee(rowMitadAbajo);
|
||||
}
|
||||
|
||||
// Métodos para el Tree View
|
||||
private void createColTreeView(Composite base) {
|
||||
|
||||
Composite row = new Composite(base, 0);
|
||||
UiService.setGridData(row, 9, 9, true, true);
|
||||
UiService.setGridLayout(row, 1);
|
||||
|
||||
Label titleLabel = new Label(row, SWT.NONE);
|
||||
titleLabel.setText("Criterios");
|
||||
UiService.setGridData(titleLabel, 9, 9, true, false);
|
||||
UiService.setFont(titleLabel, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
// Criterion tree
|
||||
criterionViewer = getViewer(row, Criterion.Type, true);
|
||||
}
|
||||
|
||||
// Crea los botones y spinner para poder introducir los datos del problema
|
||||
private void createColParametersPromethee(Composite base) {
|
||||
Composite row = new Composite(base, 0);
|
||||
UiService.setGridData(row, 9, 9, true, true);
|
||||
UiService.setGridLayout(row, 1);
|
||||
|
||||
titleLabelParametersCriterion = new Label(row, SWT.NONE);
|
||||
titleLabelParametersCriterion.setText("Parametros de --------");
|
||||
UiService.setGridData(titleLabelParametersCriterion, 9, 9, true, false);
|
||||
UiService.setFont(titleLabelParametersCriterion, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
Composite row1 = new Composite(row, SWT.BORDER);
|
||||
UiService.setGridData(row1, 9, 9, true, true);
|
||||
UiService.setGridLayout(row1, 1);
|
||||
|
||||
comboBox = new Combo(row1, 0);
|
||||
UiService.setGridData(comboBox, -1, 9, false, false);
|
||||
comboBox.add("Type One");
|
||||
comboBox.add("Type Two");
|
||||
comboBox.add("Type three");
|
||||
comboBox.add("Type Four");
|
||||
comboBox.add("Type Five");
|
||||
comboBox.add("Type Six");
|
||||
comboBox.addSelectionListener(new SelectionListener() {
|
||||
|
||||
@Override
|
||||
public void widgetSelected(SelectionEvent e) {
|
||||
Combo comboBox = (Combo) e.getSource();
|
||||
|
||||
//Arrays.stream(rowTypeData.getChildren()).forEach(k -> k.dispose());
|
||||
//CreateComponentType(rowTypeData, comboBox.getSelectionIndex() + 1);
|
||||
//rowTypeData.layout();
|
||||
switch(comboBox.getSelectionIndex()) {
|
||||
case 0:
|
||||
rowLabelPp.setVisible(false);
|
||||
rowLabelQq.setVisible(false);
|
||||
rowLabelS.setVisible(false);
|
||||
break;
|
||||
case 1:
|
||||
rowLabelPp.setVisible(false);
|
||||
rowLabelQq.setVisible(true);
|
||||
rowLabelS.setVisible(false);
|
||||
break;
|
||||
case 2:
|
||||
rowLabelPp.setVisible(true);
|
||||
rowLabelQq.setVisible(false);
|
||||
rowLabelS.setVisible(false);
|
||||
break;
|
||||
case 3:
|
||||
case 4:
|
||||
rowLabelPp.setVisible(true);
|
||||
rowLabelQq.setVisible(true);
|
||||
rowLabelS.setVisible(false);
|
||||
break;
|
||||
case 5:
|
||||
rowLabelPp.setVisible(false);
|
||||
rowLabelQq.setVisible(false);
|
||||
rowLabelS.setVisible(true);
|
||||
break;
|
||||
}
|
||||
|
||||
prometheeData.get(selectedIndex).setTypeFunc(comboBox.getSelectionIndex() + 1);
|
||||
setParametersSelected();
|
||||
refreshUI();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void widgetDefaultSelected(SelectionEvent e) {
|
||||
// TODO Auto-generated method stub
|
||||
}
|
||||
});
|
||||
|
||||
rowTypeData = new Composite(row1, SWT.NONE);
|
||||
UiService.setGridData(rowTypeData, 9, 9, true, true);
|
||||
UiService.setGridLayout(rowTypeData, 1);
|
||||
CreateComponentType(rowTypeData, 1);
|
||||
rowLabelPp.setVisible(false);
|
||||
rowLabelQq.setVisible(false);
|
||||
rowLabelS.setVisible(false);
|
||||
}
|
||||
|
||||
private void CreateComponentType(Composite base, int type) {
|
||||
// P
|
||||
rowLabelPp = new Composite(base, 0);
|
||||
UiService.setGridData(rowLabelPp, 9, 9, true, false);
|
||||
UiService.setGridLayout(rowLabelPp, 2, true);
|
||||
Label labelPp = new Label(rowLabelPp, SWT.NONE);
|
||||
labelPp.setText("P:");
|
||||
spinnerP = new Spinner(rowLabelPp, SWT.BORDER);
|
||||
spinnerP.setDigits(3);
|
||||
spinnerP.setMinimum(Integer.MIN_VALUE);
|
||||
spinnerP.setMaximum(Integer.MAX_VALUE);
|
||||
//spinnerP.addModifyListener(mdfListener);
|
||||
spinnerP.addModifyListener(new ModifyListener() {
|
||||
|
||||
@Override
|
||||
public void modifyText(ModifyEvent e) {
|
||||
//saveParameters();
|
||||
switch (comboBox.getSelectionIndex()) {
|
||||
case 0:
|
||||
prometheeData.get(selectedIndex).setP(0);
|
||||
break;
|
||||
default:
|
||||
prometheeData.get(selectedIndex).setP(DoubleHelper.ParseDouble(spinnerP.getText()));
|
||||
}
|
||||
nextPhase();
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
// Q
|
||||
rowLabelQq = new Composite(base, 0);
|
||||
UiService.setGridData(rowLabelQq, 9, 9, true, false);
|
||||
UiService.setGridLayout(rowLabelQq, 2, true);
|
||||
Label labelQq = new Label(rowLabelQq, SWT.NONE);
|
||||
labelQq.setText("Q:");
|
||||
spinnerQ = new Spinner(rowLabelQq, SWT.BORDER);
|
||||
spinnerQ.setDigits(3);
|
||||
spinnerQ.setMinimum(Integer.MIN_VALUE);
|
||||
spinnerQ.setMaximum(Integer.MAX_VALUE);
|
||||
//spinnerQ.addModifyListener(mdfListener);
|
||||
spinnerQ.addModifyListener(new ModifyListener() {
|
||||
|
||||
@Override
|
||||
public void modifyText(ModifyEvent e) {
|
||||
//saveParameters();
|
||||
switch (comboBox.getSelectionIndex()) {
|
||||
case 0:
|
||||
prometheeData.get(selectedIndex).setQ(0);
|
||||
break;
|
||||
default:
|
||||
prometheeData.get(selectedIndex).setQ(DoubleHelper.ParseDouble(spinnerQ.getText()));
|
||||
}
|
||||
nextPhase();
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
// S
|
||||
rowLabelS = new Composite(base, 0);
|
||||
UiService.setGridData(rowLabelS, 9, 9, true, false);
|
||||
UiService.setGridLayout(rowLabelS, 2, true);
|
||||
Label labelS = new Label(rowLabelS, SWT.NONE);
|
||||
labelS.setText("S:");
|
||||
spinnerS = new Spinner(rowLabelS, SWT.BORDER);
|
||||
spinnerS.setDigits(3);
|
||||
spinnerS.setMinimum(Integer.MIN_VALUE);
|
||||
spinnerS.setMaximum(Integer.MAX_VALUE);
|
||||
spinnerS.addModifyListener(new ModifyListener() {
|
||||
|
||||
@Override
|
||||
public void modifyText(ModifyEvent e) {
|
||||
//saveParameters();
|
||||
switch (comboBox.getSelectionIndex()) {
|
||||
case 0:
|
||||
prometheeData.get(selectedIndex).setS(0);
|
||||
break;
|
||||
default:
|
||||
prometheeData.get(selectedIndex).setS(DoubleHelper.ParseDouble(spinnerS.getText()));
|
||||
}
|
||||
nextPhase();
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// Funión que nos devuelve el Viewer con los criterios
|
||||
private ProblemElementViewer getViewer(Composite parent, String type, boolean addParent) {
|
||||
|
||||
ProblemElementViewerLabel viewer = ContextInjectionFactory.make(ProblemElementViewerLabel.class, this.context);
|
||||
|
||||
if (addParent) {
|
||||
FakeProblemElement fakePE = new FakeProblemElement("");
|
||||
fakePE.as(type);
|
||||
viewer.useGlobalParent(fakePE);
|
||||
}
|
||||
|
||||
viewer.createControls(type, parent);
|
||||
viewer.addListener((IProblemElementViewerOnSingleClick) this);
|
||||
viewer.loadListeners();
|
||||
|
||||
UiService.setGridLayout(viewer.getTree().getTree(), 1);
|
||||
UiService.setGridData(viewer.getTree().getTree(), 9, 9, true, true);
|
||||
|
||||
return viewer;
|
||||
}
|
||||
|
||||
// Función con la que podemos controlar el funcionamiento del click en el Viewer
|
||||
public void problemElementViewerOnSingleClick(ProblemElement item) {
|
||||
// Seleccionado el fake parent.
|
||||
if (item.getCanonicalName().equals(""))
|
||||
return;
|
||||
|
||||
// Saving
|
||||
saveParameters();
|
||||
|
||||
String selectedCriterion = item.getName();
|
||||
titleLabelParametersCriterion.setText("Parametros de " + selectedCriterion);
|
||||
|
||||
for (int i = 0; i < model.numberCriterions(); i++) {
|
||||
if (model.getCriterionNames()[i].equals(selectedCriterion)) {
|
||||
selectedIndex = i;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
//Changing the spinner parameters.
|
||||
setParametersSelected();
|
||||
|
||||
refreshUI();
|
||||
}
|
||||
|
||||
public void saveParameters() {
|
||||
prometheeData.get(selectedIndex).setTypeFunc(comboBox.getSelectionIndex() + 1);
|
||||
|
||||
switch (comboBox.getSelectionIndex()) {
|
||||
case 0:
|
||||
prometheeData.get(selectedIndex).setP(0);
|
||||
prometheeData.get(selectedIndex).setQ(0);
|
||||
case 1:
|
||||
prometheeData.get(selectedIndex).setQ(DoubleHelper.ParseDouble(spinnerQ.getText()));
|
||||
break;
|
||||
case 2:
|
||||
prometheeData.get(selectedIndex).setP(DoubleHelper.ParseDouble(spinnerP.getText()));
|
||||
break;
|
||||
case 3:
|
||||
case 4:
|
||||
prometheeData.get(selectedIndex).setP(DoubleHelper.ParseDouble(spinnerP.getText()));
|
||||
prometheeData.get(selectedIndex).setQ(DoubleHelper.ParseDouble(spinnerQ.getText()));
|
||||
break;
|
||||
case 5:
|
||||
prometheeData.get(selectedIndex).setS(DoubleHelper.ParseDouble(spinnerS.getText()));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
private void setParametersSelected() {
|
||||
comboBox.select( prometheeData.get(selectedIndex).getTypeFunc() - 1);
|
||||
|
||||
spinnerP.setSelection( ChangeDoubleToInt(prometheeData.get(selectedIndex).getP(),spinnerP) );
|
||||
spinnerQ.setSelection( ChangeDoubleToInt(prometheeData.get(selectedIndex).getQ(),spinnerQ) );
|
||||
spinnerS.setSelection( ChangeDoubleToInt(prometheeData.get(selectedIndex).getS(),spinnerS) );
|
||||
|
||||
switch(comboBox.getSelectionIndex()) {
|
||||
case 0:
|
||||
rowLabelPp.setVisible(false);
|
||||
rowLabelQq.setVisible(false);
|
||||
rowLabelS.setVisible(false);
|
||||
break;
|
||||
case 1:
|
||||
rowLabelPp.setVisible(false);
|
||||
rowLabelQq.setVisible(true);
|
||||
rowLabelS.setVisible(false);
|
||||
break;
|
||||
case 2:
|
||||
rowLabelPp.setVisible(true);
|
||||
rowLabelQq.setVisible(false);
|
||||
rowLabelS.setVisible(false);
|
||||
break;
|
||||
case 3:
|
||||
case 4:
|
||||
rowLabelPp.setVisible(true);
|
||||
rowLabelQq.setVisible(true);
|
||||
rowLabelS.setVisible(false);
|
||||
break;
|
||||
case 5:
|
||||
rowLabelPp.setVisible(false);
|
||||
rowLabelQq.setVisible(false);
|
||||
rowLabelS.setVisible(true);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
private int ChangeDoubleToInt(double number, Spinner spinner) {
|
||||
double newNumber = number;
|
||||
newNumber *= Math.pow(10, spinner.getDigits());
|
||||
return (int) newNumber;
|
||||
}
|
||||
|
||||
private void nextPhase() {
|
||||
float[] p = new float[model.getCriterionNames().length];
|
||||
float[] q = new float[model.getCriterionNames().length];
|
||||
float[] s = new float[model.getCriterionNames().length];
|
||||
|
||||
int[] typeFunc = new int[model.getCriterionNames().length];
|
||||
|
||||
for(int i = 0; i < prometheeData.size(); i++) {
|
||||
p[i] = (float) prometheeData.get(i).getP();
|
||||
q[i] = (float) prometheeData.get(i).getQ();
|
||||
s[i] = (float) prometheeData.get(i).getS();
|
||||
|
||||
typeFunc[i] = prometheeData.get(i).getTypeFunc();
|
||||
}
|
||||
model.nextPhase(p, q, s, typeFunc);
|
||||
|
||||
}
|
||||
|
||||
public void checkStateChanged(CheckStateChangedEvent event) {
|
||||
refreshUI();
|
||||
}
|
||||
|
||||
public void refreshUI() {
|
||||
this.sendRefresh();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void refresh() {
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isForwardEnabled() {
|
||||
return nextPhase;
|
||||
}
|
||||
|
||||
}
|
||||
+33
@@ -0,0 +1,33 @@
|
||||
package flintstones.method.promethee.phase.gathering.viewer;
|
||||
|
||||
import javax.inject.Inject;
|
||||
|
||||
import org.eclipse.e4.core.contexts.ContextInjectionFactory;
|
||||
import org.eclipse.e4.core.contexts.IEclipseContext;
|
||||
import org.eclipse.jface.resource.ImageDescriptor;
|
||||
import org.eclipse.jface.viewers.DelegatingStyledCellLabelProvider.IStyledLabelProvider;
|
||||
|
||||
import flintstones.application.perspective.framework.ui.viewer.ProblemElementViewer;
|
||||
import flintstones.entity.problemelement.entities.ProblemElementHelper;
|
||||
import flintstones.method.promethee.phase.gathering.provider.ProblemElementLabelProvider;
|
||||
import flintstones.model.problemelement.service.IProblemElementService;
|
||||
import flintstones.model.ui.service.UiService;
|
||||
|
||||
public class ProblemElementViewerLabel extends ProblemElementViewer{
|
||||
|
||||
@Inject
|
||||
IProblemElementService pService;
|
||||
|
||||
@Inject
|
||||
IEclipseContext context;
|
||||
|
||||
@Override
|
||||
protected IStyledLabelProvider getLabelProvider(String type) {
|
||||
ImageDescriptor individualImage = UiService.getIcon(ProblemElementHelper.getImage(type, false));
|
||||
ImageDescriptor groupImage = UiService.getIcon(ProblemElementHelper.getImage(type, true));
|
||||
|
||||
ProblemElementLabelProvider provider = new ProblemElementLabelProvider(individualImage,groupImage);
|
||||
ContextInjectionFactory.inject(provider, context);
|
||||
return provider;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user