User:Eric Martz/JSmol Notes
From Proteopedia
| Contents | 
Things To Be Aware Of Before Converting To JSmol
Advantages
Of course there are huge advantages to using JSmol:
- Users of a JSmol website do not need to install Java (which is a likely security risk).
- The very popular Google Chrome browser no longer supports Java, nor does Edge (the new browser in Windows 10). Opera plans to remove support for Java.
- A JSmol website will likely work on iPads and smart phones. (Java is not available for these platforms, so Jmol is not an option for them.)
Disadvantages
JSmol is slower than Jmol
|  | ||
| Atoms (Kilo) | KD (Asymmetric Unit) | |
| 1.7 | 28 | |
| 6 | 87 | |
| 12 | 160 | |
| 23 | 233 | |
| 45 | 826 | |
| 60 | 900 | |
| 57 (2.7K x 21 NMR models. Includes hydrogen.) | 416 (20K x 20 NMR models) | |
| Models with >10,000 atoms are in the largest ~10% of the PDB; with >20,000 atoms, the largest ~5%; with >50,000 atoms, the largest ~1.5% (counting all models for NMR ensembles). | ||
JSmol is significantly slower than Jmol. Rotation will be jerkier (see JSmol/Rotation Speeds). Smaller molecules (<10,000 atoms) are handled quite well. Large molecules (>20,000 atoms; see table at right) may be slow to load and process. (Sometimes I’ve seen delays of up to a minute, even more, during which JSmol freezes. These delays tend to happen with large molecules but are not simply related to size.) Multiple-model ensembles (such as from NMR experiments) may cause JSmol to freeze while taking minutes to load the ensemble, or loading may never finish.
Here is how two websites that now use JSmol by default have handled these issues:
- FirstGlance in Jmol loads only the first model when there are more than one (in JSmol). It offers signed Jmol_S (Java) as an option (and a preference setting). The unsigned Jmol applet is no longer offered because it is deprecated and Oracle says that eventually it won't be allowed. FirstGlance recommends using Java when the molecule has >20,000 atoms, and even more strongly recommends it when >50,000 atoms.
- Proteopedia loads only amino acid alpha carbon atoms (or nucleic acid phosphorus atoms) and ligand atoms, since its ribbon view (secondary structure schematic) works fine without the other atoms. A prominent message is displayed that a simplified model is being shown, and there is a button to load the complete model. For registered users who are logged in, Proteopedia has a preference setting that will use Jmol_S instead of JSmol.
Poor performance in Internet Explorer, Edge, Chrome and Opera
JSmol runs in the javascript of the browser. Different web browsers operate JSmol with very different performances (see JSmol/Rotation Speeds). Firefox runs JSmol best (Safari is equally good). Chrome and Opera are up to several fold slower, and Edge is about 4-fold slower. Internet Explorer is unacceptably slow (all versions, including version 11), but since early 2016, it is no longer the most widely used browser. Thus, Firefox is by far the best browser for JSmol.
- FirstGlance in Jmol detects the browser being used, and recommends a different browser when not in Firefox.
The findings below are based primarily on tests with FirstGlance in Jmol, and possibly results may be different for other JSmol websites.
The above snapshot is taken from FirstGlance in Jmol. For more details, see the Notes for FirstGlance.
Converting Websites from Jmol to JSmol
Get JSmol
1. Download Jmol. The download package includes both JSmol and the Jmol Java applet. Go to Jmol.Org, click Downloads.
2. Unzip the downloaded Jmol file. After unzipping, inside the main folder is jsmol.zip. Unzip that too.
3. Copy the jsmol folder (the one you unzipped in step 2) and all its contents (~2,000 files!) into the resource that you are upgrading. (You don’t need to copy any of the other files in the main folder.)
Jmol.js -> Jmol2.js
The following steps apply to the main html file of your resource:
4. Javascript files in the <header> section of the main html file. If the old page used Jmol.js, there will be a line like this that can be removed or commented out:
<!— COMMENT OUT THIS LINE <script src="jmol/Jmol.js"></script> -->
Add these two lines. Jmol2.js replaces Jmol.js, defining the same functions you were already using in Jmol.js. The order of these two lines is critical: JSmol.min.js must come before Jmol2.js.
<script type="text/javascript" src="jsmol/JSmol.min.js"></script> <script type="text/javascript" src="jsmol/js/Jmol2.js"></script>
jmolInitialize()
Find jmolInitialize() in your code. If necessary, change the relative directory path argument of this function to reflect the location of the jsmol directory you have added. For example, if your main html file is in folder1/folder2/main.html, and the location of jsmol is folder1/jsmol, then from main.html, jmolInitialize("../jsmol").
(to be continued)
I know that the above is incomplete. When I learn more I will add it here.
Other Conversion Advice
- Converting pages from Jmol to JSmol in the Jmol Wiki. This writeup is too technical for me to understand.
Creating New Websites That Use JSmol
Download and unzip the jsmol directory (see steps 1-3 in the previous section).
In the jsmol directory are various demonstration .htm files that illustrate uses of JSmol, such as jsmol.htm, a series lite.htm, lite2.htm, etc., a series simple.htm, simple1.htm, supersimple.htm, etc., test2.htm, etc.
Unfortunately, I know of no documentation for these demonstration files other than the files themselves.
There are two ways to preview these .htm files:
- Substitute the filename for "jsmol.htm" at the end of the url http://chemapps.stolaf.edu/jmol/jsmol/jsmol.htm.
- Drag the file from your local jsmol directory, and drop it into Firefox. This may not work in any browser other than Firefox.
Starting Your New Website
Here is one possible procedure:
- Choose one of the demonstration files that has features that you want to use in your website.
- Copy it into a new directory that also contains a copy of the jsmol directory with all the original files in that directory.
- Edit any references to files or directories in the jsmol directory to prefix those with "jsmol/", so the .htm file that is in the same directory with the jsmol directory can "find" those files. For example, in simple.htm, two changes are needed (additions in boldface):
- <script type="text/javascript" src="jsmol/JSmol.min.js"></script>
- j2sPath: "jsmol/j2s",
 
- After the above two changes, you can drag the file simple.htm into Firefox, and it works.
- Edit one thing at a time in your chosen, working demonstration file, save, and re-test. Thus you can gradually modify the demonstration file to become your desired website.
If you have questions or get stuck, please address your questions to the jmol-users email list.
See Also
- Jmol, where the four forms of Jmol are explained, and links are provided to other relevant articles.
- JSmol/Rotation Speeds for the 6 most popular browsers, without and with Java.

