50f747162b3cd18b72a3c33347ac6182c5784ced
[jalview.git] / src / jalview / io / HTMLOutput.java
1 package jalview.io;\r
2 \r
3 import jalview.gui.*;\r
4 import jalview.datamodel.*;\r
5 import jalview.schemes.*;\r
6 import java.awt.*;\r
7 import javax.swing.*;\r
8 import java.io.*;\r
9 import java.util.*;\r
10 \r
11 \r
12 public class HTMLOutput\r
13 {\r
14   AlignViewport av;\r
15   SequenceRenderer sr;\r
16   Color color;\r
17 \r
18   public HTMLOutput(AlignViewport av)\r
19   {\r
20     this.av = av;\r
21     sr = new SequenceRenderer(av);\r
22     JalviewFileChooser chooser = new JalviewFileChooser(\r
23       jalview.bin.Cache.getProperty("LAST_DIRECTORY"),\r
24       new String[]{"html"},\r
25       new String[]{"HTML files"},\r
26       "HTML files");\r
27 \r
28     chooser.setFileView(new JalviewFileView());\r
29     chooser.setDialogTitle("Save as HTML");\r
30     chooser.setToolTipText("Save");\r
31     int value = chooser.showSaveDialog(null);\r
32     if(value == JalviewFileChooser.APPROVE_OPTION)\r
33     {\r
34       String choice =  chooser.getSelectedFile().getPath();\r
35       jalview.bin.Cache.setProperty("LAST_DIRECTORY", chooser.getSelectedFile().getParent());\r
36       try{\r
37         PrintWriter out = new java.io.PrintWriter(new java.io.FileWriter(choice));\r
38         out.println("<HTML>");\r
39         out.println("<style type=\"text/css\">");\r
40         out.println("<!--");\r
41         out.print("td {font-family: \""+av.getFont().getFamily()+"\", \""+av.getFont().getName()+ "\", mono; "\r
42                    +"font-size: "+av.getFont().getSize()+"px; ");\r
43 \r
44 \r
45         if (av.getFont().getStyle() == Font.BOLD)\r
46            out.print("font-weight: BOLD; ");\r
47 \r
48         if (av.getFont().getStyle() == Font.ITALIC)\r
49            out.print("font-style: italic; ");\r
50 \r
51         out.println("text-align: center; }");\r
52 \r
53         out.println("-->");\r
54         out.println("</style>");\r
55         out.println("<BODY>");\r
56 \r
57 \r
58         if(av.getWrapAlignment())\r
59            drawWrappedAlignment(out);\r
60         else\r
61            drawUnwrappedAlignment(out);\r
62 \r
63         out.println("\n</body>\n</html>");\r
64         out.close();\r
65         jalview.util.BrowserLauncher.openURL( "file:///"+choice );\r
66       }\r
67       catch(Exception ex){ex.printStackTrace();}\r
68     }\r
69   }\r
70 \r
71   void drawUnwrappedAlignment(PrintWriter out)\r
72   {\r
73 \r
74     out.println("<table border=\"1\"><tr><td>\n");\r
75     out.println("<table border=\"0\"  cellpadding=\"0\" cellspacing=\"0\">\n");\r
76 \r
77 \r
78     //////////////\r
79     SequenceGroup [] groups;\r
80     SequenceI seq;\r
81     ColourSchemeI cs = null;\r
82     AlignmentI alignment = av.getAlignment();\r
83     String r,g,b;\r
84 \r
85   // draws the top row, the measure rule\r
86     out.println("<tr><td colspan=\"6\"></td>");\r
87     int i=0;\r
88     for(i=10; i<alignment.getWidth()-10; i+=10)\r
89       out.println("<td colspan=\"9\">"+i+"<br>|</td><td></td>");\r
90 \r
91     out.println("<td colspan=\"3\"></td><td colspan=\"3\">"+i+"<br>|</td>");\r
92     out.println("</tr>");\r
93 \r
94     for (i = 0; i < alignment.getHeight(); i++)\r
95     {\r
96       seq = alignment.getSequenceAt(i);\r
97       groups = alignment.findAllGroups( seq );\r
98       if(av.getShowFullId())\r
99         out.println("<tr><td nowrap>"+seq.getDisplayId()+"&nbsp;&nbsp;</td>");\r
100       else\r
101         out.println("<tr><td nowrap>"+seq.getName()+"&nbsp;&nbsp;</td>");\r
102 \r
103 \r
104 \r
105       for (int res = 0; res < seq.getLength(); res++)\r
106       {\r
107         cs = av.getGlobalColourScheme();\r
108 \r
109         if(groups!=null)\r
110          {\r
111            for (int k = 0; k < groups.length; k++)\r
112              if (groups[k].getStartRes() <= res && groups[k].getEndRes() >= res)\r
113              {\r
114                cs = groups[k].cs;\r
115                break;\r
116              }\r
117          }\r
118 \r
119 \r
120         color = sr.getResidueBoxColour(cs, seq, res);\r
121 \r
122         if(color.getRGB()<-1)\r
123         {\r
124           out.println("<td bgcolor=\"#"\r
125                       + jalview.util.Format.getHexString(color)\r
126                       + "\">"+seq.getCharAt(res)+"</td>");\r
127         }\r
128         else\r
129           out.println("<td>"+seq.getCharAt(res)+"</td>");\r
130 \r
131       }\r
132 \r
133       out.println("</tr>");\r
134     }\r
135     //////////////\r
136     out.println("</table>");\r
137     out.println("</td></tr></table>");\r
138 \r
139   }\r
140 \r
141   void drawWrappedAlignment(PrintWriter out)\r
142   {\r
143      ////////////////////////////////////\r
144      /// How many sequences and residues can we fit on a printable page?\r
145      AlignmentI al = av.getAlignment();\r
146      SequenceGroup [] groups;\r
147      SequenceI seq;\r
148      ColourSchemeI cs = null;\r
149      String r,g,b;\r
150 \r
151      out.println("<table border=\"1\"><tr><td>\n");\r
152      out.println("<table border=\"0\"  cellpadding=\"0\" cellspacing=\"0\">\n");\r
153 \r
154      for(int startRes=0; startRes<al.getWidth(); startRes+=av.getChunkWidth())\r
155      {\r
156 \r
157        int endRes = startRes+av.getChunkWidth();\r
158        if(endRes>al.getWidth())\r
159            endRes = al.getWidth();\r
160 \r
161      out.println("<tr>");\r
162      out.println("<td colspan=\"6\">&nbsp;</td>");\r
163      for (int i = startRes+10; i < endRes; i += 10)\r
164        out.println("<td colspan=\"9\">" + i + "<br>|</td><td></td>");\r
165 \r
166     // out.println("<td colspan=\"3\"></td><td colspan=\"3\">" + i +\r
167     //             "<br>|</td>");\r
168      out.println("</tr>");\r
169 \r
170 \r
171 \r
172        for (int s = 0; s < al.getHeight(); s++)\r
173        {\r
174          out.println("<tr>");\r
175          seq = al.getSequenceAt(s);\r
176          groups = al.findAllGroups( seq );\r
177          if(av.getShowFullId())\r
178            out.println("<td nowrap>"+seq.getDisplayId()+"&nbsp;&nbsp;</td>");\r
179          else\r
180            out.println("<td nowrap>"+seq.getName()+"&nbsp;&nbsp;</td>");\r
181 \r
182          for (int res = startRes; res < endRes; res++)\r
183               {\r
184                 cs = av.getGlobalColourScheme();\r
185                 if(groups!=null)\r
186                  {\r
187                    for (int k = 0; k < groups.length; k++)\r
188                      if (groups[k].getStartRes() <= res && groups[k].getEndRes() >= res)\r
189                      {\r
190                        cs = groups[k].cs;\r
191                        break;\r
192                      }\r
193                  }\r
194 \r
195                 color = sr.getResidueBoxColour(cs, seq, res);\r
196 \r
197                 if(color.getRGB()<-1)\r
198                 {\r
199                   r = Integer.toHexString(color.getRed());\r
200                   if(r.length()<2)\r
201                     r = "0"+r;\r
202                   g = Integer.toHexString(color.getGreen());\r
203                   if(g.length()<2)\r
204                     g = "0"+g;\r
205                   b = Integer.toHexString(color.getBlue());\r
206                   if(b.length()<2)\r
207                     b = "0"+b;\r
208                   out.println("<td bgcolor=\"#"+ r + g + b + "\">"+seq.getCharAt(res)+"</td>");\r
209                 }\r
210                 else\r
211                   out.println("<td>"+seq.getCharAt(res)+"</td>");\r
212 \r
213               }\r
214 \r
215          out.println("</tr>");\r
216 \r
217        }\r
218        if(endRes<al.getWidth())\r
219            out.println("<tr><td height=\"5\"></td></tr>");\r
220 \r
221 \r
222 \r
223      }\r
224 \r
225     out.println("</table>");\r
226     out.println("</table>");\r
227 \r
228 \r
229 \r
230   }\r
231 \r
232 \r
233 }\r