-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathREADME.txt
141 lines (101 loc) · 4.07 KB
/
README.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
NDKmol - Molecular Viewer on Android NDK and iOS
* This is "development" branch. Please use ES1 branch for a stable version *
== About ==
NDKmol is a molecular viewer for Android.
You can view three dimensional structures of proteins and
small molecules. NDKmol supports most of common representations
for molecules, such as ribbon, trace, stick, sphere and line.
NDKmol also supports symmetry operations; biological assemblies and
crystal packing can be displayed.
NDKmol is very compact and optimized for performance.
You can open large molecules like ribosome!
NDKmol has same functionality as GLmol, which is written in
WebGL/Javascript and runs on Web browsers.
You can try GLmol at
http://webglmol.sourceforge.jp/index-en.html
== Features ==
* Read PDB file
* Read SDF/MOL file
* Search and Download structures from RCSB PDB and NCBI PubChem
* Rotate/Translate/Zoom model by finger
* Representations
- Line
- Stick
- Sphere(van der Waals radius)
- Alpha carbon trace
- Ribbon (thick or thin)
- Strand
- B factor tube
- Nucleic acid ladder
- Nucleic acid line
- Solvent 'stars'
* Smoothing of beta sheets
* Coloring
- By chain
- By secondary structure(when defined in SHEET/HELIX records)
- By Elements
- Gradation (a.k.a chainbow)
- B factor
- polar/nonpolar
* Crystallography
- Display unit cell
- Show crystal packing (when defined in REMARK section)
- Display biological assembly (when defined in REMARK section)
== How to Use ==
When launched, NDKmol automatically loads porin (PDBID: 2POR)
as an example. You can rotate the molecule by your finger.
To zoom or translate the molecule, press <MENU> button in your
phone/tablet and select the mode. Two-finger gestures are
also supported.
Everything can be done from the <MENU>; changing representation
of protein or ligand (non protein molecules), changing colors,
showing biological assembly, crystal packing and/or unit cell.
To load other PDB files, please put the file in "PDB" directory
of the SD card and select "Open" command in the MENU.
You can also download structures directly from RCSB PDB and NCBI PubChem
web server. Select "Search and Download" in the menu.
== Reference ==
A PDB file (PDBID: 2POR) is included as an example.
"Structure of porin refined at 1.8 A resolution"
Weiss, M.S., Schulz, G.E., J.Mol.Biol. 227: 493-509 (1992)
== License ==
(C) Copyright biochem_fan, 2011-2013
LGPL version 3.
Briefly, you don't have to open-source your code but if you
modified my code, please open-source the modification so that I can merge it.
Also please acknowledge use of my code in e.g. "About" dialog.
If LGPL is not suitable for your purpose, just tell me.
I will consider another license for you.
== Contact ==
Project website is located at http://webglmol.sourceforge.jp/
Comments and suggestions are welcome at http://sourceforge.jp/projects/webglmol/forums/ or
== iOS support ==
iOS port was merged to this repository.
How to use:
single-finger drag - rotation
double-finger drag(pan) - translation
double-finger pinch - zoom
single-finger long press - open "view settings" panel
Lacking Features:
File browser and PDB/PubChem searcher is not implemented.
How to integrate to your code:
"MolecularViewerViewController.mm" is the main view controller.
You can invoke this controller from your code.
To change models, save PDB file in the resource directory and
call "loadMolecule" method in MolecularViewerViewController.mm
== Build instructions ==
Android:
Don't forget to install Android NDK as well as Android SDK.
== Switching OpenGL ES 1.0 and 2.0 ==
By default, iOS version uses GL ES 2.0 and Android version uses GL ES 1.0.
To change this behaviour, please edit GLES.hpp.
For Android, you need to edit three files as well.
- Applicatin.mk
- Android.mk
- AndroidManifest.xml
see comments in the file
- NDKmolActivity.java
public static final boolean GLES1 = true; // or false
I don't know why, but the Android simulator fails to run GL ES 2.0 version of NDKmol,
which works on actual devices.