chainNames)
{
chainMenu.removeAll();
if (chainNames == null || chainNames.isEmpty())
{
return;
}
JMenuItem menuItem = new JMenuItem(
MessageManager.getString("label.all"));
menuItem.addActionListener(new ActionListener()
{
@Override
public void actionPerformed(ActionEvent evt)
{
allChainsSelected = true;
for (int i = 0; i < chainMenu.getItemCount(); i++)
{
if (chainMenu.getItem(i) instanceof JCheckBoxMenuItem)
{
((JCheckBoxMenuItem) chainMenu.getItem(i)).setSelected(true);
}
}
showSelectedChains();
allChainsSelected = false;
}
});
chainMenu.add(menuItem);
for (String chain : chainNames)
{
menuItem = new JCheckBoxMenuItem(chain, true);
menuItem.addItemListener(new ItemListener()
{
@Override
public void itemStateChanged(ItemEvent evt)
{
if (!allChainsSelected)
{
showSelectedChains();
}
}
});
chainMenu.add(menuItem);
}
}
abstract void showSelectedChains();
/**
* Action on selecting one of Jalview's registered colour schemes
*/
@Override
public void changeColour_actionPerformed(String colourSchemeName)
{
AlignmentI al = getAlignmentPanel().av.getAlignment();
ColourSchemeI cs = ColourSchemes.getInstance()
.getColourScheme(colourSchemeName, getAlignmentPanel().av, al,
null);
getBinding().setJalviewColourScheme(cs);
}
/**
* Builds the colour menu
*/
protected void buildColourMenu()
{
colourMenu.removeAll();
AlignmentI al = getAlignmentPanel().av.getAlignment();
/*
* add colour by sequence, by chain, by charge and cysteine
*/
colourMenu.add(seqColour);
colourMenu.add(chainColour);
colourMenu.add(chargeColour);
chargeColour.setEnabled(!al.isNucleotide());
/*
* add all 'simple' (per-residue) colour schemes registered to Jalview
*/
ButtonGroup itemGroup = ColourMenuHelper.addMenuItems(colourMenu, this,
al, true);
/*
* add 'colour by viewer' (menu item text is set in subclasses)
*/
viewerColour.setSelected(false);
viewerColour.addActionListener(new ActionListener()
{
@Override
public void actionPerformed(ActionEvent actionEvent)
{
viewerColour_actionPerformed(actionEvent);
}
});
colourMenu.add(viewerColour);
/*
* add 'set background colour'
*/
JMenuItem backGround = new JMenuItem();
backGround
.setText(MessageManager.getString("action.background_colour"));
backGround.addActionListener(new ActionListener()
{
@Override
public void actionPerformed(ActionEvent actionEvent)
{
background_actionPerformed(actionEvent);
}
});
colourMenu.add(backGround);
/*
* add colour buttons to a group so their selection is
* mutually exclusive (background colour is a separate option)
*/
itemGroup.add(seqColour);
itemGroup.add(chainColour);
itemGroup.add(chargeColour);
itemGroup.add(viewerColour);
}
/**
* Construct menu items
*/
protected void initMenus()
{
AAStructureBindingModel binding = getBinding();
seqColour = new JRadioButtonMenuItem();
seqColour.setText(MessageManager.getString("action.by_sequence"));
seqColour.setName(ViewerColour.BySequence.name());
seqColour.setSelected(binding.isColourBySequence());
seqColour.addActionListener(new ActionListener()
{
@Override
public void actionPerformed(ActionEvent actionEvent)
{
seqColour_actionPerformed(actionEvent);
}
});
chainColour = new JRadioButtonMenuItem();
chainColour.setText(MessageManager.getString("action.by_chain"));
chainColour.setName(ViewerColour.ByChain.name());
chainColour.addActionListener(new ActionListener()
{
@Override
public void actionPerformed(ActionEvent actionEvent)
{
chainColour_actionPerformed(actionEvent);
}
});
chargeColour = new JRadioButtonMenuItem();
chargeColour.setText(MessageManager.getString("label.charge_cysteine"));
chargeColour.setName(ViewerColour.ChargeCysteine.name());
chargeColour.addActionListener(new ActionListener()
{
@Override
public void actionPerformed(ActionEvent actionEvent)
{
chargeColour_actionPerformed(actionEvent);
}
});
viewerColour = new JRadioButtonMenuItem();
// text is set in overrides of this method
viewerColour.setName(ViewerColour.ByViewer.name());
viewerColour.setSelected(!binding.isColourBySequence());
if (_colourwith == null)
{
_colourwith = new Vector<>();
}
if (_alignwith == null)
{
_alignwith = new Vector<>();
}
ViewSelectionMenu seqColourBy = new ViewSelectionMenu(
MessageManager.getString("label.colour_by"), this, _colourwith,
new ItemListener()
{
@Override
public void itemStateChanged(ItemEvent e)
{
if (!seqColour.isSelected())
{
seqColour.doClick();
}
else
{
// update the Chimera display now.
seqColour_actionPerformed(null);
}
}
});
viewMenu.add(seqColourBy);
final ItemListener handler = new ItemListener()
{
@Override
public void itemStateChanged(ItemEvent e)
{
alignStructs.setEnabled(!_alignwith.isEmpty());
alignStructs.setToolTipText(MessageManager.formatMessage(
"label.align_structures_using_linked_alignment_views",
_alignwith.size()));
}
};
viewSelectionMenu = new ViewSelectionMenu(
MessageManager.getString("label.superpose_with"), this,
_alignwith, handler);
handler.itemStateChanged(null);
viewerActionMenu.add(viewSelectionMenu, 0);
viewerActionMenu.addMenuListener(new MenuListener()
{
@Override
public void menuSelected(MenuEvent e)
{
handler.itemStateChanged(null);
}
@Override
public void menuDeselected(MenuEvent e)
{
}
@Override
public void menuCanceled(MenuEvent e)
{
}
});
buildColourMenu();
}
@Override
public void setJalviewColourScheme(ColourSchemeI cs)
{
getBinding().setJalviewColourScheme(cs);
}
/**
* Sends commands to the structure viewer to superimpose structures based on
* currently associated alignments. May optionally return an error message for
* the operation.
*/
@Override
protected String alignStructs_actionPerformed(ActionEvent actionEvent)
{
return alignStructs_withAllAlignPanels();
}
protected String alignStructs_withAllAlignPanels()
{
if (getAlignmentPanel() == null)
{
return null;
}
if (_alignwith.size() == 0)
{
_alignwith.add(getAlignmentPanel());
}
String reply = null;
try
{
AlignmentI[] als = new Alignment[_alignwith.size()];
HiddenColumns[] alc = new HiddenColumns[_alignwith.size()];
int[] alm = new int[_alignwith.size()];
int a = 0;
for (AlignmentPanel alignPanel : _alignwith)
{
als[a] = alignPanel.av.getAlignment();
alm[a] = -1;
alc[a++] = alignPanel.av.getAlignment().getHiddenColumns();
}
reply = getBinding().superposeStructures(als, alm, alc);
if (reply != null)
{
String text = MessageManager
.formatMessage("error.superposition_failed", reply);
statusBar.setText(text);
}
} catch (Exception e)
{
StringBuffer sp = new StringBuffer();
for (AlignmentPanel alignPanel : _alignwith)
{
sp.append("'" + alignPanel.alignFrame.getTitle() + "' ");
}
Cache.log.info("Couldn't align structures with the " + sp.toString()
+ "associated alignment panels.", e);
}
return reply;
}
/**
* Opens a colour chooser dialog, and applies the chosen colour to the
* background of the structure viewer
*/
@Override
public void background_actionPerformed(ActionEvent actionEvent)
{
String ttl = MessageManager.getString("label.select_background_colour");
ColourChooserListener listener = new ColourChooserListener()
{
@Override
public void colourSelected(Color c)
{
getBinding().setBackgroundColour(c);
}
};
JalviewColourChooser.showColourChooser(this, ttl, null, listener);
}
@Override
public void viewerColour_actionPerformed(ActionEvent actionEvent)
{
if (viewerColour.isSelected())
{
// disable automatic sequence colouring.
getBinding().setColourBySequence(false);
}
}
@Override
public void chainColour_actionPerformed(ActionEvent actionEvent)
{
chainColour.setSelected(true);
getBinding().colourByChain();
}
@Override
public void chargeColour_actionPerformed(ActionEvent actionEvent)
{
chargeColour.setSelected(true);
getBinding().colourByCharge();
}
@Override
public void seqColour_actionPerformed(ActionEvent actionEvent)
{
AAStructureBindingModel binding = getBinding();
binding.setColourBySequence(seqColour.isSelected());
if (_colourwith == null)
{
_colourwith = new Vector<>();
}
if (binding.isColourBySequence())
{
if (!binding.isLoadingFromArchive())
{
if (_colourwith.size() == 0 && getAlignmentPanel() != null)
{
// Make the currently displayed alignment panel the associated view
_colourwith.add(getAlignmentPanel().alignFrame.alignPanel);
}
}
// Set the colour using the current view for the associated alignframe
for (AlignmentPanel alignPanel : _colourwith)
{
binding.colourBySequence(alignPanel);
}
seqColoursApplied = true;
}
}
@Override
public void pdbFile_actionPerformed(ActionEvent actionEvent)
{
// TODO: JAL-3048 not needed for Jalview-JS - save PDB file
JalviewFileChooser chooser = new JalviewFileChooser(
Cache.getProperty("LAST_DIRECTORY"));
chooser.setFileView(new JalviewFileView());
chooser.setDialogTitle(MessageManager.getString("label.save_pdb_file"));
chooser.setToolTipText(MessageManager.getString("action.save"));
int value = chooser.showSaveDialog(this);
if (value == JalviewFileChooser.APPROVE_OPTION)
{
BufferedReader in = null;
try
{
// TODO: cope with multiple PDB files in view
in = new BufferedReader(
new FileReader(getBinding().getStructureFiles()[0]));
File outFile = chooser.getSelectedFile();
PrintWriter out = new PrintWriter(new FileOutputStream(outFile));
String data;
while ((data = in.readLine()) != null)
{
if (!(data.indexOf("") > -1 || data.indexOf("
") > -1))
{
out.println(data);
}
}
out.close();
} catch (Exception ex)
{
ex.printStackTrace();
} finally
{
if (in != null)
{
try
{
in.close();
} catch (IOException e)
{
// ignore
}
}
}
}
}
@Override
public void viewMapping_actionPerformed(ActionEvent actionEvent)
{
CutAndPasteTransfer cap = new CutAndPasteTransfer();
try
{
cap.appendText(getBinding().printMappings());
} catch (OutOfMemoryError e)
{
new OOMWarning(
"composing sequence-structure alignments for display in text box.",
e);
cap.dispose();
return;
}
Desktop.addInternalFrame(cap,
MessageManager.getString("label.pdb_sequence_mapping"), 550,
600);
}
protected abstract String getViewerName();
/**
* Configures the title and menu items of the viewer panel.
*/
@Override
public void updateTitleAndMenus()
{
AAStructureBindingModel binding = getBinding();
if (binding.hasFileLoadingError())
{
repaint();
return;
}
setChainMenuItems(binding.getChainNames());
this.setTitle(binding.getViewerTitle(getViewerName(), true));
/*
* enable 'Superpose with' if more than one mapped structure
*/
viewSelectionMenu.setEnabled(false);
if (getBinding().getStructureFiles().length > 1
&& getBinding().getSequence().length > 1)
{
viewSelectionMenu.setEnabled(true);
}
/*
* Show action menu if it has any enabled items
*/
viewerActionMenu.setVisible(false);
for (int i = 0; i < viewerActionMenu.getItemCount(); i++)
{
if (viewerActionMenu.getItem(i).isEnabled())
{
viewerActionMenu.setVisible(true);
break;
}
}
if (!binding.isLoadingFromArchive())
{
seqColour_actionPerformed(null);
}
}
@Override
public String toString()
{
return getTitle();
}
@Override
public boolean hasMapping()
{
if (worker != null && (addingStructures || _started))
{
return false;
}
if (getBinding() == null)
{
if (_aps == null || _aps.size() == 0)
{
// viewer has been closed, but we did at some point run.
return true;
}
return false;
}
String[] pdbids = getBinding().getStructureFiles();
if (pdbids == null)
{
return false;
}
int p=0;
for (String pdbid:pdbids) {
StructureMapping sm[] = getBinding().getSsm().getMapping(pdbid);
if (sm!=null && sm.length>0 && sm[0]!=null) {
p++;
}
}
// only return true if there is a mapping for every structure file we have loaded
if (p == 0 || p != pdbids.length)
{
return false;
}
// and that coloring has been applied
return seqColoursApplied;
}
@Override
public void raiseViewer()
{
toFront();
}
}