seqAssociated.setSelected(acg.isSeqAssociated());
}
adjusting = true;
- Vector list = new Vector();
- int index = 1;
- for (int i = 0; i < av.getAlignment().getAlignmentAnnotation().length; i++)
- {
- String label = av.getAlignment().getAlignmentAnnotation()[i].label;
- if (!list.contains(label))
- list.addElement(label);
- else
- list.addElement(label + "_" + (index++));
- }
-
- annotations = new JComboBox(list);
+ annotations = new JComboBox(getAnnotationItems(seqAssociated.isSelected()));
threshold.addItem("No Threshold");
threshold.addItem("Above Threshold");
}
+ private Vector<String> getAnnotationItems(boolean isSeqAssociated) {
+ Vector<String> list = new Vector<String>();
+ int index = 1;
+ int[] anmap = new int[av.getAlignment().getAlignmentAnnotation().length];
+ boolean enableSeqAss=false;
+ for (int i = 0; i < av.getAlignment().getAlignmentAnnotation().length; i++)
+ {
+ if (av.getAlignment().getAlignmentAnnotation()[i].sequenceRef==null)
+ {
+ if (isSeqAssociated)
+ {
+ continue;
+ }
+ } else {
+ enableSeqAss=true;
+ }
+ String label = av.getAlignment().getAlignmentAnnotation()[i].label;
+ if (!list.contains(label))
+ {anmap[list.size()] = i;
+ list.addElement(label);
+
+ }else {
+ if (!isSeqAssociated) {
+ anmap[list.size()] = i;
+ list.addElement(label + "_" + (index++));
+ }
+ }
+ }
+ seqAssociated.setEnabled(enableSeqAss);
+ annmap = new int[list.size()];
+ System.arraycopy(anmap, 0, annmap, 0, annmap.length);
+ return list;
+ }
private void setDefaultMinMax()
{
minColour.setBackground(Cache.getDefaultColour("ANNOTATIONCOLOUR_MIN", Color.orange));
jPanel1.add(ok);
jPanel1.add(cancel);
- jPanel2.add(annotations);
+ jPanel2.add(annotations, "grow, wrap");
+ jPanel2.add(seqAssociated);
jPanel2.add(currentColours);
JPanel colpanel = new JPanel(new FlowLayout());
colpanel.setBackground(Color.white);
colpanel.add(minColour);
colpanel.add(maxColour);
jPanel2.add(colpanel, "wrap");
- jPanel2.add(seqAssociated, "wrap");
jPanel2.add(threshold);
jPanel2.add(defColours,"skip 1, wrap");
jPanel2.add(thresholdIsMin);
protected void seqAssociated_actionPerformed(ActionEvent arg0)
{
- changeColour();
+ adjusting=true;
+ String cursel = (String) annotations.getSelectedItem();
+ boolean isvalid=false,isseqs=seqAssociated.isSelected();
+ this.annotations.removeAllItems();
+ for (String anitem:getAnnotationItems(seqAssociated.isSelected()))
+ {
+ if (anitem.equals( cursel) || (isseqs && cursel.startsWith(anitem)))
+ {
+ isvalid=true;
+ cursel=anitem;
+ }
+ this.annotations.addItem(anitem);
+ }
+ adjusting=false;
+ if (isvalid) { this.annotations.setSelectedItem(cursel); } else {
+ if (annotations.getItemCount()>0) {
+ annotations.setSelectedIndex(0);
+ }
+ }
}
protected void resetColours_actionPerformed(ActionEvent arg0)
}
JComboBox annotations;
-
+ int[] annmap;
JPanel minColour = new JPanel();
JPanel maxColour = new JPanel();
return;
}
- currentAnnotation = av.getAlignment().getAlignmentAnnotation()[annotations
- .getSelectedIndex()];
+ currentAnnotation = av.getAlignment().getAlignmentAnnotation()[annmap[annotations
+ .getSelectedIndex()]];
int aboveThreshold = -1;
if (threshold.getSelectedItem().equals("Above Threshold"))