molstar 4.0.1 → 4.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +20 -20
- package/README.md +197 -197
- package/build/viewer/embedded.html +52 -52
- package/build/viewer/index.html +129 -129
- package/build/viewer/molstar.js +1 -1
- package/build/viewer/molstar.js.LICENSE.txt +0 -9
- package/lib/apps/docking-viewer/index.html +36 -36
- package/lib/apps/docking-viewer/viewport.d.ts +8 -8
- package/lib/apps/mesoscale-explorer/behavior/camera.d.ts +1 -1
- package/lib/apps/mesoscale-explorer/behavior/select.d.ts +1 -1
- package/lib/apps/mesoscale-explorer/data/cellpack/model.d.ts +2 -2
- package/lib/apps/mesoscale-explorer/data/cellpack/preset.d.ts +1 -1
- package/lib/apps/mesoscale-explorer/data/cellpack/preset.js +5 -5
- package/lib/apps/mesoscale-explorer/data/generic/preset.d.ts +1 -1
- package/lib/apps/mesoscale-explorer/data/generic/preset.js +3 -3
- package/lib/apps/mesoscale-explorer/data/mmcif/preset.d.ts +1 -1
- package/lib/apps/mesoscale-explorer/data/mmcif/preset.js +3 -3
- package/lib/apps/mesoscale-explorer/data/petworld/preset.d.ts +1 -1
- package/lib/apps/mesoscale-explorer/data/petworld/preset.js +3 -3
- package/lib/apps/mesoscale-explorer/data/state.d.ts +19 -10
- package/lib/apps/mesoscale-explorer/data/state.js +14 -2
- package/lib/apps/mesoscale-explorer/index.html +100 -100
- package/lib/apps/mesoscale-explorer/style.scss +33 -33
- package/lib/apps/mesoscale-explorer/ui/entities.d.ts +19 -13
- package/lib/apps/mesoscale-explorer/ui/entities.js +23 -4
- package/lib/apps/viewer/app.d.ts +30 -24
- package/lib/apps/viewer/app.js +6 -6
- package/lib/apps/viewer/embedded.html +52 -52
- package/lib/apps/viewer/index.html +129 -129
- package/lib/cli/chem-comp-dict/create-ions.js +9 -9
- package/lib/cli/chem-comp-dict/create-saccharides.js +9 -9
- package/lib/cli/chem-comp-dict/util.d.ts +112 -112
- package/lib/cli/cifschema/util/cif-dic.js +1 -0
- package/lib/cli/cifschema/util/generate.js +12 -12
- package/lib/cli/lipid-params/index.js +9 -9
- package/lib/cli/mvs/mvs-print-schema.d.ts +1 -0
- package/lib/cli/mvs/mvs-print-schema.js +1 -0
- package/lib/cli/mvs/mvs-render.d.ts +1 -0
- package/lib/cli/mvs/mvs-render.js +1 -0
- package/lib/cli/mvs/mvs-validate.d.ts +1 -0
- package/lib/cli/mvs/mvs-validate.js +1 -0
- package/lib/commonjs/apps/docking-viewer/viewport.d.ts +8 -8
- package/lib/commonjs/apps/mesoscale-explorer/behavior/camera.d.ts +1 -1
- package/lib/commonjs/apps/mesoscale-explorer/behavior/select.d.ts +1 -1
- package/lib/commonjs/apps/mesoscale-explorer/data/cellpack/model.d.ts +2 -2
- package/lib/commonjs/apps/mesoscale-explorer/data/cellpack/preset.d.ts +1 -1
- package/lib/commonjs/apps/mesoscale-explorer/data/cellpack/preset.js +5 -5
- package/lib/commonjs/apps/mesoscale-explorer/data/generic/preset.d.ts +1 -1
- package/lib/commonjs/apps/mesoscale-explorer/data/generic/preset.js +3 -3
- package/lib/commonjs/apps/mesoscale-explorer/data/mmcif/preset.d.ts +1 -1
- package/lib/commonjs/apps/mesoscale-explorer/data/mmcif/preset.js +3 -3
- package/lib/commonjs/apps/mesoscale-explorer/data/petworld/preset.d.ts +1 -1
- package/lib/commonjs/apps/mesoscale-explorer/data/petworld/preset.js +3 -3
- package/lib/commonjs/apps/mesoscale-explorer/data/state.d.ts +19 -10
- package/lib/commonjs/apps/mesoscale-explorer/data/state.js +15 -3
- package/lib/commonjs/apps/mesoscale-explorer/ui/entities.d.ts +19 -13
- package/lib/commonjs/apps/mesoscale-explorer/ui/entities.js +22 -3
- package/lib/commonjs/apps/viewer/app.d.ts +30 -24
- package/lib/commonjs/apps/viewer/app.js +6 -6
- package/lib/commonjs/cli/chem-comp-dict/create-ions.js +9 -9
- package/lib/commonjs/cli/chem-comp-dict/create-saccharides.js +9 -9
- package/lib/commonjs/cli/chem-comp-dict/util.d.ts +112 -112
- package/lib/commonjs/cli/cifschema/util/cif-dic.js +1 -0
- package/lib/commonjs/cli/cifschema/util/generate.js +12 -12
- package/lib/commonjs/cli/lipid-params/index.js +9 -9
- package/lib/commonjs/cli/mvs/mvs-print-schema.d.ts +1 -0
- package/lib/commonjs/cli/mvs/mvs-print-schema.js +1 -0
- package/lib/commonjs/cli/mvs/mvs-render.d.ts +1 -0
- package/lib/commonjs/cli/mvs/mvs-render.js +1 -0
- package/lib/commonjs/cli/mvs/mvs-validate.d.ts +1 -0
- package/lib/commonjs/cli/mvs/mvs-validate.js +1 -0
- package/lib/commonjs/examples/alpha-orbitals/example-data.js +160 -160
- package/lib/commonjs/extensions/alpha-orbitals/gpu/shader.frag.js +136 -136
- package/lib/commonjs/extensions/alpha-orbitals/transforms.d.ts +2 -2
- package/lib/commonjs/extensions/anvil/behavior.d.ts +10 -9
- package/lib/commonjs/extensions/anvil/representation.d.ts +5 -0
- package/lib/commonjs/extensions/assembly-symmetry/behavior.d.ts +2 -1
- package/lib/commonjs/extensions/assembly-symmetry/prop.js +24 -24
- package/lib/commonjs/extensions/assembly-symmetry/representation.d.ts +1 -0
- package/lib/commonjs/extensions/backgrounds/index.d.ts +2 -2
- package/lib/commonjs/extensions/backgrounds/index.js +2 -1
- package/lib/commonjs/extensions/dnatco/behavior.d.ts +1 -1
- package/lib/commonjs/extensions/dnatco/confal-pyramids/behavior.d.ts +10 -10
- package/lib/commonjs/extensions/dnatco/confal-pyramids/behavior.js +5 -5
- package/lib/commonjs/extensions/dnatco/confal-pyramids/representation.d.ts +3 -0
- package/lib/commonjs/extensions/dnatco/ntc-tube/behavior.d.ts +10 -10
- package/lib/commonjs/extensions/dnatco/ntc-tube/behavior.js +5 -5
- package/lib/commonjs/extensions/dnatco/ntc-tube/representation.d.ts +3 -0
- package/lib/commonjs/extensions/g3d/format.d.ts +6 -6
- package/lib/commonjs/extensions/geo-export/glb-exporter.d.ts +1 -1
- package/lib/commonjs/extensions/geo-export/glb-exporter.js +6 -4
- package/lib/commonjs/extensions/geo-export/index.d.ts +1 -1
- package/lib/commonjs/extensions/geo-export/usdz-exporter.js +41 -41
- package/lib/commonjs/extensions/meshes/mesh-extension.d.ts +2 -3
- package/lib/commonjs/extensions/meshes/mesh-streaming/behavior.d.ts +1 -1
- package/lib/commonjs/extensions/meshes/mesh-streaming/server-info.d.ts +2 -2
- package/lib/commonjs/extensions/model-archive/quality-assessment/behavior.d.ts +9 -9
- package/lib/commonjs/extensions/model-export/index.d.ts +1 -1
- package/lib/commonjs/extensions/mp4-export/index.d.ts +1 -1
- package/lib/commonjs/extensions/mvs/behavior.d.ts +1 -1
- package/lib/commonjs/extensions/mvs/camera.d.ts +2 -0
- package/lib/commonjs/extensions/mvs/camera.js +29 -2
- package/lib/commonjs/extensions/mvs/components/annotation-label/representation.d.ts +4 -0
- package/lib/commonjs/extensions/mvs/components/annotation-label/visual.d.ts +1 -0
- package/lib/commonjs/extensions/mvs/components/custom-label/representation.d.ts +4 -2
- package/lib/commonjs/extensions/mvs/components/custom-label/visual.d.ts +1 -0
- package/lib/commonjs/extensions/mvs/components/formats.d.ts +6 -4
- package/lib/commonjs/extensions/mvs/components/formats.js +2 -1
- package/lib/commonjs/extensions/mvs/load-helpers.d.ts +1 -1
- package/lib/commonjs/extensions/mvs/load.d.ts +2 -0
- package/lib/commonjs/extensions/mvs/load.js +12 -6
- package/lib/commonjs/extensions/mvs/tree/mvs/mvs-builder.d.ts +2 -8
- package/lib/commonjs/extensions/pdbe/structure-quality-report/behavior.d.ts +1 -1
- package/lib/commonjs/extensions/rcsb/validation-report/behavior.d.ts +22 -22
- package/lib/commonjs/extensions/rcsb/validation-report/representation.d.ts +5 -0
- package/lib/commonjs/extensions/sb-ncbr/partial-charges/behavior.d.ts +1 -1
- package/lib/commonjs/extensions/sb-ncbr/partial-charges/preset.d.ts +4 -4
- package/lib/commonjs/extensions/volumes-and-segmentations/entry-meshes.d.ts +1 -1
- package/lib/commonjs/extensions/volumes-and-segmentations/entry-root.d.ts +5 -5
- package/lib/commonjs/extensions/volumes-and-segmentations/entry-segmentation.d.ts +1 -1
- package/lib/commonjs/extensions/volumes-and-segmentations/entry-state.d.ts +2 -2
- package/lib/commonjs/extensions/volumes-and-segmentations/global-state.d.ts +2 -2
- package/lib/commonjs/extensions/volumes-and-segmentations/helpers.d.ts +1 -1
- package/lib/commonjs/extensions/volumes-and-segmentations/index.d.ts +1 -1
- package/lib/commonjs/extensions/wwpdb/ccd/behavior.d.ts +1 -1
- package/lib/commonjs/extensions/wwpdb/ccd/representation.d.ts +4 -4
- package/lib/commonjs/extensions/zenodo/index.d.ts +1 -1
- package/lib/commonjs/mol-canvas3d/canvas3d.d.ts +14 -2
- package/lib/commonjs/mol-canvas3d/canvas3d.js +2 -2
- package/lib/commonjs/mol-canvas3d/controls/trackball.js +1 -1
- package/lib/commonjs/mol-canvas3d/helper/handle-helper.d.ts +1 -0
- package/lib/commonjs/mol-canvas3d/helper/helper.d.ts +2 -0
- package/lib/commonjs/mol-canvas3d/passes/background.d.ts +6 -1
- package/lib/commonjs/mol-canvas3d/passes/background.js +13 -1
- package/lib/commonjs/mol-canvas3d/passes/bloom.d.ts +37 -0
- package/lib/commonjs/mol-canvas3d/passes/bloom.js +272 -0
- package/lib/commonjs/mol-canvas3d/passes/dpoit.js +4 -2
- package/lib/commonjs/mol-canvas3d/passes/draw.d.ts +11 -7
- package/lib/commonjs/mol-canvas3d/passes/draw.js +29 -3
- package/lib/commonjs/mol-canvas3d/passes/image.d.ts +6 -0
- package/lib/commonjs/mol-canvas3d/passes/postprocessing.d.ts +31 -5
- package/lib/commonjs/mol-canvas3d/passes/postprocessing.js +35 -40
- package/lib/commonjs/mol-geo/geometry/base.d.ts +3 -1
- package/lib/commonjs/mol-geo/geometry/base.js +4 -1
- package/lib/commonjs/mol-geo/geometry/cylinders/cylinders.d.ts +2 -1
- package/lib/commonjs/mol-geo/geometry/cylinders/cylinders.js +4 -1
- package/lib/commonjs/mol-geo/geometry/direct-volume/direct-volume.d.ts +2 -1
- package/lib/commonjs/mol-geo/geometry/direct-volume/direct-volume.js +4 -1
- package/lib/commonjs/mol-geo/geometry/emissive-data.d.ts +26 -0
- package/lib/commonjs/mol-geo/geometry/emissive-data.js +80 -0
- package/lib/commonjs/mol-geo/geometry/image/image.d.ts +2 -1
- package/lib/commonjs/mol-geo/geometry/image/image.js +4 -1
- package/lib/commonjs/mol-geo/geometry/lines/lines.d.ts +3 -2
- package/lib/commonjs/mol-geo/geometry/lines/lines.js +4 -1
- package/lib/commonjs/mol-geo/geometry/mesh/color-smoothing.d.ts +2 -1
- package/lib/commonjs/mol-geo/geometry/mesh/color-smoothing.js +36 -2
- package/lib/commonjs/mol-geo/geometry/mesh/mesh.d.ts +2 -1
- package/lib/commonjs/mol-geo/geometry/mesh/mesh.js +11 -4
- package/lib/commonjs/mol-geo/geometry/points/points.d.ts +3 -2
- package/lib/commonjs/mol-geo/geometry/points/points.js +4 -1
- package/lib/commonjs/mol-geo/geometry/spheres/spheres.d.ts +2 -2
- package/lib/commonjs/mol-geo/geometry/spheres/spheres.js +7 -3
- package/lib/commonjs/mol-geo/geometry/text/text.d.ts +2 -1
- package/lib/commonjs/mol-geo/geometry/text/text.js +4 -1
- package/lib/commonjs/mol-geo/geometry/texture-mesh/color-smoothing.d.ts +2 -1
- package/lib/commonjs/mol-geo/geometry/texture-mesh/color-smoothing.js +34 -2
- package/lib/commonjs/mol-geo/geometry/texture-mesh/texture-mesh.d.ts +3 -1
- package/lib/commonjs/mol-geo/geometry/texture-mesh/texture-mesh.js +14 -4
- package/lib/commonjs/mol-geo/util/location-iterator.d.ts +5 -2
- package/lib/commonjs/mol-geo/util/location-iterator.js +8 -3
- package/lib/commonjs/mol-gl/renderable/cylinders.d.ts +10 -0
- package/lib/commonjs/mol-gl/renderable/direct-volume.d.ts +10 -0
- package/lib/commonjs/mol-gl/renderable/image.d.ts +10 -0
- package/lib/commonjs/mol-gl/renderable/lines.d.ts +10 -0
- package/lib/commonjs/mol-gl/renderable/mesh.d.ts +10 -0
- package/lib/commonjs/mol-gl/renderable/points.d.ts +10 -0
- package/lib/commonjs/mol-gl/renderable/schema.d.ts +24 -1
- package/lib/commonjs/mol-gl/renderable/schema.js +15 -2
- package/lib/commonjs/mol-gl/renderable/spheres.d.ts +10 -0
- package/lib/commonjs/mol-gl/renderable/text.d.ts +10 -0
- package/lib/commonjs/mol-gl/renderable/texture-mesh.d.ts +10 -0
- package/lib/commonjs/mol-gl/renderable.d.ts +1 -1
- package/lib/commonjs/mol-gl/renderable.js +2 -2
- package/lib/commonjs/mol-gl/renderer.d.ts +2 -1
- package/lib/commonjs/mol-gl/renderer.js +58 -49
- package/lib/commonjs/mol-gl/scene.d.ts +3 -1
- package/lib/commonjs/mol-gl/scene.js +26 -1
- package/lib/commonjs/mol-gl/shader/background.frag.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/background.frag.js +95 -94
- package/lib/commonjs/mol-gl/shader/background.vert.js +11 -11
- package/lib/commonjs/mol-gl/shader/blend-back-dpoit.frag.js +13 -13
- package/lib/commonjs/mol-gl/shader/bloom/blur.frag.d.ts +1 -0
- package/lib/commonjs/mol-gl/shader/bloom/blur.frag.js +32 -0
- package/lib/commonjs/mol-gl/shader/bloom/composite.frag.d.ts +1 -0
- package/lib/commonjs/mol-gl/shader/bloom/composite.frag.js +37 -0
- package/lib/commonjs/mol-gl/shader/bloom/luminosity.frag.d.ts +1 -0
- package/lib/commonjs/mol-gl/shader/bloom/luminosity.frag.js +56 -0
- package/lib/commonjs/mol-gl/shader/cas.frag.js +144 -144
- package/lib/commonjs/mol-gl/shader/chunks/apply-fog.glsl.js +31 -31
- package/lib/commonjs/mol-gl/shader/chunks/apply-interior-color.glsl.js +12 -12
- package/lib/commonjs/mol-gl/shader/chunks/apply-light-color.glsl.d.ts +2 -2
- package/lib/commonjs/mol-gl/shader/chunks/apply-light-color.glsl.js +78 -70
- package/lib/commonjs/mol-gl/shader/chunks/apply-marker-color.glsl.js +16 -16
- package/lib/commonjs/mol-gl/shader/chunks/assign-clipping-varying.glsl.js +8 -8
- package/lib/commonjs/mol-gl/shader/chunks/assign-color-varying.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/assign-color-varying.glsl.js +140 -112
- package/lib/commonjs/mol-gl/shader/chunks/assign-group.glsl.js +6 -6
- package/lib/commonjs/mol-gl/shader/chunks/assign-marker-varying.glsl.js +8 -8
- package/lib/commonjs/mol-gl/shader/chunks/assign-material-color.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/assign-material-color.glsl.js +112 -123
- package/lib/commonjs/mol-gl/shader/chunks/assign-position.glsl.js +14 -14
- package/lib/commonjs/mol-gl/shader/chunks/assign-size.glsl.js +18 -18
- package/lib/commonjs/mol-gl/shader/chunks/check-picking-alpha.glsl.js +12 -12
- package/lib/commonjs/mol-gl/shader/chunks/check-transparency.glsl.d.ts +1 -0
- package/lib/commonjs/mol-gl/shader/chunks/check-transparency.glsl.js +20 -0
- package/lib/commonjs/mol-gl/shader/chunks/clip-instance.glsl.js +7 -7
- package/lib/commonjs/mol-gl/shader/chunks/clip-pixel.glsl.js +5 -5
- package/lib/commonjs/mol-gl/shader/chunks/color-frag-params.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/color-frag-params.glsl.js +60 -51
- package/lib/commonjs/mol-gl/shader/chunks/color-vert-params.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/color-vert-params.glsl.js +122 -92
- package/lib/commonjs/mol-gl/shader/chunks/common-clip.glsl.js +104 -104
- package/lib/commonjs/mol-gl/shader/chunks/common-frag-params.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/common-frag-params.glsl.js +150 -149
- package/lib/commonjs/mol-gl/shader/chunks/common-vert-params.glsl.js +61 -61
- package/lib/commonjs/mol-gl/shader/chunks/common.glsl.js +234 -234
- package/lib/commonjs/mol-gl/shader/chunks/dpoit-write.glsl.js +62 -62
- package/lib/commonjs/mol-gl/shader/chunks/fade-lod.glsl.js +42 -42
- package/lib/commonjs/mol-gl/shader/chunks/float-to-rgba.glsl.js +39 -39
- package/lib/commonjs/mol-gl/shader/chunks/light-frag-params.glsl.js +127 -127
- package/lib/commonjs/mol-gl/shader/chunks/matrix-scale.glsl.js +5 -5
- package/lib/commonjs/mol-gl/shader/chunks/normal-frag-params.glsl.js +2 -2
- package/lib/commonjs/mol-gl/shader/chunks/read-from-texture.glsl.js +14 -14
- package/lib/commonjs/mol-gl/shader/chunks/rgba-to-float.glsl.js +84 -84
- package/lib/commonjs/mol-gl/shader/chunks/size-vert-params.glsl.js +11 -11
- package/lib/commonjs/mol-gl/shader/chunks/texture3d-from-1d-trilinear.glsl.js +23 -23
- package/lib/commonjs/mol-gl/shader/chunks/texture3d-from-2d-linear.glsl.js +17 -17
- package/lib/commonjs/mol-gl/shader/chunks/texture3d-from-2d-nearest.glsl.js +8 -8
- package/lib/commonjs/mol-gl/shader/chunks/wboit-write.glsl.js +25 -25
- package/lib/commonjs/mol-gl/shader/compose.frag.js +12 -12
- package/lib/commonjs/mol-gl/shader/compute/color-smoothing/accumulate.frag.js +23 -23
- package/lib/commonjs/mol-gl/shader/compute/color-smoothing/accumulate.vert.js +43 -43
- package/lib/commonjs/mol-gl/shader/compute/color-smoothing/normalize.frag.js +15 -15
- package/lib/commonjs/mol-gl/shader/copy.frag.js +11 -11
- package/lib/commonjs/mol-gl/shader/cylinders.frag.d.ts +2 -2
- package/lib/commonjs/mol-gl/shader/cylinders.frag.js +267 -264
- package/lib/commonjs/mol-gl/shader/cylinders.vert.js +89 -89
- package/lib/commonjs/mol-gl/shader/depth-merge.frag.js +23 -23
- package/lib/commonjs/mol-gl/shader/direct-volume.frag.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/direct-volume.frag.js +362 -356
- package/lib/commonjs/mol-gl/shader/direct-volume.vert.js +41 -41
- package/lib/commonjs/mol-gl/shader/evaluate-dpoit.frag.js +10 -10
- package/lib/commonjs/mol-gl/shader/evaluate-wboit.frag.js +17 -17
- package/lib/commonjs/mol-gl/shader/fxaa.frag.js +228 -228
- package/lib/commonjs/mol-gl/shader/gaussian-density.frag.js +49 -49
- package/lib/commonjs/mol-gl/shader/gaussian-density.vert.js +27 -27
- package/lib/commonjs/mol-gl/shader/hi-z.frag.js +18 -18
- package/lib/commonjs/mol-gl/shader/histogram-pyramid/reduction.frag.js +58 -58
- package/lib/commonjs/mol-gl/shader/histogram-pyramid/sum.frag.js +19 -19
- package/lib/commonjs/mol-gl/shader/image.frag.d.ts +2 -2
- package/lib/commonjs/mol-gl/shader/image.frag.js +170 -161
- package/lib/commonjs/mol-gl/shader/image.vert.js +21 -21
- package/lib/commonjs/mol-gl/shader/lines.frag.d.ts +2 -2
- package/lib/commonjs/mol-gl/shader/lines.frag.js +43 -40
- package/lib/commonjs/mol-gl/shader/lines.vert.js +117 -117
- package/lib/commonjs/mol-gl/shader/marching-cubes/active-voxels.frag.js +70 -70
- package/lib/commonjs/mol-gl/shader/marching-cubes/isosurface.frag.js +311 -311
- package/lib/commonjs/mol-gl/shader/marking/edge.frag.js +28 -28
- package/lib/commonjs/mol-gl/shader/marking/overlay.frag.js +26 -26
- package/lib/commonjs/mol-gl/shader/mesh.frag.d.ts +2 -2
- package/lib/commonjs/mol-gl/shader/mesh.frag.js +66 -63
- package/lib/commonjs/mol-gl/shader/mesh.vert.js +49 -49
- package/lib/commonjs/mol-gl/shader/outlines.frag.js +95 -95
- package/lib/commonjs/mol-gl/shader/points.frag.d.ts +2 -2
- package/lib/commonjs/mol-gl/shader/points.frag.js +60 -56
- package/lib/commonjs/mol-gl/shader/points.vert.js +38 -38
- package/lib/commonjs/mol-gl/shader/postprocessing.frag.js +150 -150
- package/lib/commonjs/mol-gl/shader/quad.vert.js +10 -10
- package/lib/commonjs/mol-gl/shader/shadows.frag.js +123 -123
- package/lib/commonjs/mol-gl/shader/smaa/blend.frag.js +56 -56
- package/lib/commonjs/mol-gl/shader/smaa/blend.vert.js +25 -25
- package/lib/commonjs/mol-gl/shader/smaa/edges.frag.js +66 -66
- package/lib/commonjs/mol-gl/shader/smaa/edges.vert.js +26 -26
- package/lib/commonjs/mol-gl/shader/smaa/weights.frag.js +206 -206
- package/lib/commonjs/mol-gl/shader/smaa/weights.vert.js +32 -32
- package/lib/commonjs/mol-gl/shader/spheres.frag.d.ts +2 -2
- package/lib/commonjs/mol-gl/shader/spheres.frag.js +149 -143
- package/lib/commonjs/mol-gl/shader/spheres.vert.js +132 -132
- package/lib/commonjs/mol-gl/shader/ssao-blur.frag.d.ts +3 -2
- package/lib/commonjs/mol-gl/shader/ssao-blur.frag.js +99 -100
- package/lib/commonjs/mol-gl/shader/ssao.frag.d.ts +3 -2
- package/lib/commonjs/mol-gl/shader/ssao.frag.js +213 -174
- package/lib/commonjs/mol-gl/shader/text.frag.d.ts +2 -2
- package/lib/commonjs/mol-gl/shader/text.frag.js +86 -84
- package/lib/commonjs/mol-gl/shader/text.vert.js +85 -85
- package/lib/commonjs/mol-gl/shader/util/grid3d-template.frag.js +46 -46
- package/lib/commonjs/mol-gl/shader-code.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader-code.js +24 -18
- package/lib/commonjs/mol-gl/webgl/compat.js +12 -12
- package/lib/commonjs/mol-gl/webgl/render-item.d.ts +3 -2
- package/lib/commonjs/mol-gl/webgl/render-item.js +1 -1
- package/lib/commonjs/mol-io/common/binary-cif/array-encoder.d.ts +1 -1
- package/lib/commonjs/mol-io/common/binary-cif/array-encoder.js +5 -2
- package/lib/commonjs/mol-io/reader/cif/schema/bird.d.ts +1 -1
- package/lib/commonjs/mol-io/reader/cif/schema/bird.js +1 -1
- package/lib/commonjs/mol-io/reader/cif/schema/ccd-extras.d.ts +4 -4
- package/lib/commonjs/mol-io/reader/cif/schema/ccd.d.ts +1 -1
- package/lib/commonjs/mol-io/reader/cif/schema/ccd.js +1 -1
- package/lib/commonjs/mol-io/reader/cif/schema/mmcif.d.ts +1 -1
- package/lib/commonjs/mol-io/reader/cif/schema/mmcif.js +1 -1
- package/lib/commonjs/mol-io/reader/cif.d.ts +1 -1
- package/lib/commonjs/mol-io/writer/cif/encoder/binary.d.ts +1 -1
- package/lib/commonjs/mol-io/writer/cif/encoder/binary.js +10 -2
- package/lib/commonjs/mol-math/linear-algebra/3d/mat3.d.ts +3 -1
- package/lib/commonjs/mol-math/linear-algebra/3d/mat3.js +8 -1
- package/lib/commonjs/mol-math/linear-algebra/3d/vec3.d.ts +6 -0
- package/lib/commonjs/mol-math/linear-algebra/3d/vec3.js +20 -0
- package/lib/commonjs/mol-model/structure/model/types/saccharides.js +1 -1
- package/lib/commonjs/mol-model/structure/structure/properties.d.ts +2 -2
- package/lib/commonjs/mol-model/structure/structure/unit/bonds/data.d.ts +9 -6
- package/lib/commonjs/mol-model/structure/structure/unit/bonds/data.js +1 -1
- package/lib/commonjs/mol-model/structure/structure/unit/bonds/inter-compute.d.ts +1 -1
- package/lib/commonjs/mol-model/structure/structure/unit/bonds/inter-compute.js +7 -4
- package/lib/commonjs/mol-model/structure/structure/unit/bonds/intra-compute.d.ts +1 -1
- package/lib/commonjs/mol-model/structure/structure/unit/bonds/intra-compute.js +10 -6
- package/lib/commonjs/mol-model/structure/structure/unit.d.ts +2 -2
- package/lib/commonjs/mol-model/structure/structure/unit.js +5 -2
- package/lib/commonjs/mol-model-formats/shape/ply.d.ts +2 -0
- package/lib/commonjs/mol-model-formats/structure/basic/schema.d.ts +118 -118
- package/lib/commonjs/mol-model-formats/structure/common/component.d.ts +2 -2
- package/lib/commonjs/mol-model-formats/structure/property/bonds/index-pair.d.ts +4 -1
- package/lib/commonjs/mol-model-formats/structure/property/bonds/index-pair.js +6 -3
- package/lib/commonjs/mol-model-props/computed/representations/interactions-inter-unit-cylinder.d.ts +1 -0
- package/lib/commonjs/mol-model-props/computed/representations/interactions-intra-unit-cylinder.d.ts +1 -0
- package/lib/commonjs/mol-model-props/computed/representations/interactions.d.ts +3 -0
- package/lib/commonjs/mol-model-props/integrative/cross-link-restraint/representation.d.ts +4 -0
- package/lib/commonjs/mol-plugin/behavior/behavior.d.ts +6 -6
- package/lib/commonjs/mol-plugin/behavior/dynamic/camera.d.ts +3 -3
- package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/accessible-surface-area.d.ts +1 -1
- package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/interactions.d.ts +1 -1
- package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/secondary-structure.d.ts +1 -1
- package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/valence-model.d.ts +1 -1
- package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/integrative/cross-link-restraint.d.ts +1 -1
- package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/sequence/sifts-mapping.d.ts +1 -1
- package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/structure-info.d.ts +1 -1
- package/lib/commonjs/mol-plugin/behavior/dynamic/representation.d.ts +4 -4
- package/lib/commonjs/mol-plugin/behavior/dynamic/selection/structure-focus-representation.d.ts +1 -1
- package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/behavior.d.ts +2 -2
- package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/model.d.ts +2 -2
- package/lib/commonjs/mol-plugin/commands.d.ts +1 -208
- package/lib/commonjs/mol-plugin/config.d.ts +5 -0
- package/lib/commonjs/mol-plugin/context.d.ts +2 -2
- package/lib/commonjs/mol-plugin/state.d.ts +6 -6
- package/lib/commonjs/mol-plugin-state/actions/structure.d.ts +3 -3
- package/lib/commonjs/mol-plugin-state/actions/structure.js +3 -5
- package/lib/commonjs/mol-plugin-state/actions/volume.d.ts +1 -1
- package/lib/commonjs/mol-plugin-state/builder/data.d.ts +4 -4
- package/lib/commonjs/mol-plugin-state/builder/structure/hierarchy-preset.d.ts +27 -27
- package/lib/commonjs/mol-plugin-state/builder/structure/hierarchy.d.ts +5 -5
- package/lib/commonjs/mol-plugin-state/builder/structure/representation-preset.d.ts +42 -42
- package/lib/commonjs/mol-plugin-state/builder/structure/representation.d.ts +4 -4
- package/lib/commonjs/mol-plugin-state/builder/structure.d.ts +7 -7
- package/lib/commonjs/mol-plugin-state/formats/coordinates.d.ts +8 -8
- package/lib/commonjs/mol-plugin-state/formats/shape.d.ts +8 -8
- package/lib/commonjs/mol-plugin-state/formats/topology.d.ts +12 -12
- package/lib/commonjs/mol-plugin-state/formats/volume.d.ts +33 -33
- package/lib/commonjs/mol-plugin-state/helpers/structure-emissive.d.ts +12 -0
- package/lib/commonjs/mol-plugin-state/helpers/structure-emissive.js +69 -0
- package/lib/commonjs/mol-plugin-state/helpers/structure-selection-query.d.ts +1 -1
- package/lib/commonjs/mol-plugin-state/manager/structure/component.d.ts +3 -1
- package/lib/commonjs/mol-plugin-state/manager/structure/component.js +9 -1
- package/lib/commonjs/mol-plugin-state/manager/structure/measurement.d.ts +341 -9
- package/lib/commonjs/mol-plugin-state/manager/structure/measurement.js +32 -19
- package/lib/commonjs/mol-plugin-state/manager/structure/selection.d.ts +1 -1
- package/lib/commonjs/mol-plugin-state/manager/volume/hierarchy.d.ts +1 -1
- package/lib/commonjs/mol-plugin-state/objects.d.ts +32 -32
- package/lib/commonjs/mol-plugin-state/transforms/representation.d.ts +33 -8
- package/lib/commonjs/mol-plugin-state/transforms/representation.js +121 -6
- package/lib/commonjs/mol-plugin-state/transforms/shape.d.ts +1 -1
- package/lib/commonjs/mol-plugin-state/transforms/volume.d.ts +16 -8
- package/lib/commonjs/mol-plugin-state/transforms/volume.js +51 -2
- package/lib/commonjs/mol-plugin-ui/state/apply-action.d.ts +2 -2
- package/lib/commonjs/mol-plugin-ui/state/update-transform.d.ts +3 -3
- package/lib/commonjs/mol-repr/representation.d.ts +6 -2
- package/lib/commonjs/mol-repr/representation.js +12 -2
- package/lib/commonjs/mol-repr/shape/loci/angle.d.ts +1 -0
- package/lib/commonjs/mol-repr/shape/loci/common.d.ts +1 -0
- package/lib/commonjs/mol-repr/shape/loci/dihedral.d.ts +1 -0
- package/lib/commonjs/mol-repr/shape/loci/distance.d.ts +1 -0
- package/lib/commonjs/mol-repr/shape/loci/label.d.ts +1 -0
- package/lib/commonjs/mol-repr/shape/loci/orientation.d.ts +1 -0
- package/lib/commonjs/mol-repr/shape/loci/plane.d.ts +1 -0
- package/lib/commonjs/mol-repr/shape/model/unitcell.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/complex-representation.d.ts +1 -1
- package/lib/commonjs/mol-repr/structure/complex-representation.js +7 -1
- package/lib/commonjs/mol-repr/structure/complex-visual.d.ts +8 -1
- package/lib/commonjs/mol-repr/structure/complex-visual.js +5 -1
- package/lib/commonjs/mol-repr/structure/params.d.ts +8 -0
- package/lib/commonjs/mol-repr/structure/registry.d.ts +14 -0
- package/lib/commonjs/mol-repr/structure/representation/backbone.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/ball-and-stick.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/carbohydrate.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/cartoon.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/ellipsoid.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/gaussian-surface.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/gaussian-volume.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/label.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/line.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/molecular-surface.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/orientation.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/point.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/putty.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/representation/spacefill.d.ts +3 -0
- package/lib/commonjs/mol-repr/structure/units-representation.d.ts +1 -1
- package/lib/commonjs/mol-repr/structure/units-representation.js +9 -3
- package/lib/commonjs/mol-repr/structure/units-visual.d.ts +9 -1
- package/lib/commonjs/mol-repr/structure/units-visual.js +5 -1
- package/lib/commonjs/mol-repr/structure/visual/bond-inter-unit-cylinder.d.ts +2 -0
- package/lib/commonjs/mol-repr/structure/visual/bond-inter-unit-line.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/bond-intra-unit-cylinder.d.ts +2 -0
- package/lib/commonjs/mol-repr/structure/visual/bond-intra-unit-line.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/carbohydrate-link-cylinder.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/carbohydrate-symbol-mesh.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/carbohydrate-terminal-link-cylinder.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/element-cross.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/element-point.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/element-sphere.d.ts +4 -0
- package/lib/commonjs/mol-repr/structure/visual/ellipsoid-mesh.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/gaussian-density-volume.d.ts +2 -0
- package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-mesh.d.ts +4 -0
- package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-mesh.js +1 -1
- package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-wireframe.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/label-text.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/molecular-surface-mesh.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/molecular-surface-wireframe.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/nucleotide-atomic-bond.d.ts +2 -0
- package/lib/commonjs/mol-repr/structure/visual/nucleotide-atomic-element.d.ts +2 -0
- package/lib/commonjs/mol-repr/structure/visual/nucleotide-atomic-ring-fill.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/nucleotide-block-mesh.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/nucleotide-ring-mesh.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/orientation-ellipsoid-mesh.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-backbone-cylinder.d.ts +2 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-backbone-sphere.d.ts +2 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-direction-wedge.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-gap-cylinder.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-trace-mesh.d.ts +1 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-tube-mesh.d.ts +1 -0
- package/lib/commonjs/mol-repr/visual.d.ts +6 -1
- package/lib/commonjs/mol-repr/visual.js +55 -1
- package/lib/commonjs/mol-repr/volume/direct-volume.d.ts +3 -0
- package/lib/commonjs/mol-repr/volume/isosurface.d.ts +6 -0
- package/lib/commonjs/mol-repr/volume/registry.d.ts +4 -0
- package/lib/commonjs/mol-repr/volume/representation.d.ts +2 -1
- package/lib/commonjs/mol-repr/volume/representation.js +9 -2
- package/lib/commonjs/mol-repr/volume/segment.d.ts +5 -0
- package/lib/commonjs/mol-repr/volume/slice.d.ts +3 -0
- package/lib/commonjs/mol-script/language/symbol-table/core.d.ts +3 -3
- package/lib/commonjs/mol-state/tree/immutable.d.ts +1 -1
- package/lib/commonjs/mol-state/tree/transient.d.ts +2 -2
- package/lib/commonjs/mol-theme/color/external-volume.d.ts +3 -1
- package/lib/commonjs/mol-theme/color/external-volume.js +8 -2
- package/lib/commonjs/mol-theme/color.d.ts +1 -0
- package/lib/commonjs/mol-theme/emissive.d.ts +40 -0
- package/lib/commonjs/mol-theme/emissive.js +137 -0
- package/lib/commonjs/mol-theme/substance.d.ts +1 -1
- package/lib/commonjs/mol-theme/substance.js +2 -2
- package/lib/commonjs/mol-theme/transparency.d.ts +0 -1
- package/lib/commonjs/mol-util/input/input-observer.js +2 -0
- package/lib/commonjs/mol-util/set.d.ts +1 -1
- package/lib/commonjs/mol-util/set.js +17 -1
- package/lib/commonjs/servers/common/swagger-ui/indexTemplate.js +66 -66
- package/lib/commonjs/servers/volume/config.js +5 -5
- package/lib/examples/alpha-orbitals/example-data.js +160 -160
- package/lib/examples/alpha-orbitals/index.html +72 -72
- package/lib/examples/basic-wrapper/index.html +137 -137
- package/lib/examples/lighting/index.html +88 -88
- package/lib/examples/proteopedia-wrapper/index.html +236 -236
- package/lib/extensions/alpha-orbitals/gpu/shader.frag.js +136 -136
- package/lib/extensions/alpha-orbitals/transforms.d.ts +2 -2
- package/lib/extensions/anvil/behavior.d.ts +10 -9
- package/lib/extensions/anvil/representation.d.ts +5 -0
- package/lib/extensions/assembly-symmetry/behavior.d.ts +2 -1
- package/lib/extensions/assembly-symmetry/prop.js +24 -24
- package/lib/extensions/assembly-symmetry/representation.d.ts +1 -0
- package/lib/extensions/backgrounds/index.d.ts +2 -2
- package/lib/extensions/backgrounds/index.js +2 -1
- package/lib/extensions/dnatco/behavior.d.ts +1 -1
- package/lib/extensions/dnatco/confal-pyramids/behavior.d.ts +10 -10
- package/lib/extensions/dnatco/confal-pyramids/behavior.js +5 -5
- package/lib/extensions/dnatco/confal-pyramids/representation.d.ts +3 -0
- package/lib/extensions/dnatco/ntc-tube/behavior.d.ts +10 -10
- package/lib/extensions/dnatco/ntc-tube/behavior.js +5 -5
- package/lib/extensions/dnatco/ntc-tube/representation.d.ts +3 -0
- package/lib/extensions/g3d/format.d.ts +6 -6
- package/lib/extensions/geo-export/glb-exporter.d.ts +1 -1
- package/lib/extensions/geo-export/glb-exporter.js +6 -4
- package/lib/extensions/geo-export/index.d.ts +1 -1
- package/lib/extensions/geo-export/usdz-exporter.js +41 -41
- package/lib/extensions/meshes/mesh-extension.d.ts +2 -3
- package/lib/extensions/meshes/mesh-streaming/behavior.d.ts +1 -1
- package/lib/extensions/meshes/mesh-streaming/server-info.d.ts +2 -2
- package/lib/extensions/model-archive/quality-assessment/behavior.d.ts +9 -9
- package/lib/extensions/model-export/index.d.ts +1 -1
- package/lib/extensions/mp4-export/index.d.ts +1 -1
- package/lib/extensions/mvs/behavior.d.ts +1 -1
- package/lib/extensions/mvs/camera.d.ts +2 -0
- package/lib/extensions/mvs/camera.js +27 -1
- package/lib/extensions/mvs/components/annotation-label/representation.d.ts +4 -0
- package/lib/extensions/mvs/components/annotation-label/visual.d.ts +1 -0
- package/lib/extensions/mvs/components/custom-label/representation.d.ts +4 -2
- package/lib/extensions/mvs/components/custom-label/visual.d.ts +1 -0
- package/lib/extensions/mvs/components/formats.d.ts +6 -4
- package/lib/extensions/mvs/components/formats.js +2 -1
- package/lib/extensions/mvs/load-helpers.d.ts +1 -1
- package/lib/extensions/mvs/load.d.ts +2 -0
- package/lib/extensions/mvs/load.js +13 -7
- package/lib/extensions/mvs/tree/mvs/mvs-builder.d.ts +2 -8
- package/lib/extensions/pdbe/structure-quality-report/behavior.d.ts +1 -1
- package/lib/extensions/rcsb/validation-report/behavior.d.ts +22 -22
- package/lib/extensions/rcsb/validation-report/representation.d.ts +5 -0
- package/lib/extensions/sb-ncbr/partial-charges/behavior.d.ts +1 -1
- package/lib/extensions/sb-ncbr/partial-charges/preset.d.ts +4 -4
- package/lib/extensions/volumes-and-segmentations/entry-meshes.d.ts +1 -1
- package/lib/extensions/volumes-and-segmentations/entry-root.d.ts +5 -5
- package/lib/extensions/volumes-and-segmentations/entry-segmentation.d.ts +1 -1
- package/lib/extensions/volumes-and-segmentations/entry-state.d.ts +2 -2
- package/lib/extensions/volumes-and-segmentations/global-state.d.ts +2 -2
- package/lib/extensions/volumes-and-segmentations/helpers.d.ts +1 -1
- package/lib/extensions/volumes-and-segmentations/index.d.ts +1 -1
- package/lib/extensions/wwpdb/ccd/behavior.d.ts +1 -1
- package/lib/extensions/wwpdb/ccd/representation.d.ts +4 -4
- package/lib/extensions/zenodo/index.d.ts +1 -1
- package/lib/mol-canvas3d/canvas3d.d.ts +14 -2
- package/lib/mol-canvas3d/canvas3d.js +2 -2
- package/lib/mol-canvas3d/controls/trackball.js +1 -1
- package/lib/mol-canvas3d/helper/handle-helper.d.ts +1 -0
- package/lib/mol-canvas3d/helper/helper.d.ts +2 -0
- package/lib/mol-canvas3d/passes/background.d.ts +6 -1
- package/lib/mol-canvas3d/passes/background.js +14 -2
- package/lib/mol-canvas3d/passes/bloom.d.ts +37 -0
- package/lib/mol-canvas3d/passes/bloom.js +268 -0
- package/lib/mol-canvas3d/passes/dpoit.js +4 -2
- package/lib/mol-canvas3d/passes/draw.d.ts +11 -7
- package/lib/mol-canvas3d/passes/draw.js +30 -4
- package/lib/mol-canvas3d/passes/image.d.ts +6 -0
- package/lib/mol-canvas3d/passes/postprocessing.d.ts +31 -5
- package/lib/mol-canvas3d/passes/postprocessing.js +33 -39
- package/lib/mol-geo/geometry/base.d.ts +3 -1
- package/lib/mol-geo/geometry/base.js +4 -1
- package/lib/mol-geo/geometry/cylinders/cylinders.d.ts +2 -1
- package/lib/mol-geo/geometry/cylinders/cylinders.js +4 -1
- package/lib/mol-geo/geometry/direct-volume/direct-volume.d.ts +2 -1
- package/lib/mol-geo/geometry/direct-volume/direct-volume.js +4 -1
- package/lib/mol-geo/geometry/emissive-data.d.ts +26 -0
- package/lib/mol-geo/geometry/emissive-data.js +72 -0
- package/lib/mol-geo/geometry/image/image.d.ts +2 -1
- package/lib/mol-geo/geometry/image/image.js +4 -1
- package/lib/mol-geo/geometry/lines/lines.d.ts +3 -2
- package/lib/mol-geo/geometry/lines/lines.js +4 -1
- package/lib/mol-geo/geometry/mesh/color-smoothing.d.ts +2 -1
- package/lib/mol-geo/geometry/mesh/color-smoothing.js +34 -1
- package/lib/mol-geo/geometry/mesh/mesh.d.ts +2 -1
- package/lib/mol-geo/geometry/mesh/mesh.js +11 -4
- package/lib/mol-geo/geometry/points/points.d.ts +3 -2
- package/lib/mol-geo/geometry/points/points.js +4 -1
- package/lib/mol-geo/geometry/spheres/spheres.d.ts +2 -2
- package/lib/mol-geo/geometry/spheres/spheres.js +7 -3
- package/lib/mol-geo/geometry/text/text.d.ts +2 -1
- package/lib/mol-geo/geometry/text/text.js +4 -1
- package/lib/mol-geo/geometry/texture-mesh/color-smoothing.d.ts +2 -1
- package/lib/mol-geo/geometry/texture-mesh/color-smoothing.js +32 -1
- package/lib/mol-geo/geometry/texture-mesh/texture-mesh.d.ts +3 -1
- package/lib/mol-geo/geometry/texture-mesh/texture-mesh.js +14 -4
- package/lib/mol-geo/util/location-iterator.d.ts +5 -2
- package/lib/mol-geo/util/location-iterator.js +8 -3
- package/lib/mol-gl/renderable/cylinders.d.ts +10 -0
- package/lib/mol-gl/renderable/direct-volume.d.ts +10 -0
- package/lib/mol-gl/renderable/image.d.ts +10 -0
- package/lib/mol-gl/renderable/lines.d.ts +10 -0
- package/lib/mol-gl/renderable/mesh.d.ts +10 -0
- package/lib/mol-gl/renderable/points.d.ts +10 -0
- package/lib/mol-gl/renderable/schema.d.ts +24 -1
- package/lib/mol-gl/renderable/schema.js +14 -1
- package/lib/mol-gl/renderable/spheres.d.ts +10 -0
- package/lib/mol-gl/renderable/text.d.ts +10 -0
- package/lib/mol-gl/renderable/texture-mesh.d.ts +10 -0
- package/lib/mol-gl/renderable.d.ts +1 -1
- package/lib/mol-gl/renderable.js +2 -2
- package/lib/mol-gl/renderer.d.ts +2 -1
- package/lib/mol-gl/renderer.js +58 -49
- package/lib/mol-gl/scene.d.ts +3 -1
- package/lib/mol-gl/scene.js +26 -1
- package/lib/mol-gl/shader/background.frag.d.ts +1 -1
- package/lib/mol-gl/shader/background.frag.js +95 -94
- package/lib/mol-gl/shader/background.vert.js +11 -11
- package/lib/mol-gl/shader/blend-back-dpoit.frag.js +13 -13
- package/lib/mol-gl/shader/bloom/blur.frag.d.ts +1 -0
- package/lib/mol-gl/shader/bloom/blur.frag.js +29 -0
- package/lib/mol-gl/shader/bloom/composite.frag.d.ts +1 -0
- package/lib/mol-gl/shader/bloom/composite.frag.js +34 -0
- package/lib/mol-gl/shader/bloom/luminosity.frag.d.ts +1 -0
- package/lib/mol-gl/shader/bloom/luminosity.frag.js +53 -0
- package/lib/mol-gl/shader/cas.frag.js +144 -144
- package/lib/mol-gl/shader/chunks/apply-fog.glsl.js +31 -31
- package/lib/mol-gl/shader/chunks/apply-interior-color.glsl.js +12 -12
- package/lib/mol-gl/shader/chunks/apply-light-color.glsl.d.ts +2 -2
- package/lib/mol-gl/shader/chunks/apply-light-color.glsl.js +78 -70
- package/lib/mol-gl/shader/chunks/apply-marker-color.glsl.js +16 -16
- package/lib/mol-gl/shader/chunks/assign-clipping-varying.glsl.js +8 -8
- package/lib/mol-gl/shader/chunks/assign-color-varying.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/assign-color-varying.glsl.js +140 -112
- package/lib/mol-gl/shader/chunks/assign-group.glsl.js +6 -6
- package/lib/mol-gl/shader/chunks/assign-marker-varying.glsl.js +8 -8
- package/lib/mol-gl/shader/chunks/assign-material-color.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/assign-material-color.glsl.js +112 -123
- package/lib/mol-gl/shader/chunks/assign-position.glsl.js +14 -14
- package/lib/mol-gl/shader/chunks/assign-size.glsl.js +18 -18
- package/lib/mol-gl/shader/chunks/check-picking-alpha.glsl.js +12 -12
- package/lib/mol-gl/shader/chunks/check-transparency.glsl.d.ts +1 -0
- package/lib/mol-gl/shader/chunks/check-transparency.glsl.js +17 -0
- package/lib/mol-gl/shader/chunks/clip-instance.glsl.js +7 -7
- package/lib/mol-gl/shader/chunks/clip-pixel.glsl.js +5 -5
- package/lib/mol-gl/shader/chunks/color-frag-params.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/color-frag-params.glsl.js +60 -51
- package/lib/mol-gl/shader/chunks/color-vert-params.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/color-vert-params.glsl.js +122 -92
- package/lib/mol-gl/shader/chunks/common-clip.glsl.js +104 -104
- package/lib/mol-gl/shader/chunks/common-frag-params.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/common-frag-params.glsl.js +150 -149
- package/lib/mol-gl/shader/chunks/common-vert-params.glsl.js +61 -61
- package/lib/mol-gl/shader/chunks/common.glsl.js +234 -234
- package/lib/mol-gl/shader/chunks/dpoit-write.glsl.js +62 -62
- package/lib/mol-gl/shader/chunks/fade-lod.glsl.js +42 -42
- package/lib/mol-gl/shader/chunks/float-to-rgba.glsl.js +39 -39
- package/lib/mol-gl/shader/chunks/light-frag-params.glsl.js +127 -127
- package/lib/mol-gl/shader/chunks/matrix-scale.glsl.js +5 -5
- package/lib/mol-gl/shader/chunks/normal-frag-params.glsl.js +2 -2
- package/lib/mol-gl/shader/chunks/read-from-texture.glsl.js +14 -14
- package/lib/mol-gl/shader/chunks/rgba-to-float.glsl.js +84 -84
- package/lib/mol-gl/shader/chunks/size-vert-params.glsl.js +11 -11
- package/lib/mol-gl/shader/chunks/texture3d-from-1d-trilinear.glsl.js +23 -23
- package/lib/mol-gl/shader/chunks/texture3d-from-2d-linear.glsl.js +17 -17
- package/lib/mol-gl/shader/chunks/texture3d-from-2d-nearest.glsl.js +8 -8
- package/lib/mol-gl/shader/chunks/wboit-write.glsl.js +25 -25
- package/lib/mol-gl/shader/compose.frag.js +12 -12
- package/lib/mol-gl/shader/compute/color-smoothing/accumulate.frag.js +23 -23
- package/lib/mol-gl/shader/compute/color-smoothing/accumulate.vert.js +43 -43
- package/lib/mol-gl/shader/compute/color-smoothing/normalize.frag.js +15 -15
- package/lib/mol-gl/shader/copy.frag.js +11 -11
- package/lib/mol-gl/shader/cylinders.frag.d.ts +2 -2
- package/lib/mol-gl/shader/cylinders.frag.js +267 -264
- package/lib/mol-gl/shader/cylinders.vert.js +89 -89
- package/lib/mol-gl/shader/depth-merge.frag.js +23 -23
- package/lib/mol-gl/shader/direct-volume.frag.d.ts +1 -1
- package/lib/mol-gl/shader/direct-volume.frag.js +362 -356
- package/lib/mol-gl/shader/direct-volume.vert.js +41 -41
- package/lib/mol-gl/shader/evaluate-dpoit.frag.js +10 -10
- package/lib/mol-gl/shader/evaluate-wboit.frag.js +17 -17
- package/lib/mol-gl/shader/fxaa.frag.js +228 -228
- package/lib/mol-gl/shader/gaussian-density.frag.js +49 -49
- package/lib/mol-gl/shader/gaussian-density.vert.js +27 -27
- package/lib/mol-gl/shader/hi-z.frag.js +18 -18
- package/lib/mol-gl/shader/histogram-pyramid/reduction.frag.js +58 -58
- package/lib/mol-gl/shader/histogram-pyramid/sum.frag.js +19 -19
- package/lib/mol-gl/shader/image.frag.d.ts +2 -2
- package/lib/mol-gl/shader/image.frag.js +170 -161
- package/lib/mol-gl/shader/image.vert.js +21 -21
- package/lib/mol-gl/shader/lines.frag.d.ts +2 -2
- package/lib/mol-gl/shader/lines.frag.js +43 -40
- package/lib/mol-gl/shader/lines.vert.js +117 -117
- package/lib/mol-gl/shader/marching-cubes/active-voxels.frag.js +70 -70
- package/lib/mol-gl/shader/marching-cubes/isosurface.frag.js +311 -311
- package/lib/mol-gl/shader/marking/edge.frag.js +28 -28
- package/lib/mol-gl/shader/marking/overlay.frag.js +26 -26
- package/lib/mol-gl/shader/mesh.frag.d.ts +2 -2
- package/lib/mol-gl/shader/mesh.frag.js +66 -63
- package/lib/mol-gl/shader/mesh.vert.js +49 -49
- package/lib/mol-gl/shader/outlines.frag.js +95 -95
- package/lib/mol-gl/shader/points.frag.d.ts +2 -2
- package/lib/mol-gl/shader/points.frag.js +60 -56
- package/lib/mol-gl/shader/points.vert.js +38 -38
- package/lib/mol-gl/shader/postprocessing.frag.js +150 -150
- package/lib/mol-gl/shader/quad.vert.js +10 -10
- package/lib/mol-gl/shader/shadows.frag.js +123 -123
- package/lib/mol-gl/shader/smaa/blend.frag.js +56 -56
- package/lib/mol-gl/shader/smaa/blend.vert.js +25 -25
- package/lib/mol-gl/shader/smaa/edges.frag.js +66 -66
- package/lib/mol-gl/shader/smaa/edges.vert.js +26 -26
- package/lib/mol-gl/shader/smaa/weights.frag.js +206 -206
- package/lib/mol-gl/shader/smaa/weights.vert.js +32 -32
- package/lib/mol-gl/shader/spheres.frag.d.ts +2 -2
- package/lib/mol-gl/shader/spheres.frag.js +149 -143
- package/lib/mol-gl/shader/spheres.vert.js +132 -132
- package/lib/mol-gl/shader/ssao-blur.frag.d.ts +3 -2
- package/lib/mol-gl/shader/ssao-blur.frag.js +99 -100
- package/lib/mol-gl/shader/ssao.frag.d.ts +3 -2
- package/lib/mol-gl/shader/ssao.frag.js +213 -174
- package/lib/mol-gl/shader/text.frag.d.ts +2 -2
- package/lib/mol-gl/shader/text.frag.js +86 -84
- package/lib/mol-gl/shader/text.vert.js +85 -85
- package/lib/mol-gl/shader/util/grid3d-template.frag.js +46 -46
- package/lib/mol-gl/shader-code.d.ts +1 -1
- package/lib/mol-gl/shader-code.js +24 -18
- package/lib/mol-gl/webgl/compat.js +12 -12
- package/lib/mol-gl/webgl/render-item.d.ts +3 -2
- package/lib/mol-gl/webgl/render-item.js +1 -1
- package/lib/mol-io/common/binary-cif/array-encoder.d.ts +1 -1
- package/lib/mol-io/common/binary-cif/array-encoder.js +5 -2
- package/lib/mol-io/reader/cif/schema/bird.d.ts +1 -1
- package/lib/mol-io/reader/cif/schema/bird.js +1 -1
- package/lib/mol-io/reader/cif/schema/ccd-extras.d.ts +4 -4
- package/lib/mol-io/reader/cif/schema/ccd.d.ts +1 -1
- package/lib/mol-io/reader/cif/schema/ccd.js +1 -1
- package/lib/mol-io/reader/cif/schema/mmcif.d.ts +1 -1
- package/lib/mol-io/reader/cif/schema/mmcif.js +1 -1
- package/lib/mol-io/reader/cif.d.ts +1 -1
- package/lib/mol-io/writer/cif/encoder/binary.d.ts +1 -1
- package/lib/mol-io/writer/cif/encoder/binary.js +10 -2
- package/lib/mol-math/linear-algebra/3d/mat3.d.ts +3 -1
- package/lib/mol-math/linear-algebra/3d/mat3.js +8 -1
- package/lib/mol-math/linear-algebra/3d/vec3.d.ts +6 -0
- package/lib/mol-math/linear-algebra/3d/vec3.js +20 -0
- package/lib/mol-model/structure/model/types/saccharides.js +1 -1
- package/lib/mol-model/structure/structure/properties.d.ts +2 -2
- package/lib/mol-model/structure/structure/unit/bonds/data.d.ts +9 -6
- package/lib/mol-model/structure/structure/unit/bonds/data.js +1 -1
- package/lib/mol-model/structure/structure/unit/bonds/inter-compute.d.ts +1 -1
- package/lib/mol-model/structure/structure/unit/bonds/inter-compute.js +7 -4
- package/lib/mol-model/structure/structure/unit/bonds/intra-compute.d.ts +1 -1
- package/lib/mol-model/structure/structure/unit/bonds/intra-compute.js +10 -6
- package/lib/mol-model/structure/structure/unit.d.ts +2 -2
- package/lib/mol-model/structure/structure/unit.js +5 -2
- package/lib/mol-model-formats/shape/ply.d.ts +2 -0
- package/lib/mol-model-formats/structure/basic/schema.d.ts +118 -118
- package/lib/mol-model-formats/structure/common/component.d.ts +2 -2
- package/lib/mol-model-formats/structure/property/bonds/index-pair.d.ts +4 -1
- package/lib/mol-model-formats/structure/property/bonds/index-pair.js +6 -3
- package/lib/mol-model-props/computed/representations/interactions-inter-unit-cylinder.d.ts +1 -0
- package/lib/mol-model-props/computed/representations/interactions-intra-unit-cylinder.d.ts +1 -0
- package/lib/mol-model-props/computed/representations/interactions.d.ts +3 -0
- package/lib/mol-model-props/integrative/cross-link-restraint/representation.d.ts +4 -0
- package/lib/mol-plugin/behavior/behavior.d.ts +6 -6
- package/lib/mol-plugin/behavior/dynamic/camera.d.ts +3 -3
- package/lib/mol-plugin/behavior/dynamic/custom-props/computed/accessible-surface-area.d.ts +1 -1
- package/lib/mol-plugin/behavior/dynamic/custom-props/computed/interactions.d.ts +1 -1
- package/lib/mol-plugin/behavior/dynamic/custom-props/computed/secondary-structure.d.ts +1 -1
- package/lib/mol-plugin/behavior/dynamic/custom-props/computed/valence-model.d.ts +1 -1
- package/lib/mol-plugin/behavior/dynamic/custom-props/integrative/cross-link-restraint.d.ts +1 -1
- package/lib/mol-plugin/behavior/dynamic/custom-props/sequence/sifts-mapping.d.ts +1 -1
- package/lib/mol-plugin/behavior/dynamic/custom-props/structure-info.d.ts +1 -1
- package/lib/mol-plugin/behavior/dynamic/representation.d.ts +4 -4
- package/lib/mol-plugin/behavior/dynamic/selection/structure-focus-representation.d.ts +1 -1
- package/lib/mol-plugin/behavior/dynamic/volume-streaming/behavior.d.ts +2 -2
- package/lib/mol-plugin/behavior/dynamic/volume-streaming/model.d.ts +2 -2
- package/lib/mol-plugin/commands.d.ts +1 -208
- package/lib/mol-plugin/config.d.ts +5 -0
- package/lib/mol-plugin/context.d.ts +2 -2
- package/lib/mol-plugin/state.d.ts +6 -6
- package/lib/mol-plugin/version.js +2 -2
- package/lib/mol-plugin-state/actions/structure.d.ts +3 -3
- package/lib/mol-plugin-state/actions/structure.js +3 -5
- package/lib/mol-plugin-state/actions/volume.d.ts +1 -1
- package/lib/mol-plugin-state/builder/data.d.ts +4 -4
- package/lib/mol-plugin-state/builder/structure/hierarchy-preset.d.ts +27 -27
- package/lib/mol-plugin-state/builder/structure/hierarchy.d.ts +5 -5
- package/lib/mol-plugin-state/builder/structure/representation-preset.d.ts +42 -42
- package/lib/mol-plugin-state/builder/structure/representation.d.ts +4 -4
- package/lib/mol-plugin-state/builder/structure.d.ts +7 -7
- package/lib/mol-plugin-state/formats/coordinates.d.ts +8 -8
- package/lib/mol-plugin-state/formats/shape.d.ts +8 -8
- package/lib/mol-plugin-state/formats/topology.d.ts +12 -12
- package/lib/mol-plugin-state/formats/volume.d.ts +33 -33
- package/lib/mol-plugin-state/helpers/structure-emissive.d.ts +12 -0
- package/lib/mol-plugin-state/helpers/structure-emissive.js +64 -0
- package/lib/mol-plugin-state/helpers/structure-selection-query.d.ts +1 -1
- package/lib/mol-plugin-state/manager/structure/component.d.ts +3 -1
- package/lib/mol-plugin-state/manager/structure/component.js +9 -1
- package/lib/mol-plugin-state/manager/structure/measurement.d.ts +341 -9
- package/lib/mol-plugin-state/manager/structure/measurement.js +32 -19
- package/lib/mol-plugin-state/manager/structure/selection.d.ts +1 -1
- package/lib/mol-plugin-state/manager/volume/hierarchy.d.ts +1 -1
- package/lib/mol-plugin-state/objects.d.ts +32 -32
- package/lib/mol-plugin-state/transforms/representation.d.ts +33 -8
- package/lib/mol-plugin-state/transforms/representation.js +120 -5
- package/lib/mol-plugin-state/transforms/shape.d.ts +1 -1
- package/lib/mol-plugin-state/transforms/volume.d.ts +16 -8
- package/lib/mol-plugin-state/transforms/volume.js +51 -2
- package/lib/mol-plugin-ui/skin/base/base.scss +37 -37
- package/lib/mol-plugin-ui/skin/base/components/controls-base.scss +333 -333
- package/lib/mol-plugin-ui/skin/base/components/controls.scss +445 -445
- package/lib/mol-plugin-ui/skin/base/components/help.scss +27 -27
- package/lib/mol-plugin-ui/skin/base/components/line-graph.scss +67 -67
- package/lib/mol-plugin-ui/skin/base/components/log.scss +100 -100
- package/lib/mol-plugin-ui/skin/base/components/misc.scss +663 -663
- package/lib/mol-plugin-ui/skin/base/components/sequence.scss +125 -125
- package/lib/mol-plugin-ui/skin/base/components/slider.scss +165 -165
- package/lib/mol-plugin-ui/skin/base/components/tasks.scss +99 -99
- package/lib/mol-plugin-ui/skin/base/components/toast.scss +83 -83
- package/lib/mol-plugin-ui/skin/base/components/transformer.scss +163 -163
- package/lib/mol-plugin-ui/skin/base/components/viewport.scss +194 -194
- package/lib/mol-plugin-ui/skin/base/layout/common.scss +71 -71
- package/lib/mol-plugin-ui/skin/base/layout/controls-landscape.scss +89 -89
- package/lib/mol-plugin-ui/skin/base/layout/controls-outside.scss +98 -98
- package/lib/mol-plugin-ui/skin/base/layout/controls-portrait.scss +108 -108
- package/lib/mol-plugin-ui/skin/base/layout.scss +40 -40
- package/lib/mol-plugin-ui/skin/base/logo.scss +12 -12
- package/lib/mol-plugin-ui/skin/base/normalize.scss +209 -209
- package/lib/mol-plugin-ui/skin/base/ui.scss +40 -40
- package/lib/mol-plugin-ui/skin/base/variables.scss +88 -88
- package/lib/mol-plugin-ui/skin/blue.scss +1 -1
- package/lib/mol-plugin-ui/skin/colors/blue.scss +23 -23
- package/lib/mol-plugin-ui/skin/colors/dark.scss +23 -23
- package/lib/mol-plugin-ui/skin/colors/light.scss +29 -29
- package/lib/mol-plugin-ui/skin/dark.scss +1 -1
- package/lib/mol-plugin-ui/skin/light.scss +1 -1
- package/lib/mol-plugin-ui/state/apply-action.d.ts +2 -2
- package/lib/mol-plugin-ui/state/update-transform.d.ts +3 -3
- package/lib/mol-repr/representation.d.ts +6 -2
- package/lib/mol-repr/representation.js +12 -2
- package/lib/mol-repr/shape/loci/angle.d.ts +1 -0
- package/lib/mol-repr/shape/loci/common.d.ts +1 -0
- package/lib/mol-repr/shape/loci/dihedral.d.ts +1 -0
- package/lib/mol-repr/shape/loci/distance.d.ts +1 -0
- package/lib/mol-repr/shape/loci/label.d.ts +1 -0
- package/lib/mol-repr/shape/loci/orientation.d.ts +1 -0
- package/lib/mol-repr/shape/loci/plane.d.ts +1 -0
- package/lib/mol-repr/shape/model/unitcell.d.ts +1 -0
- package/lib/mol-repr/structure/complex-representation.d.ts +1 -1
- package/lib/mol-repr/structure/complex-representation.js +7 -1
- package/lib/mol-repr/structure/complex-visual.d.ts +8 -1
- package/lib/mol-repr/structure/complex-visual.js +5 -1
- package/lib/mol-repr/structure/params.d.ts +8 -0
- package/lib/mol-repr/structure/registry.d.ts +14 -0
- package/lib/mol-repr/structure/representation/backbone.d.ts +3 -0
- package/lib/mol-repr/structure/representation/ball-and-stick.d.ts +3 -0
- package/lib/mol-repr/structure/representation/carbohydrate.d.ts +3 -0
- package/lib/mol-repr/structure/representation/cartoon.d.ts +3 -0
- package/lib/mol-repr/structure/representation/ellipsoid.d.ts +3 -0
- package/lib/mol-repr/structure/representation/gaussian-surface.d.ts +3 -0
- package/lib/mol-repr/structure/representation/gaussian-volume.d.ts +3 -0
- package/lib/mol-repr/structure/representation/label.d.ts +3 -0
- package/lib/mol-repr/structure/representation/line.d.ts +3 -0
- package/lib/mol-repr/structure/representation/molecular-surface.d.ts +3 -0
- package/lib/mol-repr/structure/representation/orientation.d.ts +3 -0
- package/lib/mol-repr/structure/representation/point.d.ts +3 -0
- package/lib/mol-repr/structure/representation/putty.d.ts +3 -0
- package/lib/mol-repr/structure/representation/spacefill.d.ts +3 -0
- package/lib/mol-repr/structure/units-representation.d.ts +1 -1
- package/lib/mol-repr/structure/units-representation.js +9 -3
- package/lib/mol-repr/structure/units-visual.d.ts +9 -1
- package/lib/mol-repr/structure/units-visual.js +5 -1
- package/lib/mol-repr/structure/visual/bond-inter-unit-cylinder.d.ts +2 -0
- package/lib/mol-repr/structure/visual/bond-inter-unit-line.d.ts +1 -0
- package/lib/mol-repr/structure/visual/bond-intra-unit-cylinder.d.ts +2 -0
- package/lib/mol-repr/structure/visual/bond-intra-unit-line.d.ts +1 -0
- package/lib/mol-repr/structure/visual/carbohydrate-link-cylinder.d.ts +1 -0
- package/lib/mol-repr/structure/visual/carbohydrate-symbol-mesh.d.ts +1 -0
- package/lib/mol-repr/structure/visual/carbohydrate-terminal-link-cylinder.d.ts +1 -0
- package/lib/mol-repr/structure/visual/element-cross.d.ts +1 -0
- package/lib/mol-repr/structure/visual/element-point.d.ts +1 -0
- package/lib/mol-repr/structure/visual/element-sphere.d.ts +4 -0
- package/lib/mol-repr/structure/visual/ellipsoid-mesh.d.ts +1 -0
- package/lib/mol-repr/structure/visual/gaussian-density-volume.d.ts +2 -0
- package/lib/mol-repr/structure/visual/gaussian-surface-mesh.d.ts +4 -0
- package/lib/mol-repr/structure/visual/gaussian-surface-mesh.js +1 -1
- package/lib/mol-repr/structure/visual/gaussian-surface-wireframe.d.ts +1 -0
- package/lib/mol-repr/structure/visual/label-text.d.ts +1 -0
- package/lib/mol-repr/structure/visual/molecular-surface-mesh.d.ts +1 -0
- package/lib/mol-repr/structure/visual/molecular-surface-wireframe.d.ts +1 -0
- package/lib/mol-repr/structure/visual/nucleotide-atomic-bond.d.ts +2 -0
- package/lib/mol-repr/structure/visual/nucleotide-atomic-element.d.ts +2 -0
- package/lib/mol-repr/structure/visual/nucleotide-atomic-ring-fill.d.ts +1 -0
- package/lib/mol-repr/structure/visual/nucleotide-block-mesh.d.ts +1 -0
- package/lib/mol-repr/structure/visual/nucleotide-ring-mesh.d.ts +1 -0
- package/lib/mol-repr/structure/visual/orientation-ellipsoid-mesh.d.ts +1 -0
- package/lib/mol-repr/structure/visual/polymer-backbone-cylinder.d.ts +2 -0
- package/lib/mol-repr/structure/visual/polymer-backbone-sphere.d.ts +2 -0
- package/lib/mol-repr/structure/visual/polymer-direction-wedge.d.ts +1 -0
- package/lib/mol-repr/structure/visual/polymer-gap-cylinder.d.ts +1 -0
- package/lib/mol-repr/structure/visual/polymer-trace-mesh.d.ts +1 -0
- package/lib/mol-repr/structure/visual/polymer-tube-mesh.d.ts +1 -0
- package/lib/mol-repr/visual.d.ts +6 -1
- package/lib/mol-repr/visual.js +57 -3
- package/lib/mol-repr/volume/direct-volume.d.ts +3 -0
- package/lib/mol-repr/volume/isosurface.d.ts +6 -0
- package/lib/mol-repr/volume/registry.d.ts +4 -0
- package/lib/mol-repr/volume/representation.d.ts +2 -1
- package/lib/mol-repr/volume/representation.js +9 -2
- package/lib/mol-repr/volume/segment.d.ts +5 -0
- package/lib/mol-repr/volume/slice.d.ts +3 -0
- package/lib/mol-script/language/symbol-table/core.d.ts +3 -3
- package/lib/mol-state/tree/immutable.d.ts +1 -1
- package/lib/mol-state/tree/transient.d.ts +2 -2
- package/lib/mol-theme/color/external-volume.d.ts +3 -1
- package/lib/mol-theme/color/external-volume.js +8 -2
- package/lib/mol-theme/color.d.ts +1 -0
- package/lib/mol-theme/emissive.d.ts +40 -0
- package/lib/mol-theme/emissive.js +134 -0
- package/lib/mol-theme/substance.d.ts +1 -1
- package/lib/mol-theme/substance.js +2 -2
- package/lib/mol-theme/transparency.d.ts +0 -1
- package/lib/mol-util/input/input-observer.js +2 -0
- package/lib/mol-util/set.d.ts +1 -1
- package/lib/mol-util/set.js +17 -1
- package/lib/servers/common/swagger-ui/indexTemplate.js +66 -66
- package/lib/servers/volume/config.js +5 -5
- package/package.json +195 -193
|
@@ -1,312 +1,312 @@
|
|
|
1
|
-
export const isosurface_frag = `
|
|
2
|
-
precision highp float;
|
|
3
|
-
precision highp int;
|
|
4
|
-
precision highp sampler2D;
|
|
5
|
-
|
|
6
|
-
#if __VERSION__ == 100
|
|
7
|
-
uniform sampler2D tActiveVoxelsPyramid;
|
|
8
|
-
#else
|
|
9
|
-
precision highp isampler2D;
|
|
10
|
-
uniform isampler2D tActiveVoxelsPyramid;
|
|
11
|
-
#endif
|
|
12
|
-
|
|
13
|
-
uniform sampler2D tActiveVoxelsBase;
|
|
14
|
-
uniform sampler2D tVolumeData;
|
|
15
|
-
uniform sampler2D tTriIndices;
|
|
16
|
-
|
|
17
|
-
uniform float uIsoValue;
|
|
18
|
-
uniform float uLevels;
|
|
19
|
-
uniform float uSize;
|
|
20
|
-
uniform float uCount;
|
|
21
|
-
uniform bool uInvert;
|
|
22
|
-
|
|
23
|
-
uniform vec3 uGridDim;
|
|
24
|
-
uniform vec3 uGridTexDim;
|
|
25
|
-
uniform mat4 uGridTransform;
|
|
26
|
-
|
|
27
|
-
// scale to volume data coord
|
|
28
|
-
uniform vec2 uScale;
|
|
29
|
-
|
|
30
|
-
#include common
|
|
31
|
-
|
|
32
|
-
// cube corners (excluding origin)
|
|
33
|
-
const vec3 c1 = vec3(1., 0., 0.);
|
|
34
|
-
const vec3 c2 = vec3(1., 1., 0.);
|
|
35
|
-
const vec3 c3 = vec3(0., 1., 0.);
|
|
36
|
-
const vec3 c4 = vec3(0., 0., 1.);
|
|
37
|
-
const vec3 c5 = vec3(1., 0., 1.);
|
|
38
|
-
const vec3 c6 = vec3(1., 1., 1.);
|
|
39
|
-
const vec3 c7 = vec3(0., 1., 1.);
|
|
40
|
-
|
|
41
|
-
vec3 index3dFrom2d(vec2 coord) {
|
|
42
|
-
vec2 gridTexPos = coord * uGridTexDim.xy;
|
|
43
|
-
vec2 columnRow = ivec2Div(gridTexPos, uGridDim.xy);
|
|
44
|
-
vec2 posXY = gridTexPos - columnRow * uGridDim.xy;
|
|
45
|
-
float posZ = columnRow.y * intDiv(uGridTexDim.x, uGridDim.x) + columnRow.x;
|
|
46
|
-
return vec3(posXY, posZ);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
vec4 texture3dFrom2dNearest(sampler2D tex, vec3 pos, vec3 gridDim, vec2 texDim) {
|
|
50
|
-
float zSlice = floor(pos.z * gridDim.z + 0.5); // round to nearest z-slice
|
|
51
|
-
float column = intDiv(intMod(zSlice * gridDim.x, texDim.x), gridDim.x);
|
|
52
|
-
float row = intDiv(zSlice * gridDim.x, texDim.x);
|
|
53
|
-
vec2 coord = (vec2(column * gridDim.x, row * gridDim.y) + (pos.xy * gridDim.xy)) / (texDim / uScale);
|
|
54
|
-
return texture2D(tex, coord + 0.5 / (texDim / uScale));
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
vec4 voxel(vec3 pos) {
|
|
58
|
-
pos = min(max(vec3(0.0), pos), uGridDim - vec3(1.0));
|
|
59
|
-
return texture3dFrom2dNearest(tVolumeData, pos / uGridDim, uGridDim, uGridTexDim.xy);
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
vec4 voxelPadded(vec3 pos) {
|
|
63
|
-
pos = min(max(vec3(0.0), pos), uGridDim - vec3(vec2(2.0), 1.0)); // remove xy padding
|
|
64
|
-
return texture3dFrom2dNearest(tVolumeData, pos / uGridDim, uGridDim, uGridTexDim.xy);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
int idot2(const in ivec2 a, const in ivec2 b) {
|
|
68
|
-
return a.x * b.x + a.y * b.y;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
int idot4(const in ivec4 a, const in ivec4 b) {
|
|
72
|
-
return a.x * b.x + a.y * b.y + a.z * b.z + a.w * b.w;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
#if __VERSION__ == 100
|
|
76
|
-
int pyramidVoxel(vec2 pos) {
|
|
77
|
-
return int(unpackRGBToInt(texture2D(tActiveVoxelsPyramid, pos / (vec2(1.0, 0.5) * uSize)).rgb));
|
|
78
|
-
}
|
|
79
|
-
#else
|
|
80
|
-
int pyramidVoxel(vec2 pos) {
|
|
81
|
-
return texture2D(tActiveVoxelsPyramid, pos / (vec2(1.0, 0.5) * uSize)).r;
|
|
82
|
-
}
|
|
83
|
-
#endif
|
|
84
|
-
|
|
85
|
-
vec4 baseVoxel(vec2 pos) {
|
|
86
|
-
return texture2D(tActiveVoxelsBase, pos / uSize);
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
vec4 getGroup(const in vec3 p) {
|
|
90
|
-
vec3 gridDim = uGridDim - vec3(1.0, 1.0, 0.0); // remove xy padding
|
|
91
|
-
// note that we swap x and z because the texture is flipped around y
|
|
92
|
-
#if defined(dAxisOrder_012)
|
|
93
|
-
float group = p.z + p.y * gridDim.z + p.x * gridDim.z * gridDim.y; // 210
|
|
94
|
-
#elif defined(dAxisOrder_021)
|
|
95
|
-
float group = p.y + p.z * gridDim.y + p.x * gridDim.y * gridDim.z; // 120
|
|
96
|
-
#elif defined(dAxisOrder_102)
|
|
97
|
-
float group = p.z + p.x * gridDim.z + p.y * gridDim.z * gridDim.x; // 201
|
|
98
|
-
#elif defined(dAxisOrder_120)
|
|
99
|
-
float group = p.x + p.z * gridDim.x + p.y * gridDim.x * gridDim.z; // 021
|
|
100
|
-
#elif defined(dAxisOrder_201)
|
|
101
|
-
float group = p.y + p.x * gridDim.y + p.z * gridDim.y * gridDim.x; // 102
|
|
102
|
-
#elif defined(dAxisOrder_210)
|
|
103
|
-
float group = p.x + p.y * gridDim.x + p.z * gridDim.x * gridDim.y; // 012
|
|
104
|
-
#endif
|
|
105
|
-
return vec4(group > 16777215.5 ? vec3(1.0) : packIntToRGB(group), 1.0);
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
void main(void) {
|
|
109
|
-
// get 1D index
|
|
110
|
-
int vI = int(gl_FragCoord.x) + int(gl_FragCoord.y) * int(uSize);
|
|
111
|
-
|
|
112
|
-
// ignore 1D indices outside of the grid
|
|
113
|
-
if(vI >= int(uCount)) discard;
|
|
114
|
-
|
|
115
|
-
ivec2 offset = ivec2(int(uSize) - 2, 0);
|
|
116
|
-
|
|
117
|
-
int start = 0;
|
|
118
|
-
ivec4 starts = ivec4(0);
|
|
119
|
-
ivec4 ends = ivec4(0);
|
|
120
|
-
int diff = 2;
|
|
121
|
-
ivec4 m = ivec4(0);
|
|
122
|
-
ivec2 position = ivec2(0);
|
|
123
|
-
ivec4 vI4 = ivec4(vI);
|
|
124
|
-
|
|
125
|
-
ivec2 relativePosition = ivec2(0);
|
|
126
|
-
int end = 0;
|
|
127
|
-
ivec2 pos1 = ivec2(0);
|
|
128
|
-
ivec2 pos2 = ivec2(0);
|
|
129
|
-
ivec2 pos3 = ivec2(0);
|
|
130
|
-
ivec2 pos4 = ivec2(0);
|
|
131
|
-
ivec3 vI3 = ivec3(vI);
|
|
132
|
-
ivec3 mask = ivec3(0);
|
|
133
|
-
|
|
134
|
-
// traverse the different levels of the pyramid
|
|
135
|
-
for(int i = 1; i < 14; i++) {
|
|
136
|
-
if(float(i) >= uLevels) break;
|
|
137
|
-
|
|
138
|
-
offset.x -= diff;
|
|
139
|
-
diff *= 2;
|
|
140
|
-
relativePosition = position + offset;
|
|
141
|
-
|
|
142
|
-
end = start + pyramidVoxel(vec2(relativePosition));
|
|
143
|
-
pos1 = ivec2(relativePosition);
|
|
144
|
-
starts.x = start;
|
|
145
|
-
ends.x = end;
|
|
146
|
-
pos2 = ivec2(relativePosition + ivec2(1, 0));
|
|
147
|
-
starts.y = ends.x;
|
|
148
|
-
ends.y = ends.x + pyramidVoxel(vec2(pos2));
|
|
149
|
-
pos3 = relativePosition + ivec2(0, 1);
|
|
150
|
-
starts.z = ends.y;
|
|
151
|
-
ends.z = ends.y + pyramidVoxel(vec2(pos3));
|
|
152
|
-
pos4 = relativePosition + ivec2(1, 1);
|
|
153
|
-
starts.w = ends.z;
|
|
154
|
-
mask = ivec3(greaterThanEqual(vI3, starts.rgb)) * ivec3(lessThan(vI3, ends.rgb));
|
|
155
|
-
m = ivec4(mask, 1 - int(any(bvec3(mask))));
|
|
156
|
-
|
|
157
|
-
relativePosition = m.x * pos1 + m.y * pos2 + m.z * pos3 + m.w * pos4;
|
|
158
|
-
start = idot4(m, starts);
|
|
159
|
-
position = 2 * (relativePosition - offset);
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
end = start + int(baseVoxel(vec2(position)).r * 255.0);
|
|
163
|
-
pos1 = position;
|
|
164
|
-
starts.x = start;
|
|
165
|
-
ends.x = end;
|
|
166
|
-
pos2 = position + ivec2(1, 0);
|
|
167
|
-
starts.y = ends.x;
|
|
168
|
-
ends.y = ends.x + int(baseVoxel(vec2(pos2)).r * 255.0);
|
|
169
|
-
pos3 = position + ivec2(0, 1);
|
|
170
|
-
starts.z = ends.y;
|
|
171
|
-
ends.z = ends.y + int(baseVoxel(vec2(pos3)).r * 255.0);
|
|
172
|
-
pos4 = position + ivec2(1, 1);
|
|
173
|
-
starts.w = ends.z;
|
|
174
|
-
mask = ivec3(greaterThanEqual(vI3, starts.rgb)) * ivec3(lessThan(vI3, ends.rgb));
|
|
175
|
-
m = ivec4(mask, 1 - int(any(bvec3(mask))));
|
|
176
|
-
position = m.x * pos1 + m.y * pos2 + m.z * pos3 + m.w * pos4;
|
|
177
|
-
|
|
178
|
-
vec2 coord2d = (vec2(position) / uSize) / uScale;
|
|
179
|
-
vec3 coord3d = floor(index3dFrom2d(coord2d) + 0.5);
|
|
180
|
-
|
|
181
|
-
float edgeIndex = floor(baseVoxel(vec2(position)).a * 255.0 + 0.5);
|
|
182
|
-
|
|
183
|
-
// current vertex for the up to 15 MC cases
|
|
184
|
-
int currentVertex = vI - idot4(m, starts);
|
|
185
|
-
|
|
186
|
-
// ensure winding-order is the same for negative and positive iso-levels
|
|
187
|
-
if (uInvert) {
|
|
188
|
-
int v = imod(currentVertex + 1, 3);
|
|
189
|
-
if (v == 1) currentVertex += 2;
|
|
190
|
-
else if (v == 0) currentVertex -= 2;
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
// get index into triIndices table
|
|
194
|
-
int mcIndex = 16 * int(edgeIndex) + currentVertex;
|
|
195
|
-
vec4 mcData = texture2D(tTriIndices, vec2(imod(mcIndex, 64), mcIndex / 64) / 64.);
|
|
196
|
-
|
|
197
|
-
// bit mask to avoid conditionals (see comment below) for getting MC case corner
|
|
198
|
-
vec4 m0 = vec4(floor(mcData.a * 255.0 + 0.5));
|
|
199
|
-
|
|
200
|
-
// get edge value masks
|
|
201
|
-
vec4 m1 = vec4(equal(m0, vec4(0., 1., 2., 3.)));
|
|
202
|
-
vec4 m2 = vec4(equal(m0, vec4(4., 5., 6., 7.)));
|
|
203
|
-
vec4 m3 = vec4(equal(m0, vec4(8., 9., 10., 11.)));
|
|
204
|
-
|
|
205
|
-
// apply bit masks
|
|
206
|
-
vec3 b0 = coord3d +
|
|
207
|
-
m1.y * c1 +
|
|
208
|
-
m1.z * c2 +
|
|
209
|
-
m1.w * c3 +
|
|
210
|
-
m2.x * c4 +
|
|
211
|
-
m2.y * c5 +
|
|
212
|
-
m2.z * c6 +
|
|
213
|
-
m2.w * c7 +
|
|
214
|
-
m3.y * c1 +
|
|
215
|
-
m3.z * c2 +
|
|
216
|
-
m3.w * c3;
|
|
217
|
-
vec3 b1 = coord3d +
|
|
218
|
-
m1.x * c1 +
|
|
219
|
-
m1.y * c2 +
|
|
220
|
-
m1.z * c3 +
|
|
221
|
-
m2.x * c5 +
|
|
222
|
-
m2.y * c6 +
|
|
223
|
-
m2.z * c7 +
|
|
224
|
-
m2.w * c4 +
|
|
225
|
-
m3.x * c4 +
|
|
226
|
-
m3.y * c5 +
|
|
227
|
-
m3.z * c6 +
|
|
228
|
-
m3.w * c7;
|
|
229
|
-
|
|
230
|
-
// the conditionals that are avoided by above bitmasks
|
|
231
|
-
// vec3 b0 = coord3d;
|
|
232
|
-
// vec3 b1 = coord3d;
|
|
233
|
-
// if (mcIndex == 0.0) {
|
|
234
|
-
// b1 += c1;
|
|
235
|
-
// } else if (mcIndex == 1.0) {
|
|
236
|
-
// b0 += c1; b1 += c2;
|
|
237
|
-
// } else if (mcIndex == 2.0) {
|
|
238
|
-
// b0 += c2; b1 += c3;
|
|
239
|
-
// } else if (mcIndex == 3.0) {
|
|
240
|
-
// b0 += c3;
|
|
241
|
-
// } else if (mcIndex == 4.0) {
|
|
242
|
-
// b0 += c4; b1 += c5;
|
|
243
|
-
// } else if (mcIndex == 5.0) {
|
|
244
|
-
// b0 += c5; b1 += c6;
|
|
245
|
-
// } else if (mcIndex == 6.0) {
|
|
246
|
-
// b0 += c6; b1 += c7;
|
|
247
|
-
// } else if (mcIndex == 7.0) {
|
|
248
|
-
// b0 += c7; b1 += c4;
|
|
249
|
-
// } else if (mcIndex == 8.0) {
|
|
250
|
-
// b1 += c4;
|
|
251
|
-
// } else if (mcIndex == 9.0) {
|
|
252
|
-
// b0 += c1; b1 += c5;
|
|
253
|
-
// } else if (mcIndex == 10.0) {
|
|
254
|
-
// b0 += c2; b1 += c6;
|
|
255
|
-
// } else if (mcIndex == 11.0) {
|
|
256
|
-
// b0 += c3; b1 += c7;
|
|
257
|
-
// }
|
|
258
|
-
// b0 = floor(b0 + 0.5);
|
|
259
|
-
// b1 = floor(b1 + 0.5);
|
|
260
|
-
|
|
261
|
-
vec4 d0 = voxel(b0);
|
|
262
|
-
vec4 d1 = voxel(b1);
|
|
263
|
-
|
|
264
|
-
float v0 = d0.a;
|
|
265
|
-
float v1 = d1.a;
|
|
266
|
-
|
|
267
|
-
float t = (uIsoValue - v0) / (v0 - v1);
|
|
268
|
-
gl_FragData[0].xyz = (uGridTransform * vec4(b0 + t * (b0 - b1), 1.0)).xyz;
|
|
269
|
-
|
|
270
|
-
// group id
|
|
271
|
-
#if __VERSION__ == 100 || defined(dConstantGroup)
|
|
272
|
-
// webgl1 does not support 'flat' interpolation (i.e. no interpolation)
|
|
273
|
-
// ensure a constant group id per triangle as needed
|
|
274
|
-
#ifdef dPackedGroup
|
|
275
|
-
gl_FragData[1] = vec4(voxel(coord3d).rgb, 1.0);
|
|
276
|
-
#else
|
|
277
|
-
gl_FragData[1] = getGroup(coord3d);
|
|
278
|
-
#endif
|
|
279
|
-
#else
|
|
280
|
-
#ifdef dPackedGroup
|
|
281
|
-
gl_FragData[1] = vec4(t < 0.5 ? d0.rgb : d1.rgb, 1.0);
|
|
282
|
-
#else
|
|
283
|
-
gl_FragData[1] = getGroup(t < 0.5 ? b0 : b1);
|
|
284
|
-
#endif
|
|
285
|
-
#endif
|
|
286
|
-
|
|
287
|
-
// normals from gradients
|
|
288
|
-
vec3 n0 = -normalize(vec3(
|
|
289
|
-
voxelPadded(b0 - c1).a - voxelPadded(b0 + c1).a,
|
|
290
|
-
voxelPadded(b0 - c3).a - voxelPadded(b0 + c3).a,
|
|
291
|
-
voxelPadded(b0 - c4).a - voxelPadded(b0 + c4).a
|
|
292
|
-
));
|
|
293
|
-
vec3 n1 = -normalize(vec3(
|
|
294
|
-
voxelPadded(b1 - c1).a - voxelPadded(b1 + c1).a,
|
|
295
|
-
voxelPadded(b1 - c3).a - voxelPadded(b1 + c3).a,
|
|
296
|
-
voxelPadded(b1 - c4).a - voxelPadded(b1 + c4).a
|
|
297
|
-
));
|
|
298
|
-
gl_FragData[2].xyz = -vec3(
|
|
299
|
-
n0.x + t * (n0.x - n1.x),
|
|
300
|
-
n0.y + t * (n0.y - n1.y),
|
|
301
|
-
n0.z + t * (n0.z - n1.z)
|
|
302
|
-
);
|
|
303
|
-
|
|
304
|
-
// ensure normal-direction is the same for negative and positive iso-levels
|
|
305
|
-
if (uInvert) {
|
|
306
|
-
gl_FragData[2].xyz *= -1.0;
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
// apply normal matrix
|
|
310
|
-
gl_FragData[2].xyz *= transpose3(inverse3(mat3(uGridTransform)));
|
|
311
|
-
}
|
|
1
|
+
export const isosurface_frag = `
|
|
2
|
+
precision highp float;
|
|
3
|
+
precision highp int;
|
|
4
|
+
precision highp sampler2D;
|
|
5
|
+
|
|
6
|
+
#if __VERSION__ == 100
|
|
7
|
+
uniform sampler2D tActiveVoxelsPyramid;
|
|
8
|
+
#else
|
|
9
|
+
precision highp isampler2D;
|
|
10
|
+
uniform isampler2D tActiveVoxelsPyramid;
|
|
11
|
+
#endif
|
|
12
|
+
|
|
13
|
+
uniform sampler2D tActiveVoxelsBase;
|
|
14
|
+
uniform sampler2D tVolumeData;
|
|
15
|
+
uniform sampler2D tTriIndices;
|
|
16
|
+
|
|
17
|
+
uniform float uIsoValue;
|
|
18
|
+
uniform float uLevels;
|
|
19
|
+
uniform float uSize;
|
|
20
|
+
uniform float uCount;
|
|
21
|
+
uniform bool uInvert;
|
|
22
|
+
|
|
23
|
+
uniform vec3 uGridDim;
|
|
24
|
+
uniform vec3 uGridTexDim;
|
|
25
|
+
uniform mat4 uGridTransform;
|
|
26
|
+
|
|
27
|
+
// scale to volume data coord
|
|
28
|
+
uniform vec2 uScale;
|
|
29
|
+
|
|
30
|
+
#include common
|
|
31
|
+
|
|
32
|
+
// cube corners (excluding origin)
|
|
33
|
+
const vec3 c1 = vec3(1., 0., 0.);
|
|
34
|
+
const vec3 c2 = vec3(1., 1., 0.);
|
|
35
|
+
const vec3 c3 = vec3(0., 1., 0.);
|
|
36
|
+
const vec3 c4 = vec3(0., 0., 1.);
|
|
37
|
+
const vec3 c5 = vec3(1., 0., 1.);
|
|
38
|
+
const vec3 c6 = vec3(1., 1., 1.);
|
|
39
|
+
const vec3 c7 = vec3(0., 1., 1.);
|
|
40
|
+
|
|
41
|
+
vec3 index3dFrom2d(vec2 coord) {
|
|
42
|
+
vec2 gridTexPos = coord * uGridTexDim.xy;
|
|
43
|
+
vec2 columnRow = ivec2Div(gridTexPos, uGridDim.xy);
|
|
44
|
+
vec2 posXY = gridTexPos - columnRow * uGridDim.xy;
|
|
45
|
+
float posZ = columnRow.y * intDiv(uGridTexDim.x, uGridDim.x) + columnRow.x;
|
|
46
|
+
return vec3(posXY, posZ);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
vec4 texture3dFrom2dNearest(sampler2D tex, vec3 pos, vec3 gridDim, vec2 texDim) {
|
|
50
|
+
float zSlice = floor(pos.z * gridDim.z + 0.5); // round to nearest z-slice
|
|
51
|
+
float column = intDiv(intMod(zSlice * gridDim.x, texDim.x), gridDim.x);
|
|
52
|
+
float row = intDiv(zSlice * gridDim.x, texDim.x);
|
|
53
|
+
vec2 coord = (vec2(column * gridDim.x, row * gridDim.y) + (pos.xy * gridDim.xy)) / (texDim / uScale);
|
|
54
|
+
return texture2D(tex, coord + 0.5 / (texDim / uScale));
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
vec4 voxel(vec3 pos) {
|
|
58
|
+
pos = min(max(vec3(0.0), pos), uGridDim - vec3(1.0));
|
|
59
|
+
return texture3dFrom2dNearest(tVolumeData, pos / uGridDim, uGridDim, uGridTexDim.xy);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
vec4 voxelPadded(vec3 pos) {
|
|
63
|
+
pos = min(max(vec3(0.0), pos), uGridDim - vec3(vec2(2.0), 1.0)); // remove xy padding
|
|
64
|
+
return texture3dFrom2dNearest(tVolumeData, pos / uGridDim, uGridDim, uGridTexDim.xy);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
int idot2(const in ivec2 a, const in ivec2 b) {
|
|
68
|
+
return a.x * b.x + a.y * b.y;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
int idot4(const in ivec4 a, const in ivec4 b) {
|
|
72
|
+
return a.x * b.x + a.y * b.y + a.z * b.z + a.w * b.w;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
#if __VERSION__ == 100
|
|
76
|
+
int pyramidVoxel(vec2 pos) {
|
|
77
|
+
return int(unpackRGBToInt(texture2D(tActiveVoxelsPyramid, pos / (vec2(1.0, 0.5) * uSize)).rgb));
|
|
78
|
+
}
|
|
79
|
+
#else
|
|
80
|
+
int pyramidVoxel(vec2 pos) {
|
|
81
|
+
return texture2D(tActiveVoxelsPyramid, pos / (vec2(1.0, 0.5) * uSize)).r;
|
|
82
|
+
}
|
|
83
|
+
#endif
|
|
84
|
+
|
|
85
|
+
vec4 baseVoxel(vec2 pos) {
|
|
86
|
+
return texture2D(tActiveVoxelsBase, pos / uSize);
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
vec4 getGroup(const in vec3 p) {
|
|
90
|
+
vec3 gridDim = uGridDim - vec3(1.0, 1.0, 0.0); // remove xy padding
|
|
91
|
+
// note that we swap x and z because the texture is flipped around y
|
|
92
|
+
#if defined(dAxisOrder_012)
|
|
93
|
+
float group = p.z + p.y * gridDim.z + p.x * gridDim.z * gridDim.y; // 210
|
|
94
|
+
#elif defined(dAxisOrder_021)
|
|
95
|
+
float group = p.y + p.z * gridDim.y + p.x * gridDim.y * gridDim.z; // 120
|
|
96
|
+
#elif defined(dAxisOrder_102)
|
|
97
|
+
float group = p.z + p.x * gridDim.z + p.y * gridDim.z * gridDim.x; // 201
|
|
98
|
+
#elif defined(dAxisOrder_120)
|
|
99
|
+
float group = p.x + p.z * gridDim.x + p.y * gridDim.x * gridDim.z; // 021
|
|
100
|
+
#elif defined(dAxisOrder_201)
|
|
101
|
+
float group = p.y + p.x * gridDim.y + p.z * gridDim.y * gridDim.x; // 102
|
|
102
|
+
#elif defined(dAxisOrder_210)
|
|
103
|
+
float group = p.x + p.y * gridDim.x + p.z * gridDim.x * gridDim.y; // 012
|
|
104
|
+
#endif
|
|
105
|
+
return vec4(group > 16777215.5 ? vec3(1.0) : packIntToRGB(group), 1.0);
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
void main(void) {
|
|
109
|
+
// get 1D index
|
|
110
|
+
int vI = int(gl_FragCoord.x) + int(gl_FragCoord.y) * int(uSize);
|
|
111
|
+
|
|
112
|
+
// ignore 1D indices outside of the grid
|
|
113
|
+
if(vI >= int(uCount)) discard;
|
|
114
|
+
|
|
115
|
+
ivec2 offset = ivec2(int(uSize) - 2, 0);
|
|
116
|
+
|
|
117
|
+
int start = 0;
|
|
118
|
+
ivec4 starts = ivec4(0);
|
|
119
|
+
ivec4 ends = ivec4(0);
|
|
120
|
+
int diff = 2;
|
|
121
|
+
ivec4 m = ivec4(0);
|
|
122
|
+
ivec2 position = ivec2(0);
|
|
123
|
+
ivec4 vI4 = ivec4(vI);
|
|
124
|
+
|
|
125
|
+
ivec2 relativePosition = ivec2(0);
|
|
126
|
+
int end = 0;
|
|
127
|
+
ivec2 pos1 = ivec2(0);
|
|
128
|
+
ivec2 pos2 = ivec2(0);
|
|
129
|
+
ivec2 pos3 = ivec2(0);
|
|
130
|
+
ivec2 pos4 = ivec2(0);
|
|
131
|
+
ivec3 vI3 = ivec3(vI);
|
|
132
|
+
ivec3 mask = ivec3(0);
|
|
133
|
+
|
|
134
|
+
// traverse the different levels of the pyramid
|
|
135
|
+
for(int i = 1; i < 14; i++) {
|
|
136
|
+
if(float(i) >= uLevels) break;
|
|
137
|
+
|
|
138
|
+
offset.x -= diff;
|
|
139
|
+
diff *= 2;
|
|
140
|
+
relativePosition = position + offset;
|
|
141
|
+
|
|
142
|
+
end = start + pyramidVoxel(vec2(relativePosition));
|
|
143
|
+
pos1 = ivec2(relativePosition);
|
|
144
|
+
starts.x = start;
|
|
145
|
+
ends.x = end;
|
|
146
|
+
pos2 = ivec2(relativePosition + ivec2(1, 0));
|
|
147
|
+
starts.y = ends.x;
|
|
148
|
+
ends.y = ends.x + pyramidVoxel(vec2(pos2));
|
|
149
|
+
pos3 = relativePosition + ivec2(0, 1);
|
|
150
|
+
starts.z = ends.y;
|
|
151
|
+
ends.z = ends.y + pyramidVoxel(vec2(pos3));
|
|
152
|
+
pos4 = relativePosition + ivec2(1, 1);
|
|
153
|
+
starts.w = ends.z;
|
|
154
|
+
mask = ivec3(greaterThanEqual(vI3, starts.rgb)) * ivec3(lessThan(vI3, ends.rgb));
|
|
155
|
+
m = ivec4(mask, 1 - int(any(bvec3(mask))));
|
|
156
|
+
|
|
157
|
+
relativePosition = m.x * pos1 + m.y * pos2 + m.z * pos3 + m.w * pos4;
|
|
158
|
+
start = idot4(m, starts);
|
|
159
|
+
position = 2 * (relativePosition - offset);
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
end = start + int(baseVoxel(vec2(position)).r * 255.0);
|
|
163
|
+
pos1 = position;
|
|
164
|
+
starts.x = start;
|
|
165
|
+
ends.x = end;
|
|
166
|
+
pos2 = position + ivec2(1, 0);
|
|
167
|
+
starts.y = ends.x;
|
|
168
|
+
ends.y = ends.x + int(baseVoxel(vec2(pos2)).r * 255.0);
|
|
169
|
+
pos3 = position + ivec2(0, 1);
|
|
170
|
+
starts.z = ends.y;
|
|
171
|
+
ends.z = ends.y + int(baseVoxel(vec2(pos3)).r * 255.0);
|
|
172
|
+
pos4 = position + ivec2(1, 1);
|
|
173
|
+
starts.w = ends.z;
|
|
174
|
+
mask = ivec3(greaterThanEqual(vI3, starts.rgb)) * ivec3(lessThan(vI3, ends.rgb));
|
|
175
|
+
m = ivec4(mask, 1 - int(any(bvec3(mask))));
|
|
176
|
+
position = m.x * pos1 + m.y * pos2 + m.z * pos3 + m.w * pos4;
|
|
177
|
+
|
|
178
|
+
vec2 coord2d = (vec2(position) / uSize) / uScale;
|
|
179
|
+
vec3 coord3d = floor(index3dFrom2d(coord2d) + 0.5);
|
|
180
|
+
|
|
181
|
+
float edgeIndex = floor(baseVoxel(vec2(position)).a * 255.0 + 0.5);
|
|
182
|
+
|
|
183
|
+
// current vertex for the up to 15 MC cases
|
|
184
|
+
int currentVertex = vI - idot4(m, starts);
|
|
185
|
+
|
|
186
|
+
// ensure winding-order is the same for negative and positive iso-levels
|
|
187
|
+
if (uInvert) {
|
|
188
|
+
int v = imod(currentVertex + 1, 3);
|
|
189
|
+
if (v == 1) currentVertex += 2;
|
|
190
|
+
else if (v == 0) currentVertex -= 2;
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
// get index into triIndices table
|
|
194
|
+
int mcIndex = 16 * int(edgeIndex) + currentVertex;
|
|
195
|
+
vec4 mcData = texture2D(tTriIndices, vec2(imod(mcIndex, 64), mcIndex / 64) / 64.);
|
|
196
|
+
|
|
197
|
+
// bit mask to avoid conditionals (see comment below) for getting MC case corner
|
|
198
|
+
vec4 m0 = vec4(floor(mcData.a * 255.0 + 0.5));
|
|
199
|
+
|
|
200
|
+
// get edge value masks
|
|
201
|
+
vec4 m1 = vec4(equal(m0, vec4(0., 1., 2., 3.)));
|
|
202
|
+
vec4 m2 = vec4(equal(m0, vec4(4., 5., 6., 7.)));
|
|
203
|
+
vec4 m3 = vec4(equal(m0, vec4(8., 9., 10., 11.)));
|
|
204
|
+
|
|
205
|
+
// apply bit masks
|
|
206
|
+
vec3 b0 = coord3d +
|
|
207
|
+
m1.y * c1 +
|
|
208
|
+
m1.z * c2 +
|
|
209
|
+
m1.w * c3 +
|
|
210
|
+
m2.x * c4 +
|
|
211
|
+
m2.y * c5 +
|
|
212
|
+
m2.z * c6 +
|
|
213
|
+
m2.w * c7 +
|
|
214
|
+
m3.y * c1 +
|
|
215
|
+
m3.z * c2 +
|
|
216
|
+
m3.w * c3;
|
|
217
|
+
vec3 b1 = coord3d +
|
|
218
|
+
m1.x * c1 +
|
|
219
|
+
m1.y * c2 +
|
|
220
|
+
m1.z * c3 +
|
|
221
|
+
m2.x * c5 +
|
|
222
|
+
m2.y * c6 +
|
|
223
|
+
m2.z * c7 +
|
|
224
|
+
m2.w * c4 +
|
|
225
|
+
m3.x * c4 +
|
|
226
|
+
m3.y * c5 +
|
|
227
|
+
m3.z * c6 +
|
|
228
|
+
m3.w * c7;
|
|
229
|
+
|
|
230
|
+
// the conditionals that are avoided by above bitmasks
|
|
231
|
+
// vec3 b0 = coord3d;
|
|
232
|
+
// vec3 b1 = coord3d;
|
|
233
|
+
// if (mcIndex == 0.0) {
|
|
234
|
+
// b1 += c1;
|
|
235
|
+
// } else if (mcIndex == 1.0) {
|
|
236
|
+
// b0 += c1; b1 += c2;
|
|
237
|
+
// } else if (mcIndex == 2.0) {
|
|
238
|
+
// b0 += c2; b1 += c3;
|
|
239
|
+
// } else if (mcIndex == 3.0) {
|
|
240
|
+
// b0 += c3;
|
|
241
|
+
// } else if (mcIndex == 4.0) {
|
|
242
|
+
// b0 += c4; b1 += c5;
|
|
243
|
+
// } else if (mcIndex == 5.0) {
|
|
244
|
+
// b0 += c5; b1 += c6;
|
|
245
|
+
// } else if (mcIndex == 6.0) {
|
|
246
|
+
// b0 += c6; b1 += c7;
|
|
247
|
+
// } else if (mcIndex == 7.0) {
|
|
248
|
+
// b0 += c7; b1 += c4;
|
|
249
|
+
// } else if (mcIndex == 8.0) {
|
|
250
|
+
// b1 += c4;
|
|
251
|
+
// } else if (mcIndex == 9.0) {
|
|
252
|
+
// b0 += c1; b1 += c5;
|
|
253
|
+
// } else if (mcIndex == 10.0) {
|
|
254
|
+
// b0 += c2; b1 += c6;
|
|
255
|
+
// } else if (mcIndex == 11.0) {
|
|
256
|
+
// b0 += c3; b1 += c7;
|
|
257
|
+
// }
|
|
258
|
+
// b0 = floor(b0 + 0.5);
|
|
259
|
+
// b1 = floor(b1 + 0.5);
|
|
260
|
+
|
|
261
|
+
vec4 d0 = voxel(b0);
|
|
262
|
+
vec4 d1 = voxel(b1);
|
|
263
|
+
|
|
264
|
+
float v0 = d0.a;
|
|
265
|
+
float v1 = d1.a;
|
|
266
|
+
|
|
267
|
+
float t = (uIsoValue - v0) / (v0 - v1);
|
|
268
|
+
gl_FragData[0].xyz = (uGridTransform * vec4(b0 + t * (b0 - b1), 1.0)).xyz;
|
|
269
|
+
|
|
270
|
+
// group id
|
|
271
|
+
#if __VERSION__ == 100 || defined(dConstantGroup)
|
|
272
|
+
// webgl1 does not support 'flat' interpolation (i.e. no interpolation)
|
|
273
|
+
// ensure a constant group id per triangle as needed
|
|
274
|
+
#ifdef dPackedGroup
|
|
275
|
+
gl_FragData[1] = vec4(voxel(coord3d).rgb, 1.0);
|
|
276
|
+
#else
|
|
277
|
+
gl_FragData[1] = getGroup(coord3d);
|
|
278
|
+
#endif
|
|
279
|
+
#else
|
|
280
|
+
#ifdef dPackedGroup
|
|
281
|
+
gl_FragData[1] = vec4(t < 0.5 ? d0.rgb : d1.rgb, 1.0);
|
|
282
|
+
#else
|
|
283
|
+
gl_FragData[1] = getGroup(t < 0.5 ? b0 : b1);
|
|
284
|
+
#endif
|
|
285
|
+
#endif
|
|
286
|
+
|
|
287
|
+
// normals from gradients
|
|
288
|
+
vec3 n0 = -normalize(vec3(
|
|
289
|
+
voxelPadded(b0 - c1).a - voxelPadded(b0 + c1).a,
|
|
290
|
+
voxelPadded(b0 - c3).a - voxelPadded(b0 + c3).a,
|
|
291
|
+
voxelPadded(b0 - c4).a - voxelPadded(b0 + c4).a
|
|
292
|
+
));
|
|
293
|
+
vec3 n1 = -normalize(vec3(
|
|
294
|
+
voxelPadded(b1 - c1).a - voxelPadded(b1 + c1).a,
|
|
295
|
+
voxelPadded(b1 - c3).a - voxelPadded(b1 + c3).a,
|
|
296
|
+
voxelPadded(b1 - c4).a - voxelPadded(b1 + c4).a
|
|
297
|
+
));
|
|
298
|
+
gl_FragData[2].xyz = -vec3(
|
|
299
|
+
n0.x + t * (n0.x - n1.x),
|
|
300
|
+
n0.y + t * (n0.y - n1.y),
|
|
301
|
+
n0.z + t * (n0.z - n1.z)
|
|
302
|
+
);
|
|
303
|
+
|
|
304
|
+
// ensure normal-direction is the same for negative and positive iso-levels
|
|
305
|
+
if (uInvert) {
|
|
306
|
+
gl_FragData[2].xyz *= -1.0;
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
// apply normal matrix
|
|
310
|
+
gl_FragData[2].xyz *= transpose3(inverse3(mat3(uGridTransform)));
|
|
311
|
+
}
|
|
312
312
|
`;
|