001/* 002 * PDB web development code 003 * 004 * This code may be freely distributed and modified under the 005 * terms of the GNU Lesser General Public Licence. This should 006 * be distributed with the code. If you do not have a copy, 007 * see: 008 * 009 * http://www.gnu.org/copyleft/lesser.html 010 * 011 * Copyright for this code is held jointly by the individual 012 * authors. These should be listed in @author doc comments. 013 * 014 * 015 * Created on Jun 13, 2009 016 * Created by Andreas Prlic 017 * 018 */ 019 020package org.biojava.nbio.structure.align.webstart; 021 022import org.biojava.nbio.structure.Atom; 023import org.biojava.nbio.structure.StructureException; 024import org.biojava.nbio.structure.align.StructureAlignment; 025import org.biojava.nbio.structure.align.StructureAlignmentFactory; 026import org.biojava.nbio.structure.align.ce.CeCPMain; 027import org.biojava.nbio.structure.align.ce.CeMain; 028import org.biojava.nbio.structure.align.client.PdbPair; 029import org.biojava.nbio.structure.align.fatcat.FatCatFlexible; 030import org.biojava.nbio.structure.align.fatcat.FatCatRigid; 031import org.biojava.nbio.structure.align.gui.AlignmentGui; 032import org.biojava.nbio.structure.align.gui.ChooseDirAction; 033import org.biojava.nbio.structure.align.gui.DisplayAFP; 034import org.biojava.nbio.structure.align.gui.StructureAlignmentDisplay; 035import org.biojava.nbio.structure.align.gui.jmol.StructureAlignmentJmol; 036import org.biojava.nbio.structure.align.model.AFPChain; 037import org.biojava.nbio.structure.align.seq.SmithWaterman3Daligner; 038import org.biojava.nbio.structure.align.util.AtomCache; 039import org.biojava.nbio.structure.align.util.UserConfiguration; 040 041import javax.swing.*; 042 043import java.io.File; 044 045public class WebStartMain 046{ 047 048 private static UserConfiguration userConfig; 049 050 /** 051 * If no arguments, shows AlignmentGui for pairwise alignments. 052 * if 1 argument: dbmenu shows the DBSearchGUI, otherwise the AlignentGUI is shown. 053 * 054 * if more than 3 arguments takes the following arguments 055 * arg0 : fatcat or biojava . 056 * arg1 : pdb1.X 057 * arg2 ; pdb2.X 058 * 059 * The 4th argument is optional and it could be the serverLocation which the client should talk to. 060 * 061 * @param args 062 */ 063 public static void main(String[] args){ 064 065 AligUIManager.setLookAndFeel(); 066 067 if ( args.length == 0){ 068 069 //JOptionPane.showMessageDialog(null, 070 // "Not enough arguments. Need at least 3, but only got " + args.length); 071 072 // we did not get enough arguments, show the general user interface... 073 074 javax.swing.SwingUtilities.invokeLater(new Runnable() { 075 @Override 076 public void run() { 077 078 AlignmentGui.getInstance(); 079 } 080 }); 081 082 return; 083 084 } 085 086 else if ( args.length < 3){ 087 //String arg0 = args[0]; 088 089 javax.swing.SwingUtilities.invokeLater(new Runnable() { 090 @Override 091 public void run() { 092 AlignmentGui.getInstance(); 093 } 094 }); 095 096 return; 097 098 } 099 100 String arg0 = args[0]; 101 102 if (! ("fatcat".equals(arg0) || 103 "biojava".equals(arg0) || 104 "fatcat_flexible".equals(arg0) || 105 "ce".equals(arg0) || 106 "ce_cp".equals(arg0) || 107 "sw".equals(arg0) 108 )){ 109 JOptionPane.showMessageDialog(null, 110 "Wrong arguments. First argument has to be \"fatcat\", \"ce\", \"ce_cp\", \"sw\", \"fatcat_flexible\", or \"biojava\", but got " + arg0); 111 return; 112 } 113 114 try { 115 116 String name1 = args[1]; 117 String name2 = args[2]; 118 119 PdbPair pair = new PdbPair(name1, name2); 120 System.out.println("### user provided: " + pair); 121 122 UserConfiguration config = getWebStartConfig(); 123 124 System.setProperty(UserConfiguration.PDB_DIR,config.getPdbFilePath()); 125 System.out.println("using PDB file path: " + config.getPdbFilePath()); 126 127 AtomCache cache = new AtomCache(config); 128 129 JFrame frame = new JFrame(); 130 frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 131 132 showProgressBar(frame,"Loading PDB files...", "Loading files from local directory or via FTP."); 133 134 Atom[] ca1 = cache.getAtoms(pair.getName1()); 135 Atom[] ca2 = cache.getAtoms(pair.getName2()); 136 137 frame.dispose(); 138 139 System.out.println("done reading structures"); 140 141 142 if ("ce".equalsIgnoreCase(arg0) || 143 "ce_cp".equalsIgnoreCase(arg0) || 144 "sw".equalsIgnoreCase(arg0) || 145 "fatcat".equalsIgnoreCase(arg0) || 146 "fatcat_flexible".equalsIgnoreCase(arg0)){ 147 try { 148 149 StructureAlignment algorithm ; 150 if ( "ce".equalsIgnoreCase(arg0)) 151 algorithm = StructureAlignmentFactory.getAlgorithm(CeMain.algorithmName); 152 else if ( "ce_cp".equalsIgnoreCase(arg0)) 153 algorithm = StructureAlignmentFactory.getAlgorithm(CeCPMain.algorithmName); 154 else if ( "fatcat".equalsIgnoreCase(arg0)) 155 algorithm = StructureAlignmentFactory.getAlgorithm(FatCatRigid.algorithmName); 156 else if ( "fatcat_flexible".equalsIgnoreCase(arg0)) 157 algorithm = StructureAlignmentFactory.getAlgorithm(FatCatFlexible.algorithmName); 158 else 159 algorithm = new SmithWaterman3Daligner(); 160 161 showStructureAlignment(algorithm ,ca1,ca2,pair.getName1(),pair.getName2()); 162 163 } catch (Exception e){ 164 e.printStackTrace(); 165 JOptionPane.showMessageDialog(null, 166 "Something went wrong! : " + e.getMessage()); 167 } 168 169 170 } else if ( "biojava".equalsIgnoreCase(arg0)){ 171 try { 172 //showBiojava(ca1,ca2); 173 } catch (Exception e){ 174 e.printStackTrace(); 175 JOptionPane.showMessageDialog(null, 176 "Something went wrong! : " + e.getMessage()); 177 System.exit(0); 178 } 179 } 180 181 182 } catch (Exception e) { 183 e.printStackTrace(); 184 JOptionPane.showMessageDialog(null, 185 "Error: " + e.getMessage()); 186 System.exit(0); 187 return; 188 } 189 } 190 191 private static JProgressBar showProgressBar(JFrame frame, String title, String displayTxt){ 192 193 frame.setTitle(title); 194 JProgressBar progressBar; 195 196 JPanel content = new JPanel(); 197 content.setOpaque(true); 198 199 //Where the GUI is constructed: 200 progressBar = new JProgressBar(); 201 progressBar.setToolTipText(title); 202 progressBar.setValue(0); 203 progressBar.setStringPainted(true); 204 progressBar.setIndeterminate(true); 205 206 JTextField txt = new JTextField(displayTxt); 207 txt.setEditable(false); 208 content.add(txt); 209 content.add(progressBar); 210 211 frame.getContentPane().add(content); 212 frame.pack(); 213 frame.setVisible(true); 214 215 return progressBar; 216 } 217 218 219 public static UserConfiguration getWebStartConfig(){ 220 221 // check if we could load it (i.e. we are running in web start mode) 222 if ( userConfig == null ) { 223 userConfig = WebStartMain.getDefaultConfig(); 224 225 } 226 227 return userConfig; 228 } 229 230 231 public static UserConfiguration getDefaultConfig(){ 232 userConfig = new UserConfiguration(); 233 234 String pdbDir = System.getProperty(UserConfiguration.PDB_DIR); 235 if ( pdbDir != null) { 236 userConfig.setPdbFilePath(pdbDir); 237 238 } 239 240 return userConfig; 241 } 242 243 244 public static UserConfiguration requestUserConfig(){ 245 246 if ( userConfig == null) { 247 248 //UserConfiguration config = new UserConfiguration(); 249 userConfig = new UserConfiguration(); 250 251 String pdbDir = System.getProperty(UserConfiguration.PDB_DIR); 252 if ( pdbDir != null) { 253 userConfig.setPdbFilePath(pdbDir); 254 return userConfig; 255 } 256 257 } 258 JTextField textField = new JTextField(); 259 ChooseDirAction action = new ChooseDirAction(textField, userConfig); 260 action.actionPerformed(null); 261 if ( textField.getText() == null) { 262 263 // accessing temp. OS directory: 264 String property = "java.io.tmpdir"; 265 String lineSplit = System.getProperty("file.separator"); 266 267 String tempdir = System.getProperty(property); 268 269 if ( !(tempdir.endsWith(lineSplit ) ) ) 270 tempdir = tempdir + lineSplit; 271 272 userConfig.setPdbFilePath(tempdir); 273 return userConfig; 274 } 275 276 File file = new File(textField.getText()); 277 if ( ! file.isDirectory() ){ 278 // should not happen 279 System.err.println("did not provide directory, going on level higher! " + file.getAbsolutePath()); 280 file = file.getParentFile(); 281 } 282 System.setProperty(UserConfiguration.PDB_DIR, file.getAbsolutePath()); 283 userConfig.setPdbFilePath(file.getAbsolutePath()); 284 285 return userConfig; 286 } 287 288 289 290 private static void showStructureAlignment(StructureAlignment algorithm, Atom[] ca1, Atom[] ca2, String name1, String name2) throws StructureException{ 291 JFrame tmpFrame = new JFrame(); 292 tmpFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 293 294 String title = "Calculating " + algorithm.getAlgorithmName() + " V." + algorithm.getVersion()+" alignment... "; 295 296 showProgressBar(tmpFrame,title, "Calculating the structure alignment."); 297 298 //do the actual alignment 299 AFPChain afpChain = algorithm.align(ca1, ca2); 300 301 afpChain.setName1(name1); 302 afpChain.setName2(name2); 303 304 tmpFrame.dispose(); 305 306 // show results 307 StructureAlignmentJmol jmol = StructureAlignmentDisplay.display(afpChain,ca1,ca2); 308 309 System.out.println(afpChain.toCE(ca1, ca2)); 310 311 DisplayAFP.showAlignmentPanel(afpChain,ca1,ca2,jmol); 312 313 } 314 315 316// private static void showBiojava(Atom[] ca1, Atom[] ca2) throws StructureException{ 317// 318// StructurePairAligner aligner = new StructurePairAligner(); 319// 320// StrucAligParameters params = StrucAligParameters.getDefaultParameters(); 321// //params.setJoinFast(true); 322// //params.setMaxIter(1); 323// try { 324// // align the full 2 structures with default parameters. 325// // see StructurePairAligner for more options and how to align 326// // any set of Atoms 327// long start = System.currentTimeMillis(); 328// 329// 330// aligner.align(ca1,ca2,params); 331// long end = System.currentTimeMillis(); 332// System.out.println("calculation time:" + (end-start)); 333// 334// AlternativeAlignment[] aligs = aligner.getAlignments(); 335// AlternativeAlignment a = aligs[0]; 336// System.out.println(a); 337// 338// if (! BiojavaJmol.jmolInClassPath()){ 339// System.err.println("Could not find Jmol in classpath, please install first!"); 340// return; 341// } 342// // display the alignment in Jmol 343// 344// 345// 346// // first get an artificial structure for the alignment 347// Structure artificial = a.getAlignedStructure(structure1, structure2); 348// 349// // and then send it to Jmol (only will work if Jmol is in the Classpath) 350// BiojavaJmol jmol = new BiojavaJmol(); 351// jmol.setTitle(artificial.getName()); 352// jmol.setStructure(artificial); 353// 354// // color the two structures 355// 356// 357// jmol.evalString("select *; backbone 0.4; wireframe off; spacefill off; " + 358// "select not protein and not solvent; spacefill on;"); 359// jmol.evalString("select */1 ; color red; model 1; "); 360// 361// 362// // now color the equivalent residues ... 363// 364// String[] pdb1 = a.getPDBresnum1(); 365// for (String res : pdb1 ){ 366// jmol.evalString("select " + res + "/1 ; backbone 0.6; color orange;"); 367// } 368// 369// jmol.evalString("select */2; color blue; model 2;"); 370// String[] pdb2 = a.getPDBresnum2(); 371// for (String res :pdb2 ){ 372// jmol.evalString("select " + res + "/2 ; backbone 0.6; color cyan;"); 373// } 374// 375// 376// // now show both models again. 377// jmol.evalString("model 0;"); 378// 379// } catch (StructureException e){ 380// e.printStackTrace(); 381// } 382// 383// } 384}