-/*\r
- * Jalview - A Sequence Alignment Editor and Viewer\r
- * Copyright (C) 2007 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
- *\r
- * This program is free software; you can redistribute it and/or\r
- * modify it under the terms of the GNU General Public License\r
- * as published by the Free Software Foundation; either version 2\r
- * of the License, or (at your option) any later version.\r
- *\r
- * This program is distributed in the hope that it will be useful,\r
- * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\r
- * GNU General Public License for more details.\r
- *\r
- * You should have received a copy of the GNU General Public License\r
- * along with this program; if not, write to the Free Software\r
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA\r
- */\r
-package jalview.gui;\r
-\r
-import java.util.*;\r
-\r
-import java.awt.*;\r
-import java.awt.event.*;\r
-import javax.swing.*;\r
-import javax.swing.event.*;\r
-\r
-import jalview.datamodel.*;\r
-import jalview.schemes.*;\r
-\r
-public class AnnotationColourChooser\r
- extends JPanel\r
-{\r
- JInternalFrame frame;\r
- AlignViewport av;\r
- AlignmentPanel ap;\r
- ColourSchemeI oldcs;\r
- Hashtable oldgroupColours;\r
- jalview.datamodel.AlignmentAnnotation currentAnnotation;\r
- boolean adjusting = false;\r
-\r
- public AnnotationColourChooser(AlignViewport av, AlignmentPanel ap)\r
- {\r
- oldcs = av.getGlobalColourScheme();\r
- if (av.alignment.getGroups() != null)\r
- {\r
- oldgroupColours = new Hashtable();\r
- Vector allGroups = ap.av.alignment.getGroups();\r
- SequenceGroup sg;\r
- for (int g = 0; g < allGroups.size(); g++)\r
- {\r
- sg = (SequenceGroup) allGroups.get(g);\r
- if (sg.cs != null)\r
- {\r
- oldgroupColours.put(sg, sg.cs);\r
- }\r
- }\r
- }\r
- this.av = av;\r
- this.ap = ap;\r
- frame = new JInternalFrame();\r
- frame.setContentPane(this);\r
- frame.setLayer(JLayeredPane.PALETTE_LAYER);\r
- Desktop.addInternalFrame(frame, "Colour by Annotation", 480, 145);\r
-\r
- try\r
- {\r
- jbInit();\r
- }\r
- catch (Exception ex)\r
- {}\r
-\r
- slider.addChangeListener(new ChangeListener()\r
- {\r
- public void stateChanged(ChangeEvent evt)\r
- {\r
- if (!adjusting)\r
- {\r
- thresholdValue.setText( ( (float) slider.getValue() / 1000f) + "");\r
- valueChanged();\r
- }\r
- }\r
- });\r
-\r
- if (av.alignment.getAlignmentAnnotation() == null)\r
- {\r
- return;\r
- }\r
-\r
- if (oldcs instanceof AnnotationColourGradient)\r
- {\r
- AnnotationColourGradient acg = (AnnotationColourGradient) oldcs;\r
- minColour.setBackground(acg.getMinColour());\r
- maxColour.setBackground(acg.getMaxColour());\r
- }\r
- else\r
- {\r
- minColour.setBackground(Color.orange);\r
- maxColour.setBackground(Color.red);\r
- }\r
-\r
- adjusting = true;\r
- for (int i = 0; i < av.alignment.getAlignmentAnnotation().length; i++)\r
- {\r
- if (av.alignment.getAlignmentAnnotation()[i].graph > 0)\r
- {\r
- annotations.addItem(av.alignment.getAlignmentAnnotation()[i].label);\r
- }\r
- }\r
-\r
- threshold.addItem("No Threshold");\r
- threshold.addItem("Above Threshold");\r
- threshold.addItem("Below Threshold");\r
-\r
- adjusting = false;\r
-\r
- changeColour();\r
-\r
- }\r
-\r
- public AnnotationColourChooser()\r
- {\r
- try\r
- {\r
- jbInit();\r
- }\r
- catch (Exception ex)\r
- {\r
- ex.printStackTrace();\r
- }\r
- }\r
-\r
- private void jbInit()\r
- throws Exception\r
- {\r
- minColour.setFont(new java.awt.Font("Verdana", Font.PLAIN, 11));\r
- minColour.setBorder(BorderFactory.createEtchedBorder());\r
- minColour.setPreferredSize(new Dimension(40, 20));\r
- minColour.setToolTipText("Minimum Colour");\r
- minColour.addMouseListener(new MouseAdapter()\r
- {\r
- public void mousePressed(MouseEvent e)\r
- {\r
- if (minColour.isEnabled())\r
- {\r
- minColour_actionPerformed();\r
- }\r
- }\r
- });\r
- maxColour.setFont(new java.awt.Font("Verdana", Font.PLAIN, 11));\r
- maxColour.setBorder(BorderFactory.createEtchedBorder());\r
- maxColour.setPreferredSize(new Dimension(40, 20));\r
- maxColour.setToolTipText("Maximum Colour");\r
- maxColour.addMouseListener(new MouseAdapter()\r
- {\r
- public void mousePressed(MouseEvent e)\r
- {\r
- if (maxColour.isEnabled())\r
- {\r
- maxColour_actionPerformed();\r
- }\r
- }\r
- });\r
- ok.setOpaque(false);\r
- ok.setText("OK");\r
- ok.addActionListener(new ActionListener()\r
- {\r
- public void actionPerformed(ActionEvent e)\r
- {\r
- ok_actionPerformed(e);\r
- }\r
- });\r
- cancel.setOpaque(false);\r
- cancel.setText("Cancel");\r
- cancel.addActionListener(new ActionListener()\r
- {\r
- public void actionPerformed(ActionEvent e)\r
- {\r
- cancel_actionPerformed(e);\r
- }\r
- });\r
- this.setLayout(borderLayout1);\r
- jPanel2.setLayout(flowLayout1);\r
- annotations.addActionListener(new ActionListener()\r
- {\r
- public void actionPerformed(ActionEvent e)\r
- {\r
- annotations_actionPerformed(e);\r
- }\r
- });\r
- jPanel1.setBackground(Color.white);\r
- jPanel2.setBackground(Color.white);\r
- threshold.addActionListener(new ActionListener()\r
- {\r
- public void actionPerformed(ActionEvent e)\r
- {\r
- threshold_actionPerformed(e);\r
- }\r
- });\r
- jPanel3.setLayout(flowLayout2);\r
- thresholdValue.addActionListener(new ActionListener()\r
- {\r
- public void actionPerformed(ActionEvent e)\r
- {\r
- thresholdValue_actionPerformed(e);\r
- }\r
- });\r
- slider.setPaintLabels(false);\r
- slider.setPaintTicks(true);\r
- slider.setBackground(Color.white);\r
- slider.setEnabled(false);\r
- slider.setOpaque(false);\r
- slider.setPreferredSize(new Dimension(150, 32));\r
- thresholdValue.setEnabled(false);\r
- thresholdValue.setColumns(10);\r
- jPanel3.setBackground(Color.white);\r
- currentColours.setFont(new java.awt.Font("Verdana", Font.PLAIN, 11));\r
- currentColours.setOpaque(false);\r
- currentColours.setText("Use Original Colours");\r
- currentColours.addActionListener(new ActionListener()\r
- {\r
- public void actionPerformed(ActionEvent e)\r
- {\r
- currentColours_actionPerformed(e);\r
- }\r
- });\r
- jPanel1.add(ok);\r
- jPanel1.add(cancel);\r
- jPanel2.add(annotations);\r
- jPanel2.add(currentColours);\r
- jPanel2.add(minColour);\r
- jPanel2.add(maxColour);\r
- this.add(jPanel3, java.awt.BorderLayout.CENTER);\r
- jPanel3.add(threshold);\r
- jPanel3.add(slider);\r
- jPanel3.add(thresholdValue);\r
- this.add(jPanel1, java.awt.BorderLayout.SOUTH);\r
- this.add(jPanel2, java.awt.BorderLayout.NORTH);\r
- }\r
-\r
- JComboBox annotations = new JComboBox();\r
- JPanel minColour = new JPanel();\r
- JPanel maxColour = new JPanel();\r
- JButton ok = new JButton();\r
- JButton cancel = new JButton();\r
- JPanel jPanel1 = new JPanel();\r
- JPanel jPanel2 = new JPanel();\r
- BorderLayout borderLayout1 = new BorderLayout();\r
- JComboBox threshold = new JComboBox();\r
- FlowLayout flowLayout1 = new FlowLayout();\r
- JPanel jPanel3 = new JPanel();\r
- FlowLayout flowLayout2 = new FlowLayout();\r
- JSlider slider = new JSlider();\r
- JTextField thresholdValue = new JTextField(20);\r
- JCheckBox currentColours = new JCheckBox();\r
-\r
- public void minColour_actionPerformed()\r
- {\r
- Color col = JColorChooser.showDialog(this,\r
- "Select Colour for Minimum Value",\r
- minColour.getBackground());\r
- if (col != null)\r
- {\r
- minColour.setBackground(col);\r
- }\r
- minColour.repaint();\r
- changeColour();\r
- }\r
-\r
- public void maxColour_actionPerformed()\r
- {\r
- Color col = JColorChooser.showDialog(this,\r
- "Select Colour for Maximum Value",\r
- maxColour.getBackground());\r
- if (col != null)\r
- {\r
- maxColour.setBackground(col);\r
- }\r
- maxColour.repaint();\r
- changeColour();\r
- }\r
-\r
- void changeColour()\r
- {\r
- // Check if combobox is still adjusting\r
- if (adjusting)\r
- {\r
- return;\r
- }\r
-\r
- // We removed the non-graph annotations when filling the combobox\r
- // so allow for them again here\r
- int nograph = 0, graph = -1;\r
- for (int i = 0; i < av.alignment.getAlignmentAnnotation().length; i++)\r
- {\r
- if (av.alignment.getAlignmentAnnotation()[i].graph == 0)\r
- {\r
- nograph++;\r
- }\r
- else\r
- {\r
- graph++;\r
- }\r
-\r
- if (graph == annotations.getSelectedIndex())\r
- {\r
- break;\r
- }\r
- }\r
-\r
- currentAnnotation = av.alignment.getAlignmentAnnotation()[graph + nograph];\r
-\r
- int aboveThreshold = -1;\r
- if (threshold.getSelectedItem().equals("Above Threshold"))\r
- {\r
- aboveThreshold = AnnotationColourGradient.ABOVE_THRESHOLD;\r
- }\r
- else if (threshold.getSelectedItem().equals("Below Threshold"))\r
- {\r
- aboveThreshold = AnnotationColourGradient.BELOW_THRESHOLD;\r
- }\r
-\r
- slider.setEnabled(true);\r
- thresholdValue.setEnabled(true);\r
-\r
- if (aboveThreshold == AnnotationColourGradient.NO_THRESHOLD)\r
- {\r
- slider.setEnabled(false);\r
- thresholdValue.setEnabled(false);\r
- thresholdValue.setText("");\r
- }\r
- else if (aboveThreshold != AnnotationColourGradient.NO_THRESHOLD &&\r
- currentAnnotation.threshold == null)\r
- {\r
- currentAnnotation.setThreshold(new jalview.datamodel.GraphLine\r
- ( (currentAnnotation.graphMax -\r
- currentAnnotation.graphMin) / 2f,\r
- "Threshold",\r
- Color.black));\r
- }\r
-\r
- if (aboveThreshold != AnnotationColourGradient.NO_THRESHOLD)\r
- {\r
- adjusting = true;\r
- float range = currentAnnotation.graphMax * 1000 -\r
- currentAnnotation.graphMin * 1000;\r
-\r
- slider.setMinimum( (int) (currentAnnotation.graphMin * 1000));\r
- slider.setMaximum( (int) (currentAnnotation.graphMax * 1000));\r
- slider.setValue( (int) (currentAnnotation.threshold.value * 1000));\r
- thresholdValue.setText(currentAnnotation.threshold.value + "");\r
- slider.setMajorTickSpacing( (int) (range / 10f));\r
- slider.setEnabled(true);\r
- thresholdValue.setEnabled(true);\r
- adjusting = false;\r
- }\r
-\r
- AnnotationColourGradient acg = null;\r
- if (currentColours.isSelected())\r
- {\r
- acg = new AnnotationColourGradient(\r
- currentAnnotation,\r
- av.getGlobalColourScheme(), aboveThreshold);\r
- }\r
- else\r
- {\r
- acg =\r
- new AnnotationColourGradient(\r
- currentAnnotation,\r
- minColour.getBackground(),\r
- maxColour.getBackground(),\r
- aboveThreshold);\r
- }\r
-\r
- av.setGlobalColourScheme(acg);\r
-\r
- if (av.alignment.getGroups() != null)\r
- {\r
- Vector allGroups = ap.av.alignment.getGroups();\r
- SequenceGroup sg;\r
- for (int g = 0; g < allGroups.size(); g++)\r
- {\r
- sg = (SequenceGroup) allGroups.get(g);\r
-\r
- if (sg.cs == null)\r
- {\r
- continue;\r
- }\r
-\r
- if (currentColours.isSelected())\r
- {\r
- sg.cs = new AnnotationColourGradient(\r
- currentAnnotation,\r
- sg.cs, aboveThreshold);\r
- }\r
- else\r
- {\r
- sg.cs = new AnnotationColourGradient(\r
- currentAnnotation,\r
- minColour.getBackground(),\r
- maxColour.getBackground(),\r
- aboveThreshold);\r
- }\r
-\r
- }\r
- }\r
-\r
- ap.repaint();\r
- }\r
-\r
- public void ok_actionPerformed(ActionEvent e)\r
- {\r
- changeColour();\r
- try\r
- {\r
- frame.setClosed(true);\r
- }\r
- catch (Exception ex)\r
- {}\r
- }\r
-\r
- public void cancel_actionPerformed(ActionEvent e)\r
- {\r
- reset();\r
- try\r
- {\r
- frame.setClosed(true);\r
- }\r
- catch (Exception ex)\r
- {}\r
- }\r
-\r
- void reset()\r
- {\r
- av.setGlobalColourScheme(oldcs);\r
- if (av.alignment.getGroups() != null)\r
- {\r
- Vector allGroups = ap.av.alignment.getGroups();\r
- SequenceGroup sg;\r
- for (int g = 0; g < allGroups.size(); g++)\r
- {\r
- sg = (SequenceGroup) allGroups.get(g);\r
- sg.cs = (ColourSchemeI) oldgroupColours.get(sg);\r
- }\r
- }\r
- }\r
-\r
- public void thresholdCheck_actionPerformed(ActionEvent e)\r
- {\r
- changeColour();\r
- }\r
-\r
- public void annotations_actionPerformed(ActionEvent e)\r
- {\r
- changeColour();\r
- }\r
-\r
- public void threshold_actionPerformed(ActionEvent e)\r
- {\r
- changeColour();\r
- }\r
-\r
- public void thresholdValue_actionPerformed(ActionEvent e)\r
- {\r
- try\r
- {\r
- float f = Float.parseFloat(thresholdValue.getText());\r
- slider.setValue( (int) (f * 1000));\r
- }\r
- catch (NumberFormatException ex)\r
- {}\r
- }\r
-\r
- public void valueChanged()\r
- {\r
- if (currentColours.isSelected()\r
- && ! (av.getGlobalColourScheme() instanceof AnnotationColourGradient))\r
- {\r
- changeColour();\r
- }\r
-\r
- currentAnnotation.threshold.value = (float) slider.getValue() / 1000f;\r
- ap.repaint();\r
- }\r
-\r
- public void currentColours_actionPerformed(ActionEvent e)\r
- {\r
- if (currentColours.isSelected())\r
- {\r
- reset();\r
- }\r
-\r
- maxColour.setEnabled(!currentColours.isSelected());\r
- minColour.setEnabled(!currentColours.isSelected());\r
-\r
- changeColour();\r
- }\r
-\r
-}\r
+/*
+ * Jalview - A Sequence Alignment Editor and Viewer (Version 2.5)
+ * Copyright (C) 2010 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle
+ *
+ * This file is part of Jalview.
+ *
+ * Jalview is free software: you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
+ *
+ * Jalview is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty
+ * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ * PURPOSE. See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along with Jalview. If not, see <http://www.gnu.org/licenses/>.
+ */
+package jalview.gui;
+
+import java.util.*;
+
+import java.awt.*;
+import java.awt.event.*;
+import javax.swing.*;
+import javax.swing.event.*;
+
+import jalview.datamodel.*;
+import jalview.schemes.*;
+import java.awt.Dimension;
+
+public class AnnotationColourChooser extends JPanel
+{
+ JInternalFrame frame;
+
+ AlignViewport av;
+
+ AlignmentPanel ap;
+
+ ColourSchemeI oldcs;
+
+ Hashtable oldgroupColours;
+
+ jalview.datamodel.AlignmentAnnotation currentAnnotation;
+
+ boolean adjusting = false;
+
+ public AnnotationColourChooser(AlignViewport av, final AlignmentPanel ap)
+ {
+ oldcs = av.getGlobalColourScheme();
+ if (av.alignment.getGroups() != null)
+ {
+ oldgroupColours = new Hashtable();
+ Vector allGroups = ap.av.alignment.getGroups();
+ SequenceGroup sg;
+ for (int g = 0; g < allGroups.size(); g++)
+ {
+ sg = (SequenceGroup) allGroups.get(g);
+ if (sg.cs != null)
+ {
+ oldgroupColours.put(sg, sg.cs);
+ }
+ }
+ }
+ this.av = av;
+ this.ap = ap;
+ frame = new JInternalFrame();
+ frame.setContentPane(this);
+ frame.setLayer(JLayeredPane.PALETTE_LAYER);
+ Desktop.addInternalFrame(frame, "Colour by Annotation", 480, 145);
+
+ slider.addChangeListener(new ChangeListener()
+ {
+ public void stateChanged(ChangeEvent evt)
+ {
+ if (!adjusting)
+ {
+ thresholdValue.setText(((float) slider.getValue() / 1000f) + "");
+ valueChanged();
+ }
+ }
+ });
+ slider.addMouseListener(new MouseAdapter()
+ {
+ public void mouseReleased(MouseEvent evt)
+ {
+ ap.paintAlignment(true);
+ }
+ });
+
+ if (av.alignment.getAlignmentAnnotation() == null)
+ {
+ return;
+ }
+
+ if (oldcs instanceof AnnotationColourGradient)
+ {
+ AnnotationColourGradient acg = (AnnotationColourGradient) oldcs;
+ minColour.setBackground(acg.getMinColour());
+ maxColour.setBackground(acg.getMaxColour());
+ }
+ else
+ {
+ minColour.setBackground(Color.orange);
+ maxColour.setBackground(Color.red);
+ }
+
+ adjusting = true;
+ Vector list = new Vector();
+ int index = 1;
+ for (int i = 0; i < av.alignment.getAlignmentAnnotation().length; i++)
+ {
+ String label = av.alignment.getAlignmentAnnotation()[i].label;
+ if (!list.contains(label))
+ list.addElement(label);
+ else
+ list.addElement(label + "_" + (index++));
+ }
+
+ annotations = new JComboBox(list);
+
+ threshold.addItem("No Threshold");
+ threshold.addItem("Above Threshold");
+ threshold.addItem("Below Threshold");
+
+ try
+ {
+ jbInit();
+ } catch (Exception ex)
+ {
+ }
+
+ adjusting = false;
+
+ changeColour();
+
+ }
+
+ public AnnotationColourChooser()
+ {
+ try
+ {
+ jbInit();
+ } catch (Exception ex)
+ {
+ ex.printStackTrace();
+ }
+ }
+
+ private void jbInit() throws Exception
+ {
+ minColour.setFont(new java.awt.Font("Verdana", Font.PLAIN, 11));
+ minColour.setBorder(BorderFactory.createEtchedBorder());
+ minColour.setPreferredSize(new Dimension(40, 20));
+ minColour.setToolTipText("Minimum Colour");
+ minColour.addMouseListener(new MouseAdapter()
+ {
+ public void mousePressed(MouseEvent e)
+ {
+ if (minColour.isEnabled())
+ {
+ minColour_actionPerformed();
+ }
+ }
+ });
+ maxColour.setFont(new java.awt.Font("Verdana", Font.PLAIN, 11));
+ maxColour.setBorder(BorderFactory.createEtchedBorder());
+ maxColour.setPreferredSize(new Dimension(40, 20));
+ maxColour.setToolTipText("Maximum Colour");
+ maxColour.addMouseListener(new MouseAdapter()
+ {
+ public void mousePressed(MouseEvent e)
+ {
+ if (maxColour.isEnabled())
+ {
+ maxColour_actionPerformed();
+ }
+ }
+ });
+ ok.setOpaque(false);
+ ok.setText("OK");
+ ok.addActionListener(new ActionListener()
+ {
+ public void actionPerformed(ActionEvent e)
+ {
+ ok_actionPerformed(e);
+ }
+ });
+ cancel.setOpaque(false);
+ cancel.setText("Cancel");
+ cancel.addActionListener(new ActionListener()
+ {
+ public void actionPerformed(ActionEvent e)
+ {
+ cancel_actionPerformed(e);
+ }
+ });
+ this.setLayout(borderLayout1);
+ jPanel2.setLayout(flowLayout1);
+ annotations.addActionListener(new ActionListener()
+ {
+ public void actionPerformed(ActionEvent e)
+ {
+ annotations_actionPerformed(e);
+ }
+ });
+ jPanel1.setBackground(Color.white);
+ jPanel2.setBackground(Color.white);
+ threshold.addActionListener(new ActionListener()
+ {
+ public void actionPerformed(ActionEvent e)
+ {
+ threshold_actionPerformed(e);
+ }
+ });
+ jPanel3.setLayout(flowLayout2);
+ thresholdValue.addActionListener(new ActionListener()
+ {
+ public void actionPerformed(ActionEvent e)
+ {
+ thresholdValue_actionPerformed(e);
+ }
+ });
+ slider.setPaintLabels(false);
+ slider.setPaintTicks(true);
+ slider.setBackground(Color.white);
+ slider.setEnabled(false);
+ slider.setOpaque(false);
+ slider.setPreferredSize(new Dimension(100, 32));
+ thresholdValue.setEnabled(false);
+ thresholdValue.setColumns(7);
+ jPanel3.setBackground(Color.white);
+ currentColours.setFont(new java.awt.Font("Verdana", Font.PLAIN, 11));
+ currentColours.setOpaque(false);
+ currentColours.setText("Use Original Colours");
+ currentColours.addActionListener(new ActionListener()
+ {
+ public void actionPerformed(ActionEvent e)
+ {
+ currentColours_actionPerformed(e);
+ }
+ });
+ thresholdIsMin.setBackground(Color.white);
+ thresholdIsMin.setText("Threshold is Min/Max");
+ thresholdIsMin.addActionListener(new ActionListener()
+ {
+ public void actionPerformed(ActionEvent actionEvent)
+ {
+ thresholdIsMin_actionPerformed(actionEvent);
+ }
+ });
+ jPanel1.add(ok);
+ jPanel1.add(cancel);
+ jPanel2.add(annotations);
+ jPanel2.add(currentColours);
+ jPanel2.add(minColour);
+ jPanel2.add(maxColour);
+ this.add(jPanel3, java.awt.BorderLayout.CENTER);
+ jPanel3.add(threshold);
+ jPanel3.add(slider);
+ jPanel3.add(thresholdValue);
+ jPanel3.add(thresholdIsMin);
+ this.add(jPanel1, java.awt.BorderLayout.SOUTH);
+ this.add(jPanel2, java.awt.BorderLayout.NORTH);
+ }
+
+ JComboBox annotations;
+
+ JPanel minColour = new JPanel();
+
+ JPanel maxColour = new JPanel();
+
+ JButton ok = new JButton();
+
+ JButton cancel = new JButton();
+
+ JPanel jPanel1 = new JPanel();
+
+ JPanel jPanel2 = new JPanel();
+
+ BorderLayout borderLayout1 = new BorderLayout();
+
+ JComboBox threshold = new JComboBox();
+
+ FlowLayout flowLayout1 = new FlowLayout();
+
+ JPanel jPanel3 = new JPanel();
+
+ FlowLayout flowLayout2 = new FlowLayout();
+
+ JSlider slider = new JSlider();
+
+ JTextField thresholdValue = new JTextField(20);
+
+ JCheckBox currentColours = new JCheckBox();
+
+ JCheckBox thresholdIsMin = new JCheckBox();
+
+ public void minColour_actionPerformed()
+ {
+ Color col = JColorChooser.showDialog(this,
+ "Select Colour for Minimum Value", minColour.getBackground());
+ if (col != null)
+ {
+ minColour.setBackground(col);
+ }
+ minColour.repaint();
+ changeColour();
+ }
+
+ public void maxColour_actionPerformed()
+ {
+ Color col = JColorChooser.showDialog(this,
+ "Select Colour for Maximum Value", maxColour.getBackground());
+ if (col != null)
+ {
+ maxColour.setBackground(col);
+ }
+ maxColour.repaint();
+ changeColour();
+ }
+
+ void changeColour()
+ {
+ // Check if combobox is still adjusting
+ if (adjusting)
+ {
+ return;
+ }
+
+ currentAnnotation = av.alignment.getAlignmentAnnotation()[annotations
+ .getSelectedIndex()];
+
+ int aboveThreshold = -1;
+ if (threshold.getSelectedItem().equals("Above Threshold"))
+ {
+ aboveThreshold = AnnotationColourGradient.ABOVE_THRESHOLD;
+ }
+ else if (threshold.getSelectedItem().equals("Below Threshold"))
+ {
+ aboveThreshold = AnnotationColourGradient.BELOW_THRESHOLD;
+ }
+
+ slider.setEnabled(true);
+ thresholdValue.setEnabled(true);
+
+ if (aboveThreshold == AnnotationColourGradient.NO_THRESHOLD)
+ {
+ slider.setEnabled(false);
+ thresholdValue.setEnabled(false);
+ thresholdValue.setText("");
+ }
+ else if (aboveThreshold != AnnotationColourGradient.NO_THRESHOLD
+ && currentAnnotation.threshold == null)
+ {
+ currentAnnotation
+ .setThreshold(new jalview.datamodel.GraphLine(
+ (currentAnnotation.graphMax - currentAnnotation.graphMin) / 2f,
+ "Threshold", Color.black));
+ }
+
+ if (aboveThreshold != AnnotationColourGradient.NO_THRESHOLD)
+ {
+ adjusting = true;
+ float range = currentAnnotation.graphMax * 1000
+ - currentAnnotation.graphMin * 1000;
+
+ slider.setMinimum((int) (currentAnnotation.graphMin * 1000));
+ slider.setMaximum((int) (currentAnnotation.graphMax * 1000));
+ slider.setValue((int) (currentAnnotation.threshold.value * 1000));
+ thresholdValue.setText(currentAnnotation.threshold.value + "");
+ slider.setMajorTickSpacing((int) (range / 10f));
+ slider.setEnabled(true);
+ thresholdValue.setEnabled(true);
+ adjusting = false;
+ }
+
+ AnnotationColourGradient acg = null;
+ if (currentColours.isSelected())
+ {
+ acg = new AnnotationColourGradient(currentAnnotation, av
+ .getGlobalColourScheme(), aboveThreshold);
+ }
+ else
+ {
+ acg = new AnnotationColourGradient(currentAnnotation, minColour
+ .getBackground(), maxColour.getBackground(), aboveThreshold);
+ }
+
+ if (currentAnnotation.graphMin == 0f
+ && currentAnnotation.graphMax == 0f)
+ {
+ acg.predefinedColours = true;
+ }
+
+ acg.thresholdIsMinMax = thresholdIsMin.isSelected();
+
+ av.setGlobalColourScheme(acg);
+
+ if (av.alignment.getGroups() != null)
+ {
+ Vector allGroups = ap.av.alignment.getGroups();
+ SequenceGroup sg;
+ for (int g = 0; g < allGroups.size(); g++)
+ {
+ sg = (SequenceGroup) allGroups.get(g);
+
+ if (sg.cs == null)
+ {
+ continue;
+ }
+
+ if (currentColours.isSelected())
+ {
+ sg.cs = new AnnotationColourGradient(currentAnnotation, sg.cs,
+ aboveThreshold);
+ }
+ else
+ {
+ sg.cs = new AnnotationColourGradient(currentAnnotation, minColour
+ .getBackground(), maxColour.getBackground(),
+ aboveThreshold);
+ }
+
+ }
+ }
+
+ ap.paintAlignment(false);
+ }
+
+ public void ok_actionPerformed(ActionEvent e)
+ {
+ changeColour();
+ try
+ {
+ frame.setClosed(true);
+ } catch (Exception ex)
+ {
+ }
+ }
+
+ public void cancel_actionPerformed(ActionEvent e)
+ {
+ reset();
+ try
+ {
+ frame.setClosed(true);
+ } catch (Exception ex)
+ {
+ }
+ }
+
+ void reset()
+ {
+ av.setGlobalColourScheme(oldcs);
+ if (av.alignment.getGroups() != null)
+ {
+ Vector allGroups = ap.av.alignment.getGroups();
+ SequenceGroup sg;
+ for (int g = 0; g < allGroups.size(); g++)
+ {
+ sg = (SequenceGroup) allGroups.get(g);
+ sg.cs = (ColourSchemeI) oldgroupColours.get(sg);
+ }
+ }
+ }
+
+ public void thresholdCheck_actionPerformed(ActionEvent e)
+ {
+ changeColour();
+ }
+
+ public void annotations_actionPerformed(ActionEvent e)
+ {
+ changeColour();
+ }
+
+ public void threshold_actionPerformed(ActionEvent e)
+ {
+ changeColour();
+ }
+
+ public void thresholdValue_actionPerformed(ActionEvent e)
+ {
+ try
+ {
+ float f = Float.parseFloat(thresholdValue.getText());
+ slider.setValue((int) (f * 1000));
+ } catch (NumberFormatException ex)
+ {
+ }
+ }
+
+ public void valueChanged()
+ {
+ if (currentColours.isSelected()
+ && !(av.getGlobalColourScheme() instanceof AnnotationColourGradient))
+ {
+ changeColour();
+ }
+
+ currentAnnotation.threshold.value = (float) slider.getValue() / 1000f;
+ ap.paintAlignment(false);
+ }
+
+ public void currentColours_actionPerformed(ActionEvent e)
+ {
+ if (currentColours.isSelected())
+ {
+ reset();
+ }
+
+ maxColour.setEnabled(!currentColours.isSelected());
+ minColour.setEnabled(!currentColours.isSelected());
+
+ changeColour();
+ }
+
+ public void thresholdIsMin_actionPerformed(ActionEvent actionEvent)
+ {
+ changeColour();
+ }
+
+}