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.
21 package jalview.appletgui;
23 import jalview.api.AlignmentViewPanel;
24 import jalview.api.FeatureRenderer;
25 import jalview.api.SequenceRenderer;
26 import jalview.datamodel.PDBEntry;
27 import jalview.datamodel.SequenceI;
28 import jalview.ext.jmol.JalviewJmolBinding;
30 import java.awt.Container;
31 import java.util.ArrayList;
32 import java.util.List;
34 import java.util.Vector;
36 import org.jmol.api.JmolAppConsoleInterface;
37 import org.jmol.java.BS;
38 import org.jmol.viewer.Viewer;
41 * bind an alignment view to an external Jmol instance.
46 public class ExtJmol extends JalviewJmolBinding
49 private AlignmentPanel ap;
51 protected ExtJmol(jalview.appletgui.AlignFrame alframe,
52 PDBEntry[] pdbentry, SequenceI[][] seq, String[][] chains,
55 super(alframe.alignPanel.getStructureSelectionManager(), pdbentry, seq,
59 public ExtJmol(Viewer viewer, AlignmentPanel alignPanel,
62 super(alignPanel.getStructureSelectionManager(), seqs, viewer);
64 notifyFileLoaded(null, null, null, null, 0);
67 private void notifyFileLoaded(Object object, Object object2, Object object3,
68 Object object4, int i) {
69 // TODO Auto-generated method stub
73 public void updateColours(Object source)
76 // TODO Auto-generated method stub
80 public void showUrl(String arg0)
82 showUrl(arg0, "jmol");
86 public FeatureRenderer getFeatureRenderer(AlignmentViewPanel alignment)
88 AlignmentPanel ap = (AlignmentPanel) alignment;
89 if (ap.av.isShowSequenceFeatures())
91 return ap.getFeatureRenderer();
100 public SequenceRenderer getSequenceRenderer(AlignmentViewPanel alignment)
102 return ((AlignmentPanel) alignment).getSequenceRenderer();
106 public void notifyScriptTermination(String strStatus, int msWalltime)
112 public void sendConsoleEcho(String strEcho)
118 public void sendConsoleMessage(String strStatus)
124 public void showUrl(String url, String target)
126 ap.alignFrame.showURL(url, target);
130 public void refreshGUI()
135 public void selectionChanged(BS arg0)
137 System.out.println(arg0);
141 public void refreshPdbEntries()
143 List<PDBEntry> pdbe = new ArrayList<PDBEntry>();
144 List<String> fileids = new ArrayList<String>();
145 SequenceI[] sq = ap.av.getAlignment().getSequencesArray();
146 for (int s = 0; s < sq.length; s++)
148 Vector<PDBEntry> pdbids = sq[s].getPDBId();
151 for (int pe = 0, peSize = pdbids.size(); pe < peSize; pe++)
153 PDBEntry pentry = pdbids.elementAt(pe);
154 if (!fileids.contains(pentry.getId()))
160 fileids.add(pentry.getId());
165 PDBEntry[] newEntries = new PDBEntry[pdbe.size()];
166 for (int pe = 0; pe < pdbe.size(); pe++)
168 newEntries[pe] = pdbe.get(pe);
170 setPdbentry(newEntries);
174 public void showConsole(boolean show)
176 // This never gets called because we haven't overriden the associated Jmol's
179 .println("WARNING: unexpected call to ExtJmol's showConsole method. (showConsole="
184 protected JmolAppConsoleInterface createJmolConsole(
185 Container consolePanel, String buttonsToShow)
187 // TODO Auto-generated method stub
192 protected void releaseUIResources()
200 public void releaseReferences(Object svl)
202 // TODO Auto-generated method stub
207 public Map<String, Object> getJSpecViewProperty(String arg0)
209 // TODO Auto-generated method stub