Reads annotation files
[jalview.git] / src / jalview / bin / JalviewLite.java
1 /*\r
2 * Jalview - A Sequence Alignment Editor and Viewer\r
3 * Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
4 *\r
5 * This program is free software; you can redistribute it and/or\r
6 * modify it under the terms of the GNU General Public License\r
7 * as published by the Free Software Foundation; either version 2\r
8 * of the License, or (at your option) any later version.\r
9 *\r
10 * This program is distributed in the hope that it will be useful,\r
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
13 * GNU General Public License for more details.\r
14 *\r
15 * You should have received a copy of the GNU General Public License\r
16 * along with this program; if not, write to the Free Software\r
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA\r
18 */\r
19 package jalview.bin;\r
20 \r
21 import jalview.appletgui.AlignFrame;\r
22 \r
23 import jalview.datamodel.*;\r
24 \r
25 import jalview.io.*;\r
26 \r
27 import java.applet.*;\r
28 \r
29 import java.awt.*;\r
30 import java.awt.event.*;\r
31 import jalview.appletgui.TreePanel;\r
32 \r
33 \r
34 /**\r
35  * Jalview Applet. Runs in Java 1.18 runtime\r
36  *\r
37  * @author $author$\r
38  * @version $Revision$\r
39  */\r
40 public class JalviewLite extends Applet\r
41 {\r
42     static int lastFrameX = 200;\r
43     static int lastFrameY = 200;\r
44     boolean fileFound = true;\r
45     String file = "No file";\r
46     Button launcher = new Button("Start Jalview");\r
47 \r
48     static AlignFrame currentAlignFrame;\r
49     boolean embedded = false;\r
50 \r
51 \r
52     /**\r
53      * init method for Jalview Applet\r
54      */\r
55     public void init()\r
56     {\r
57         int r = 255;\r
58         int g = 255;\r
59         int b = 255;\r
60         String param = getParameter("RGB");\r
61 \r
62         if (param != null)\r
63         {\r
64             try\r
65             {\r
66                 r = Integer.parseInt(param.substring(0, 2), 16);\r
67                 g = Integer.parseInt(param.substring(2, 4), 16);\r
68                 b = Integer.parseInt(param.substring(4, 6), 16);\r
69             }\r
70             catch (Exception ex)\r
71             {\r
72                 r = 255;\r
73                 g = 255;\r
74                 b = 255;\r
75             }\r
76         }\r
77 \r
78         param = getParameter("label");\r
79         if(param != null)\r
80           launcher.setLabel(param);\r
81 \r
82         this.setBackground(new Color(r, g, b));\r
83 \r
84         file = getParameter("file");\r
85         if(file.indexOf("://")==-1)\r
86                file = getCodeBase() + file;\r
87 \r
88         final JalviewLite applet = this;\r
89         if(getParameter("embedded")!=null\r
90            && getParameter("embedded").equalsIgnoreCase("true"))\r
91         {\r
92           embedded = true;\r
93           LoadingThread loader = new LoadingThread(file,\r
94                             "URL",\r
95                             applet);\r
96           loader.start();\r
97         }\r
98         else if (file != null)\r
99         {\r
100             add(launcher);\r
101 \r
102             launcher.addActionListener(new java.awt.event.ActionListener()\r
103                 {\r
104                     public void actionPerformed(ActionEvent e)\r
105                     {\r
106                         LoadingThread loader = new LoadingThread(file,\r
107                             "URL",\r
108                             applet);\r
109                         loader.start();\r
110                       }\r
111                 });\r
112         }\r
113         else\r
114         {\r
115             file = "NO FILE";\r
116             fileFound = false;\r
117         }\r
118     }\r
119 \r
120 \r
121     public static void main(String [] args)\r
122     {\r
123       if(args.length!=1)\r
124       {\r
125         System.out.println("\nUsage: java -jar jalviewApplet.jar fileName\n");\r
126         System.exit(1);\r
127       }\r
128 \r
129       String format = jalview.io.IdentifyFile.Identify(args[0],"File");\r
130       SequenceI[] sequences = new AppletFormatAdapter().readFile(args[0], "File", format);\r
131 \r
132       if ( (sequences != null) && (sequences.length > 0))\r
133       {\r
134         AlignFrame af = new AlignFrame(new Alignment(sequences), null, args[0]);\r
135         af.statusBar.setText("Successfully loaded file " + args[0]);\r
136       }\r
137     }\r
138 \r
139 \r
140     /**\r
141      * Initialises and displays a new java.awt.Frame\r
142      *\r
143      * @param frame java.awt.Frame to be displayed\r
144      * @param title title of new frame\r
145      * @param width width if new frame\r
146      * @param height height of new frame\r
147      */\r
148     public static void addFrame(final Frame frame, String title, int width,\r
149         int height)\r
150     {\r
151         frame.setLocation(lastFrameX, lastFrameY);\r
152         lastFrameX += 40;\r
153         lastFrameY += 40;\r
154         frame.setSize(width, height);\r
155         frame.setTitle(title);\r
156         frame.addWindowListener(new WindowAdapter()\r
157             {\r
158                 public void windowClosing(WindowEvent e)\r
159                 {\r
160                     if(currentAlignFrame == frame)\r
161                     {\r
162                       currentAlignFrame = null;\r
163                     }\r
164                     lastFrameX -=40;\r
165                     lastFrameY-=40;\r
166                     frame.setMenuBar(null);\r
167                     frame.dispose();\r
168                 }\r
169                 public void windowActivated(WindowEvent e)\r
170                 {\r
171                   if(frame instanceof AlignFrame)\r
172                     currentAlignFrame = (AlignFrame)frame;\r
173                 }\r
174 \r
175             });\r
176         frame.setVisible(true);\r
177     }\r
178 \r
179     public String getAlignment(String format)\r
180     {\r
181       return getAlignment(format, "true");\r
182     }\r
183 \r
184     public String getAlignment(String format, String suffix)\r
185     {\r
186       try\r
187       {\r
188         boolean seqlimits = suffix.equalsIgnoreCase("true");\r
189 \r
190         String reply = new AppletFormatAdapter().formatSequences(format,\r
191             currentAlignFrame.viewport.getAlignment().getSequences(), seqlimits);\r
192         return reply;\r
193       }\r
194       catch (Exception ex)\r
195       {\r
196         ex.printStackTrace();\r
197         return "Error retrieving alignment in " + format + " format. ";\r
198       }\r
199     }\r
200 \r
201     /**\r
202      * This paints the background surrounding the "Launch Jalview button"\r
203      * <br>\r
204      * <br>If file given in parameter not found, displays error message\r
205      *\r
206      * @param g graphics context\r
207      */\r
208     public void paint(Graphics g)\r
209     {\r
210         if (!fileFound)\r
211         {\r
212             g.setColor(new Color(200, 200, 200));\r
213             g.setColor(Color.cyan);\r
214             g.fillRect(0, 0, getSize().width, getSize().height);\r
215             g.setColor(Color.red);\r
216             g.drawString("Jalview can't open file", 5, 15);\r
217             g.drawString("\"" + file + "\"", 5, 30);\r
218         }\r
219         else if(embedded)\r
220         {\r
221           g.setColor(Color.black);\r
222           g.setFont(new Font("Arial", Font.BOLD, 24));\r
223           g.drawString("Jalview Applet", 50, this.size().height/2 -30);\r
224           g.drawString("Loading Data...", 50, this.size().height/2);\r
225         }\r
226 \r
227 \r
228     }\r
229 \r
230     class LoadingThread extends Thread\r
231     {\r
232         String file;\r
233         String protocol;\r
234         String format;\r
235         JalviewLite applet;\r
236 \r
237         public LoadingThread(String file,\r
238                              String protocol,\r
239                              JalviewLite applet)\r
240         {\r
241             this.file = file;\r
242             this.protocol = protocol;\r
243             format = jalview.io.IdentifyFile.Identify(file, "URL");\r
244             this.applet = applet;\r
245         }\r
246 \r
247         public void run()\r
248         {\r
249             SequenceI[] sequences = null;\r
250             sequences = new AppletFormatAdapter().readFile(file, protocol, format);\r
251 \r
252             if ((sequences != null) && (sequences.length > 0))\r
253             {\r
254               currentAlignFrame = new AlignFrame(new Alignment(sequences),\r
255                                                  applet, file);\r
256               if (embedded)\r
257                 currentAlignFrame.setEmbedded();\r
258 \r
259               currentAlignFrame.statusBar.setText("Successfully loaded file " + file);\r
260 \r
261 \r
262                 String treeFile = applet.getParameter("treeFile");\r
263                 if (treeFile != null)\r
264                 {\r
265                   if (treeFile.indexOf("://") == -1)\r
266                   treeFile = getCodeBase() + treeFile;\r
267 \r
268                   try\r
269                   {\r
270                     jalview.io.NewickFile fin = new jalview.io.NewickFile(applet.\r
271                         getCodeBase() + treeFile, "URL");\r
272                     fin.parse();\r
273 \r
274                     if (fin.getTree() != null)\r
275                     {\r
276                       TreePanel tp = null;\r
277                       tp = new TreePanel(currentAlignFrame.viewport,\r
278                                          currentAlignFrame.viewport.getAlignment().getSequences(),\r
279                                          fin, "FromFile", applet.getCodeBase() + treeFile);\r
280                       addFrame(tp, treeFile, 600, 500);\r
281                       currentAlignFrame.addTreeMenuItem(tp, treeFile);\r
282                     }\r
283                   }\r
284                   catch (Exception ex)\r
285                   {\r
286                     ex.printStackTrace();\r
287                   }\r
288               }\r
289 \r
290               String param = getParameter("features");\r
291               if (param != null)\r
292               {\r
293                 if (param.indexOf("://") == -1)\r
294                   param = getCodeBase() + param;\r
295 \r
296                 currentAlignFrame.parseFeaturesFile(param);\r
297               }\r
298 \r
299              param = getParameter("annotations");\r
300              if (param != null)\r
301              {\r
302                if (param.indexOf("://") == -1)\r
303                  param = getCodeBase() + param;\r
304 \r
305                new AnnotationReader().readAnnotationFile(\r
306                    currentAlignFrame.viewport.getAlignment(),\r
307                    param);\r
308 \r
309                currentAlignFrame.alignPanel.fontChanged();\r
310              }\r
311 \r
312 \r
313                 String pdbfile = applet.getParameter("PDBFILE");\r
314                 if(pdbfile!=null)\r
315                 {\r
316                   if(pdbfile.indexOf("://")==-1)\r
317                        pdbfile = getCodeBase() + pdbfile;\r
318 \r
319                   String sequence = applet.getParameter("PDBSEQ");\r
320 \r
321                   if(sequence!=null)\r
322                   {\r
323                     new MCview.AppletPDBViewer(pdbfile, "URL",\r
324                                                (Sequence)currentAlignFrame.getAlignViewport().getAlignment().findName(sequence),\r
325                                                currentAlignFrame.getSeqcanvas());\r
326                   }\r
327 \r
328                 }\r
329             }\r
330             else\r
331             {\r
332                 fileFound = false;\r
333                 remove(launcher);\r
334                 repaint();\r
335             }\r
336         }\r
337     }\r
338 }\r