@source http://chemapps.stolaf.edu/jmol/jsmol
@author hansonr@stolaf.edu project started 8/26/2012
last revision, 8/17/13
JSmol -- Java(Script) web-based molecular viewer
see http://jmol.sourceforge.net http://jsmol.sourceforge.net
http://chemapps.stolaf.edu/jmol/jsmol/jsmol.htm
This zip directory contains a complete Java->JavaScript code conversion for Jmol.
Note that JSmol is not a different program than Jmol.
JSmol is Jmol, just compiled into JavaScript as well as Java byte code.
All development is done working with the trunk Jmol Java source,
but compilation of that code creates both Java .class files and equivalent JavaScript .js files
As such, JSmol has all of the features of Jmol:
full file reading (including binary formats)
full Jmol scripting (including atom selection and Jmol Math)
full Jmol shape object support
full rendering, including pixel-based translucency
full Jmol WRITE capability (requires server-side jsmol.php)
full language localizaion using GetText
Wiki: http://wiki.jmol.org/index.php/Jmol_JavaScript_Object#JSmol
Status:
complete Jmol code implementation in JavaScript
Java2Script js compiler adapted successfully
HTML5: slower rendering; but a full implementation of Jmol
WebGL: partial only; fast rendering, including cartoons and isosurfaces (vdw, sasurface), not text
To do:
WebGL option is limited; still no text, for example, and is not being actively pursued
due to graphical limitations and absence on iPad.
What's here:
MAIN DIRECTORIES:
j2s/ java/ JavaScript versions of Java classes
J/ JavaScript versions of Jmol classes (org.jmol)
JZ/ JavaScript versions of JZlib (com.jcraft.jzlib)
core/ package.js and selected minimized core JS files,
trans/ *.po language localization files from src/org/jmol/translation/JmolApplet
img/ images used in the HTML5 version of JSmol (cover image "play" button)
java/ Java JAR files for JmolApplet and JSpecView
jme/ JME.jar -- Java Molecular Editor (Peter Ertl) -- see jmetest.htm
jsme/ JSME files -- JavaScript Molecular Editor (Peter Ertl and Bruno Bienfait) -- see jsmetest.htm
ADDITIONAL DIRECTORIES:
data/ all the model and script files used by these test pages
flot/ files required by jmol-flot-energy.htm
jquery/ original jQuery files adapted to make js/JSmoljQuery.js
(modifications primarily allow binary AJAX)
js/ JSmolXXXX.js JavaScript files that are included in JSmol.min.js
as well as uncompressed coreXXX.js files; useful for debugging
These include:
j2sjmol.js
JSmol.js
JSmolApi.js
JSmolApplet.js
JSmolControls.js
JSmolCore.js
JSmolGLmol.js
JSmolJME.js
JSmoljQueryExt.js
JSmolJSV.js
JSmolThree.js
JSmolTM.js
php/ contains jsmol.php, which is necessary on a server for some browsers
to access binary files via AJAX.
FILES:
JSmol.min.js
============
All of the necessary files to start JSmol, minimized with the
Google Closure Compiler, including:
jquery.js
JSmoljQueryExt.js
JSmolCore.js
JSmol.js
JSmolApplet.js
JSmolControls.js
JSmolApi.js
j2sjmol.js
JSmol.min.nojq.js
============
All of the above, but without jquery.js.
(You must include jQuery separately.)
JSmol.min.core.js
============
All of the above, plus core Java files:
JSmol.min.js
coretop2.js
j2s/core/core.z.js
JSmol.lite.js
============
A very light-weight non-Jmol model viewer. Just balls and sticks.
jquery.js
JSmoljQueryExt.js
JSmolCore.js
JSmolTM.js
JSmol.lite.nojq.js
============
A super light-weight non-Jmol model viewer. Just balls and sticks; no jQuery.
(You must include jQuery separately.)
JSmoljQueryExt.js
JSmolCore.js
JSmolTM.js
jsmol.htm
=========
The main test page. Use this page as your starting point for the pages you write.
jsmol.htm is a general test of the integration of JSmol with JmolJSO.
It uses JSmol.min.js, which will call for files in j2s/ as needed.
On the server side, it uses jsmol.php for delivering cross-domain models into the viewer.
lite.htm
==========
A demo of JSmol.lite.js reading a file from PubChem
liteNCI.htm
==========
A demo of JSmol.lite.js reading a file from NCI
lite3.htm
==========
A demo of JSmol.lite.js using HTML-encoded structure
lite4.htm
==========
A demo of JSmol.lite.js using site-based structure file
resize.htm
==========
A test of applet resizing
simple.htm
==========
A JavaScript equivalent of http://chemapps.stolaf.edu/jmol/simple.htm
simple2.htm
===========
An early JavaScript equivalent of http://chemapps.stolaf.edu/jmol/simple2.htm
sync2.htm
=========
Illustrating applet synchronization in JSmol/HTML5
vibrate.htm
===========
A page quickly made from the original Java version in http://chemapps.stolaf.edu/jmol/examples-12
test2.htm
=========
Bob's main test page that does not use JSmol.min.js and instead uses the files in js/
This Jmol page will automatically switch to different modes
depending upon browser capabilities. It is set to use HTML5, but you can change that.
Read the information in the file for details.
It uses the unminimized set of JSmolXXXX.js files
If you add
?debugcode
to the URL, it will bypasss j2s/core files and read files
directly from j2s/J, j2s/com, and j2s/java. Note that in this mode
the popup menu and the Jmol console are not available.
It can uses the signed Jmol applet, the unsigned Jmol applet
with server-side help, or JSmol using
HTML5 when WebGL is not available (iPad/iPhone/Android).
JSmol implements Java2Script
to recreate the entire Jmol Java applet in JavaScript.
Note that if test2.htm is on your LOCAL MACHINE, then the unsigned applet,
which is in java/, will not find the data files, which are in data/,
and even if you use the signed applet, then some browsers may not be able to
find those files on your local machine. Firefox/Windows is fine.
On the server side, it uses jsmol.php for
delivering cross-domain models into the viewer.
=======================================================
Credits:
Jmol code conversion to JavaScript by Bob Hanson.
GLmol interface written by Takanori Nakane.
Java2Script written by Zhou Renjian, et al.
Jzlib written by Atsuhiko Yamanaka.
Testing assistance by Duncan Blue, St. Olaf '17
=======================================================
Developer notes:
The creation of the files in j2s is now very easy.
See README-DEVELOPER.TXT in the main directory.
We start with two Sourceforge projects in Eclipse: Jmol and JSmol.
Eclipse (must be 3.5 or 3.6) needs to include the Java2Script plug-in.
All the PROGRAMMING is done in the Jmol project.
JavaDoc @j2sNative sections allow indicating specific JavaScript/Java-only segments
See development notes in JSmol project ANT task file buildfromjmol.xml
=======================================================
revision 8/17/2013 -- better description of compiled JavaScript files.
-- addition of JSmoljQueryExt.js
revision 7/28/2013 -- reorganization of directories
revision 12:32 PM 11/2/2012 -- java/jmolcore.z.js
revision 1:19 PM 11/13/2012 -- full binary file reading on all tested browsers
revision 9:20 PM 11/18/2012 -- full threading -- hover, spin, animation, vibration, timeout, delay, moveto
revision 11/21/2012 10:26:18 AM -- Spartan binary file reading, measurements working
revision 8:11 AM 11/22/2012 -- color Labels fix; adds _version information; adds Jmol.debugCode (true to skip core.z.js)
revision 8:12 PM 11/23/2012 -- adds MO homo SQUARED
revision 12:23 PM 11/24/2012 -- j2sjmol.js code trimming, Jmol.clearConsole(applet),
automatic switching of consoles between applets on mouseClick and scipting,
better handling of console vs information
revision 5:46 AM 11/26/2012 -- clean, ordered execution solves multithreading issues in Firefox and for multiple applets
revision 6:48 AM 12/7/2012 -- threading work complete -- script queuing, !quit, !exit, TRY/CATCH, FUNCTION, DELAY, MOVE, etc.
revision 12/24/2012 9:48:49 PM -- JavaScript popup menu and (preliminary) console
revision 7:45 PM 1/2/2013 -- Chrome displaying default popup menu with menu right-mouse click
revision 9:22 AM 1/15/2013 -- Full writing of PNG, PNGJ, JMOL, ZIP and general WRITE command; requires jsmol.php on server currently
-- JavaScript version completely switched to double precision; subtle differences with Jmol may arise.
revision 1/17/2013 6:00:50 PM -- SMILES matching compare({*},{*},"isomer") fails (Java new int[n][] in SmilesMatcher)
revision 10:57 AM 2/23/2013 -- rearranging of files in jsmol/ directory; move of j2s/org/mol to j2s/J
revision 12:25 PM 3/16/2013 -- fully optimized with Mar 03 13 Java2Script compiler.
revision 3/18/2013 10:21:04 PM -- localization working -- set LANGUAGE
revision 3/23/2013 1:12:18 AM -- added Info.coverImage, Info.coverTitle, Info.coverScript
-- j2s/img directory added, with play_make_live.jpg (Jonathan Gutow)
-- minimization fixed
-- JSmolJME upgraded to allow HTML5 option with JSME (Peter Ertl, Bruno Bienfait)
revision 3/24/2013 3:39:35 AM -- JSmol.lite.js -- just reads MOL files and displays simply; 125K uncompressed; 44K compressed