2 * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
3 * Copyright (C) $$Year-Rel$$ The Jalview Authors
5 * This file is part of Jalview.
7 * Jalview is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation, either version 3
10 * of the License, or (at your option) any later version.
12 * Jalview is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty
14 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with Jalview. If not, see <http://www.gnu.org/licenses/>.
19 * The Jalview Authors are detailed in the 'AUTHORS' file.
23 import jalview.datamodel.PDBEntry;
24 import jalview.datamodel.SequenceI;
25 import jalview.gui.AlignmentPanel;
26 import jalview.gui.Desktop;
27 import jalview.gui.JvOptionPane;
28 import jalview.gui.OOMWarning;
29 import jalview.gui.UserDefinedColours;
30 import jalview.io.DataSourceType;
31 import jalview.io.JalviewFileChooser;
32 import jalview.io.JalviewFileView;
33 import jalview.schemes.BuriedColourScheme;
34 import jalview.schemes.HelixColourScheme;
35 import jalview.schemes.HydrophobicColourScheme;
36 import jalview.schemes.StrandColourScheme;
37 import jalview.schemes.TaylorColourScheme;
38 import jalview.schemes.TurnColourScheme;
39 import jalview.schemes.UserColourScheme;
40 import jalview.schemes.ZappoColourScheme;
41 import jalview.util.MessageManager;
42 import jalview.ws.ebi.EBIFetchClient;
44 import java.awt.Color;
45 import java.awt.event.ActionEvent;
46 import java.awt.event.ActionListener;
47 import java.awt.event.ItemEvent;
48 import java.awt.event.ItemListener;
49 import java.awt.event.KeyAdapter;
50 import java.awt.event.KeyEvent;
51 import java.awt.event.MouseAdapter;
52 import java.awt.event.MouseEvent;
53 import java.io.BufferedReader;
55 import java.io.FileOutputStream;
56 import java.io.FileReader;
57 import java.io.PrintWriter;
60 import javax.swing.ButtonGroup;
61 import javax.swing.JCheckBoxMenuItem;
62 import javax.swing.JColorChooser;
63 import javax.swing.JInternalFrame;
64 import javax.swing.JMenu;
65 import javax.swing.JMenuBar;
66 import javax.swing.JMenuItem;
67 import javax.swing.JRadioButtonMenuItem;
69 public class PDBViewer extends JInternalFrame implements Runnable
73 * The associated sequence in an alignment
85 DataSourceType protocol;
89 public PDBViewer(PDBEntry pdbentry, SequenceI[] seq, String[] chains,
90 AlignmentPanel ap, DataSourceType protocol)
92 this.pdbentry = pdbentry;
96 this.protocol = protocol;
101 } catch (Exception ex)
103 ex.printStackTrace();
106 StringBuffer title = new StringBuffer(seq[0].getName() + ":"
107 + pdbentry.getFile());
109 pdbcanvas = new PDBCanvas();
111 setContentPane(pdbcanvas);
113 if (pdbentry.getFile() != null)
117 tmpPDBFile = pdbentry.getFile();
118 PDBfile pdbfile = new PDBfile(false, false, false, tmpPDBFile,
119 DataSourceType.FILE);
121 pdbcanvas.init(pdbentry, seq, chains, ap, protocol);
123 } catch (java.io.IOException ex)
125 ex.printStackTrace();
130 Thread worker = new Thread(this);
134 String method = (String) pdbentry.getProperty("method");
137 title.append(" Method: ");
138 title.append(method);
140 String ch = (String) pdbentry.getProperty("chains");
143 title.append(" Chain:");
146 Desktop.addInternalFrame(this, title.toString(), 400, 400);
154 EBIFetchClient ebi = new EBIFetchClient();
155 String query = "pdb:" + pdbentry.getId();
156 pdbentry.setFile(ebi.fetchDataAsFile(query, "default", "xml")
159 if (pdbentry.getFile() != null)
161 pdbcanvas.init(pdbentry, seq, chains, ap, protocol);
163 } catch (Exception ex)
165 pdbcanvas.errorMessage = "Error retrieving file: " + pdbentry.getId();
166 ex.printStackTrace();
170 private void jbInit() throws Exception
172 this.addKeyListener(new KeyAdapter()
175 public void keyPressed(KeyEvent evt)
177 pdbcanvas.keyPressed(evt);
181 this.setJMenuBar(jMenuBar1);
182 fileMenu.setText(MessageManager.getString("action.file"));
183 coloursMenu.setText(MessageManager.getString("label.colours"));
184 saveMenu.setActionCommand(MessageManager.getString("action.save_image"));
185 saveMenu.setText(MessageManager.getString("action.save_as"));
187 png.addActionListener(new ActionListener()
190 public void actionPerformed(ActionEvent e)
192 png_actionPerformed(e);
196 eps.addActionListener(new ActionListener()
199 public void actionPerformed(ActionEvent e)
201 eps_actionPerformed(e);
204 mapping.setText(MessageManager.getString("label.view_mapping"));
205 mapping.addActionListener(new ActionListener()
208 public void actionPerformed(ActionEvent e)
210 mapping_actionPerformed(e);
213 wire.setText(MessageManager.getString("label.wireframe"));
214 wire.addActionListener(new ActionListener()
217 public void actionPerformed(ActionEvent e)
219 wire_actionPerformed(e);
222 depth.setSelected(true);
223 depth.setText(MessageManager.getString("label.depthcue"));
224 depth.addActionListener(new ActionListener()
227 public void actionPerformed(ActionEvent e)
229 depth_actionPerformed(e);
232 zbuffer.setSelected(true);
233 zbuffer.setText(MessageManager.getString("label.z_buffering"));
234 zbuffer.addActionListener(new ActionListener()
237 public void actionPerformed(ActionEvent e)
239 zbuffer_actionPerformed(e);
242 charge.setText(MessageManager.getString("label.charge_cysteine"));
243 charge.addActionListener(new ActionListener()
246 public void actionPerformed(ActionEvent e)
248 charge_actionPerformed(e);
251 chain.setText(MessageManager.getString("action.by_chain"));
252 chain.addActionListener(new ActionListener()
255 public void actionPerformed(ActionEvent e)
257 chain_actionPerformed(e);
260 seqButton.setSelected(true);
261 seqButton.setText(MessageManager.getString("action.by_sequence"));
262 seqButton.addActionListener(new ActionListener()
265 public void actionPerformed(ActionEvent e)
267 seqButton_actionPerformed(e);
270 allchains.setSelected(true);
271 allchains.setText(MessageManager.getString("label.show_all_chains"));
272 allchains.addItemListener(new ItemListener()
275 public void itemStateChanged(ItemEvent e)
277 allchains_itemStateChanged(e);
280 zappo.setText(MessageManager.getString("label.colourScheme_zappo"));
281 zappo.addActionListener(new ActionListener()
284 public void actionPerformed(ActionEvent e)
286 zappo_actionPerformed(e);
289 taylor.setText(MessageManager.getString("label.colourScheme_taylor"));
290 taylor.addActionListener(new ActionListener()
293 public void actionPerformed(ActionEvent e)
295 taylor_actionPerformed(e);
298 hydro.setText(MessageManager
299 .getString("label.colourScheme_hydrophobic"));
300 hydro.addActionListener(new ActionListener()
303 public void actionPerformed(ActionEvent e)
305 hydro_actionPerformed(e);
308 helix.setText(MessageManager
309 .getString("label.colourScheme_helix_propensity"));
310 helix.addActionListener(new ActionListener()
313 public void actionPerformed(ActionEvent e)
315 helix_actionPerformed(e);
318 strand.setText(MessageManager
319 .getString("label.colourScheme_strand_propensity"));
320 strand.addActionListener(new ActionListener()
323 public void actionPerformed(ActionEvent e)
325 strand_actionPerformed(e);
328 turn.setText(MessageManager
329 .getString("label.colourScheme_turn_propensity"));
330 turn.addActionListener(new ActionListener()
333 public void actionPerformed(ActionEvent e)
335 turn_actionPerformed(e);
338 buried.setText(MessageManager
339 .getString("label.colourScheme_buried_index"));
340 buried.addActionListener(new ActionListener()
343 public void actionPerformed(ActionEvent e)
345 buried_actionPerformed(e);
348 user.setText(MessageManager.getString("action.user_defined"));
349 user.addActionListener(new ActionListener()
352 public void actionPerformed(ActionEvent e)
354 user_actionPerformed(e);
357 viewMenu.setText(MessageManager.getString("action.view"));
359 .setText(MessageManager.getString("action.background_colour"));
360 background.addActionListener(new ActionListener()
363 public void actionPerformed(ActionEvent e)
365 background_actionPerformed(e);
368 savePDB.setText(MessageManager.getString("label.pdb_file"));
369 savePDB.addActionListener(new ActionListener()
372 public void actionPerformed(ActionEvent e)
374 savePDB_actionPerformed(e);
377 jMenuBar1.add(fileMenu);
378 jMenuBar1.add(coloursMenu);
379 jMenuBar1.add(viewMenu);
380 fileMenu.add(saveMenu);
381 fileMenu.add(mapping);
382 saveMenu.add(savePDB);
385 coloursMenu.add(seqButton);
386 coloursMenu.add(chain);
387 coloursMenu.add(charge);
388 coloursMenu.add(zappo);
389 coloursMenu.add(taylor);
390 coloursMenu.add(hydro);
391 coloursMenu.add(helix);
392 coloursMenu.add(strand);
393 coloursMenu.add(turn);
394 coloursMenu.add(buried);
395 coloursMenu.add(user);
396 coloursMenu.add(background);
397 ButtonGroup bg = new ButtonGroup();
410 Map<String, UserColourScheme> userColourSchemes = UserDefinedColours
411 .getUserColourSchemes();
412 if (userColourSchemes != null)
414 for (String userColour : userColourSchemes.keySet())
416 final JRadioButtonMenuItem radioItem = new JRadioButtonMenuItem(
418 radioItem.setName("USER_DEFINED");
419 radioItem.addMouseListener(new MouseAdapter()
422 public void mousePressed(MouseEvent evt)
424 if (evt.isPopupTrigger()) // Mac
426 offerRemoval(radioItem);
431 public void mouseReleased(MouseEvent evt)
433 if (evt.isPopupTrigger()) // Windows
435 offerRemoval(radioItem);
442 void offerRemoval(final JRadioButtonMenuItem radioItem)
444 radioItem.removeActionListener(radioItem.getActionListeners()[0]);
446 int option = JvOptionPane.showInternalConfirmDialog(
447 jalview.gui.Desktop.desktop, MessageManager
448 .getString("label.remove_from_default_list"),
450 .getString("label.remove_user_defined_colour"),
451 JvOptionPane.YES_NO_OPTION);
452 if (option == JvOptionPane.YES_OPTION)
454 jalview.gui.UserDefinedColours
455 .removeColourFromDefaults(radioItem.getText());
456 coloursMenu.remove(radioItem);
460 radioItem.addActionListener(new ActionListener()
463 public void actionPerformed(ActionEvent evt)
465 user_actionPerformed(evt);
471 radioItem.addActionListener(new ActionListener()
474 public void actionPerformed(ActionEvent evt)
476 user_actionPerformed(evt);
479 coloursMenu.add(radioItem);
486 viewMenu.add(zbuffer);
487 viewMenu.add(allchains);
490 JMenuBar jMenuBar1 = new JMenuBar();
492 JMenu fileMenu = new JMenu();
494 JMenu coloursMenu = new JMenu();
496 JMenu saveMenu = new JMenu();
498 JMenuItem png = new JMenuItem();
500 JMenuItem eps = new JMenuItem();
502 JMenuItem mapping = new JMenuItem();
504 JCheckBoxMenuItem wire = new JCheckBoxMenuItem();
506 JCheckBoxMenuItem depth = new JCheckBoxMenuItem();
508 JCheckBoxMenuItem zbuffer = new JCheckBoxMenuItem();
510 JCheckBoxMenuItem allchains = new JCheckBoxMenuItem();
512 JRadioButtonMenuItem charge = new JRadioButtonMenuItem();
514 JRadioButtonMenuItem chain = new JRadioButtonMenuItem();
516 JRadioButtonMenuItem seqButton = new JRadioButtonMenuItem();
518 JRadioButtonMenuItem hydro = new JRadioButtonMenuItem();
520 JRadioButtonMenuItem taylor = new JRadioButtonMenuItem();
522 JRadioButtonMenuItem zappo = new JRadioButtonMenuItem();
524 JRadioButtonMenuItem user = new JRadioButtonMenuItem();
526 JRadioButtonMenuItem buried = new JRadioButtonMenuItem();
528 JRadioButtonMenuItem turn = new JRadioButtonMenuItem();
530 JRadioButtonMenuItem strand = new JRadioButtonMenuItem();
532 JRadioButtonMenuItem helix = new JRadioButtonMenuItem();
534 JMenu viewMenu = new JMenu();
536 JMenuItem background = new JMenuItem();
538 JMenuItem savePDB = new JMenuItem();
546 public void eps_actionPerformed(ActionEvent e)
548 makePDBImage(jalview.util.ImageMaker.TYPE.EPS);
557 public void png_actionPerformed(ActionEvent e)
559 makePDBImage(jalview.util.ImageMaker.TYPE.PNG);
562 void makePDBImage(jalview.util.ImageMaker.TYPE type)
564 int width = pdbcanvas.getWidth();
565 int height = pdbcanvas.getHeight();
567 jalview.util.ImageMaker im;
569 if (type == jalview.util.ImageMaker.TYPE.PNG)
571 im = new jalview.util.ImageMaker(this,
572 jalview.util.ImageMaker.TYPE.PNG, "Make PNG image from view",
573 width, height, null, null, null, 0, false);
575 else if (type == jalview.util.ImageMaker.TYPE.EPS)
577 im = new jalview.util.ImageMaker(this,
578 jalview.util.ImageMaker.TYPE.EPS, "Make EPS file from view",
579 width, height, null, this.getTitle(), null, 0, false);
584 im = new jalview.util.ImageMaker(this,
585 jalview.util.ImageMaker.TYPE.SVG, "Make SVG file from PCA",
586 width, height, null, this.getTitle(), null, 0, false);
589 if (im.getGraphics() != null)
591 pdbcanvas.drawAll(im.getGraphics(), width, height);
596 public void charge_actionPerformed(ActionEvent e)
598 pdbcanvas.bysequence = false;
599 pdbcanvas.pdb.setChargeColours();
600 pdbcanvas.redrawneeded = true;
604 public void hydro_actionPerformed(ActionEvent e)
606 pdbcanvas.bysequence = false;
607 pdbcanvas.pdb.setColours(new HydrophobicColourScheme());
608 pdbcanvas.redrawneeded = true;
612 public void chain_actionPerformed(ActionEvent e)
614 pdbcanvas.bysequence = false;
615 pdbcanvas.pdb.setChainColours();
616 pdbcanvas.redrawneeded = true;
620 public void zbuffer_actionPerformed(ActionEvent e)
622 pdbcanvas.zbuffer = !pdbcanvas.zbuffer;
623 pdbcanvas.redrawneeded = true;
627 public void molecule_actionPerformed(ActionEvent e)
629 pdbcanvas.bymolecule = !pdbcanvas.bymolecule;
630 pdbcanvas.redrawneeded = true;
634 public void depth_actionPerformed(ActionEvent e)
636 pdbcanvas.depthcue = !pdbcanvas.depthcue;
637 pdbcanvas.redrawneeded = true;
641 public void wire_actionPerformed(ActionEvent e)
643 pdbcanvas.wire = !pdbcanvas.wire;
644 pdbcanvas.redrawneeded = true;
648 public void seqButton_actionPerformed(ActionEvent e)
650 pdbcanvas.bysequence = true;
651 pdbcanvas.updateSeqColours();
654 public void mapping_actionPerformed(ActionEvent e)
656 jalview.gui.CutAndPasteTransfer cap = new jalview.gui.CutAndPasteTransfer();
659 cap.setText(pdbcanvas.mappingDetails.toString());
660 Desktop.addInternalFrame(cap,
661 MessageManager.getString("label.pdb_sequence_mapping"), 550,
663 } catch (OutOfMemoryError oom)
665 new OOMWarning("Opening sequence to structure mapping report", oom);
670 public void allchains_itemStateChanged(ItemEvent e)
672 pdbcanvas.setAllchainsVisible(allchains.getState());
675 public void zappo_actionPerformed(ActionEvent e)
677 pdbcanvas.bysequence = false;
678 pdbcanvas.pdb.setColours(new ZappoColourScheme());
679 pdbcanvas.redrawneeded = true;
683 public void taylor_actionPerformed(ActionEvent e)
685 pdbcanvas.bysequence = false;
686 pdbcanvas.pdb.setColours(new TaylorColourScheme());
687 pdbcanvas.redrawneeded = true;
691 public void helix_actionPerformed(ActionEvent e)
693 pdbcanvas.bysequence = false;
694 pdbcanvas.pdb.setColours(new HelixColourScheme());
695 pdbcanvas.redrawneeded = true;
699 public void strand_actionPerformed(ActionEvent e)
701 pdbcanvas.bysequence = false;
702 pdbcanvas.pdb.setColours(new StrandColourScheme());
703 pdbcanvas.redrawneeded = true;
707 public void turn_actionPerformed(ActionEvent e)
709 pdbcanvas.bysequence = false;
710 pdbcanvas.pdb.setColours(new TurnColourScheme());
711 pdbcanvas.redrawneeded = true;
715 public void buried_actionPerformed(ActionEvent e)
717 pdbcanvas.bysequence = false;
718 pdbcanvas.pdb.setColours(new BuriedColourScheme());
719 pdbcanvas.redrawneeded = true;
723 public void user_actionPerformed(ActionEvent e)
725 if (e.getActionCommand().equals(
726 MessageManager.getString("action.user_defined")))
728 // new UserDefinedColours(pdbcanvas, null);
732 UserColourScheme udc = UserDefinedColours
733 .getUserColourSchemes().get(e.getActionCommand());
735 pdbcanvas.pdb.setColours(udc);
736 pdbcanvas.redrawneeded = true;
741 public void background_actionPerformed(ActionEvent e)
743 Color col = JColorChooser.showDialog(this,
744 MessageManager.getString("label.select_background_colour"),
745 pdbcanvas.backgroundColour);
749 pdbcanvas.backgroundColour = col;
750 pdbcanvas.redrawneeded = true;
755 public void savePDB_actionPerformed(ActionEvent e)
757 JalviewFileChooser chooser = new JalviewFileChooser(
758 jalview.bin.Cache.getProperty("LAST_DIRECTORY"));
760 chooser.setFileView(new JalviewFileView());
761 chooser.setDialogTitle(MessageManager.getString("label.save_pdb_file"));
762 chooser.setToolTipText(MessageManager.getString("action.save"));
764 int value = chooser.showSaveDialog(this);
766 if (value == JalviewFileChooser.APPROVE_OPTION)
770 BufferedReader in = new BufferedReader(new FileReader(tmpPDBFile));
771 File outFile = chooser.getSelectedFile();
773 PrintWriter out = new PrintWriter(new FileOutputStream(outFile));
775 while ((data = in.readLine()) != null)
777 if (!(data.indexOf("<PRE>") > -1 || data.indexOf("</PRE>") > -1))
784 } catch (Exception ex)
786 ex.printStackTrace();