molstar 3.0.0-dev.5 → 3.0.0-dev.9
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 +187 -187
- package/build/viewer/embedded.html +43 -43
- package/build/viewer/index.html +106 -95
- package/build/viewer/molstar.js +1 -1
- package/lib/apps/docking-viewer/index.d.ts +2 -1
- package/lib/apps/docking-viewer/index.html +36 -36
- package/lib/apps/docking-viewer/index.js +87 -74
- package/lib/apps/viewer/app.d.ts +230 -0
- package/lib/apps/viewer/app.js +515 -0
- package/lib/apps/viewer/embedded.html +43 -43
- package/lib/apps/viewer/index.d.ts +2 -403
- package/lib/apps/viewer/index.html +106 -95
- package/lib/apps/viewer/index.js +2 -420
- package/lib/cli/cifschema/index.d.ts +1 -1
- package/lib/cli/cifschema/index.js +15 -35
- package/lib/commonjs/apps/docking-viewer/index.d.ts +2 -1
- package/lib/commonjs/apps/docking-viewer/index.js +86 -73
- package/lib/commonjs/apps/viewer/app.d.ts +230 -0
- package/lib/commonjs/apps/viewer/app.js +521 -0
- package/lib/commonjs/apps/viewer/index.d.ts +2 -403
- package/lib/commonjs/apps/viewer/index.js +2 -423
- package/lib/commonjs/cli/cifschema/index.d.ts +1 -1
- package/lib/commonjs/cli/cifschema/index.js +15 -35
- package/lib/commonjs/examples/alpha-orbitals/index.js +3 -4
- package/lib/commonjs/examples/basic-wrapper/index.js +23 -11
- package/lib/commonjs/examples/lighting/index.d.ts +1 -1
- package/lib/commonjs/examples/lighting/index.js +57 -41
- package/lib/commonjs/examples/proteopedia-wrapper/index.js +26 -14
- package/lib/commonjs/extensions/alpha-orbitals/transforms.d.ts +0 -1
- package/lib/commonjs/extensions/alpha-orbitals/transforms.js +1 -14
- package/lib/commonjs/extensions/anvil/behavior.d.ts +4 -0
- package/lib/commonjs/extensions/anvil/representation.d.ts +50 -0
- package/lib/commonjs/extensions/cellpack/representation.d.ts +10 -0
- package/lib/commonjs/extensions/dnatco/confal-pyramids/representation.d.ts +30 -0
- package/lib/commonjs/extensions/geo-export/mesh-exporter.js +4 -4
- package/lib/commonjs/extensions/model-archive/quality-assessment/behavior.d.ts +68 -0
- package/lib/commonjs/extensions/model-archive/quality-assessment/behavior.js +236 -0
- package/lib/commonjs/extensions/model-archive/quality-assessment/color/plddt.d.ts +14 -0
- package/lib/commonjs/extensions/model-archive/quality-assessment/color/plddt.js +125 -0
- package/lib/commonjs/extensions/model-archive/quality-assessment/color/qmean.d.ts +12 -0
- package/lib/commonjs/extensions/model-archive/quality-assessment/color/qmean.js +111 -0
- package/lib/commonjs/extensions/model-archive/quality-assessment/prop.d.ts +28 -0
- package/lib/commonjs/extensions/model-archive/quality-assessment/prop.js +130 -0
- package/lib/commonjs/extensions/pdbe/structure-quality-report/prop.js +1 -1
- package/lib/commonjs/extensions/rcsb/assembly-symmetry/behavior.d.ts +6 -2
- package/lib/commonjs/extensions/rcsb/assembly-symmetry/prop.js +1 -1
- package/lib/commonjs/extensions/rcsb/assembly-symmetry/representation.d.ts +10 -0
- package/lib/commonjs/extensions/rcsb/validation-report/prop.js +1 -1
- package/lib/commonjs/extensions/rcsb/validation-report/representation.d.ts +50 -0
- package/lib/commonjs/mol-canvas3d/canvas3d.d.ts +3 -9
- package/lib/commonjs/mol-canvas3d/canvas3d.js +34 -23
- package/lib/commonjs/mol-canvas3d/helper/bounding-sphere-helper.js +3 -2
- package/lib/commonjs/mol-canvas3d/helper/camera-helper.d.ts +4 -0
- package/lib/commonjs/mol-canvas3d/helper/camera-helper.js +2 -2
- package/lib/commonjs/mol-canvas3d/helper/handle-helper.d.ts +4 -0
- package/lib/commonjs/mol-canvas3d/helper/handle-helper.js +2 -2
- package/lib/commonjs/mol-canvas3d/helper/helper.d.ts +2 -0
- package/lib/commonjs/mol-canvas3d/passes/draw.d.ts +13 -1
- package/lib/commonjs/mol-canvas3d/passes/draw.js +16 -15
- package/lib/commonjs/mol-canvas3d/passes/image.d.ts +1 -0
- package/lib/commonjs/mol-canvas3d/passes/image.js +3 -2
- package/lib/commonjs/mol-canvas3d/passes/marking.js +1 -1
- package/lib/commonjs/mol-canvas3d/passes/multi-sample.d.ts +10 -2
- package/lib/commonjs/mol-canvas3d/passes/multi-sample.js +18 -14
- package/lib/commonjs/mol-canvas3d/passes/pick.js +12 -12
- package/lib/commonjs/mol-canvas3d/passes/postprocessing.js +3 -3
- package/lib/commonjs/mol-canvas3d/passes/smaa.js +1 -1
- package/lib/commonjs/mol-geo/geometry/base.d.ts +18 -0
- package/lib/commonjs/mol-geo/geometry/base.js +18 -1
- package/lib/commonjs/mol-geo/geometry/clipping-data.d.ts +1 -3
- package/lib/commonjs/mol-geo/geometry/clipping-data.js +3 -8
- package/lib/commonjs/mol-geo/geometry/color-data.d.ts +1 -1
- package/lib/commonjs/mol-geo/geometry/color-data.js +22 -0
- package/lib/commonjs/mol-geo/geometry/cylinders/cylinders.d.ts +12 -2
- package/lib/commonjs/mol-geo/geometry/cylinders/cylinders.js +2 -2
- package/lib/commonjs/mol-geo/geometry/direct-volume/direct-volume.d.ts +15 -38
- package/lib/commonjs/mol-geo/geometry/direct-volume/direct-volume.js +21 -66
- package/lib/commonjs/mol-geo/geometry/direct-volume/transfer-function.d.ts +2 -4
- package/lib/commonjs/mol-geo/geometry/direct-volume/transfer-function.js +4 -7
- package/lib/commonjs/mol-geo/geometry/image/image.d.ts +10 -0
- package/lib/commonjs/mol-geo/geometry/image/image.js +1 -1
- package/lib/commonjs/mol-geo/geometry/lines/lines.d.ts +11 -0
- package/lib/commonjs/mol-geo/geometry/lines/lines.js +1 -1
- package/lib/commonjs/mol-geo/geometry/marker-data.d.ts +0 -1
- package/lib/commonjs/mol-geo/geometry/marker-data.js +13 -9
- package/lib/commonjs/mol-geo/geometry/mesh/mesh.d.ts +10 -0
- package/lib/commonjs/mol-geo/geometry/mesh/mesh.js +2 -2
- package/lib/commonjs/mol-geo/geometry/points/points.d.ts +11 -1
- package/lib/commonjs/mol-geo/geometry/points/points.js +1 -1
- package/lib/commonjs/mol-geo/geometry/size-data.js +5 -5
- package/lib/commonjs/mol-geo/geometry/spheres/spheres.d.ts +10 -0
- package/lib/commonjs/mol-geo/geometry/spheres/spheres.js +2 -2
- package/lib/commonjs/mol-geo/geometry/text/text.d.ts +10 -0
- package/lib/commonjs/mol-geo/geometry/text/text.js +1 -1
- package/lib/commonjs/mol-geo/geometry/texture-mesh/texture-mesh.d.ts +10 -0
- package/lib/commonjs/mol-geo/geometry/texture-mesh/texture-mesh.js +2 -2
- package/lib/commonjs/mol-gl/compute/histogram-pyramid/sum.js +2 -2
- package/lib/commonjs/mol-gl/compute/marching-cubes/isosurface.d.ts +2 -2
- package/lib/commonjs/mol-gl/compute/marching-cubes/isosurface.js +10 -9
- package/lib/commonjs/mol-gl/render-object.d.ts +2 -1
- package/lib/commonjs/mol-gl/render-object.js +10 -10
- package/lib/commonjs/mol-gl/renderable/cylinders.d.ts +11 -5
- package/lib/commonjs/mol-gl/renderable/cylinders.js +3 -3
- package/lib/commonjs/mol-gl/renderable/direct-volume.d.ts +15 -14
- package/lib/commonjs/mol-gl/renderable/direct-volume.js +3 -3
- package/lib/commonjs/mol-gl/renderable/image.d.ts +10 -4
- package/lib/commonjs/mol-gl/renderable/image.js +2 -2
- package/lib/commonjs/mol-gl/renderable/lines.d.ts +39 -33
- package/lib/commonjs/mol-gl/renderable/lines.js +3 -3
- package/lib/commonjs/mol-gl/renderable/mesh.d.ts +11 -5
- package/lib/commonjs/mol-gl/renderable/mesh.js +3 -3
- package/lib/commonjs/mol-gl/renderable/points.d.ts +10 -4
- package/lib/commonjs/mol-gl/renderable/points.js +2 -2
- package/lib/commonjs/mol-gl/renderable/schema.d.ts +10 -11
- package/lib/commonjs/mol-gl/renderable/schema.js +4 -10
- package/lib/commonjs/mol-gl/renderable/spheres.d.ts +11 -5
- package/lib/commonjs/mol-gl/renderable/spheres.js +3 -3
- package/lib/commonjs/mol-gl/renderable/text.d.ts +10 -4
- package/lib/commonjs/mol-gl/renderable/text.js +2 -2
- package/lib/commonjs/mol-gl/renderable/texture-mesh.d.ts +11 -6
- package/lib/commonjs/mol-gl/renderable/texture-mesh.js +3 -3
- package/lib/commonjs/mol-gl/renderable.d.ts +0 -1
- package/lib/commonjs/mol-gl/renderer.d.ts +12 -12
- package/lib/commonjs/mol-gl/renderer.js +23 -92
- package/lib/commonjs/mol-gl/scene.d.ts +2 -2
- package/lib/commonjs/mol-gl/scene.js +7 -5
- package/lib/commonjs/mol-gl/shader/chunks/apply-light-color.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/apply-light-color.glsl.js +1 -1
- 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 +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/assign-group.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/assign-group.glsl.js +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/assign-marker-varying.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/assign-marker-varying.glsl.js +1 -1
- 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 +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/assign-position.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/assign-position.glsl.js +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/assign-size.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/assign-size.glsl.js +1 -1
- 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 +1 -1
- 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 +1 -1
- 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 +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/common-vert-params.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/common-vert-params.glsl.js +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/common.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/common.glsl.js +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/wboit-write.glsl.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/chunks/wboit-write.glsl.js +1 -1
- package/lib/commonjs/mol-gl/shader/compute/color-smoothing/accumulate.vert.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/compute/color-smoothing/accumulate.vert.js +1 -1
- package/lib/commonjs/mol-gl/shader/cylinders.frag.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/cylinders.frag.js +1 -1
- package/lib/commonjs/mol-gl/shader/direct-volume.frag.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/direct-volume.frag.js +1 -1
- package/lib/commonjs/mol-gl/shader/gaussian-density.frag.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/gaussian-density.frag.js +1 -1
- package/lib/commonjs/mol-gl/shader/histogram-pyramid/reduction.frag.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/histogram-pyramid/reduction.frag.js +1 -1
- package/lib/commonjs/mol-gl/shader/image.frag.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/image.frag.js +1 -1
- package/lib/commonjs/mol-gl/shader/marching-cubes/isosurface.frag.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/marching-cubes/isosurface.frag.js +1 -1
- package/lib/commonjs/mol-gl/shader/mesh.frag.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/mesh.frag.js +1 -1
- package/lib/commonjs/mol-gl/shader/mesh.vert.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/mesh.vert.js +1 -1
- package/lib/commonjs/mol-gl/shader/spheres.frag.d.ts +1 -1
- package/lib/commonjs/mol-gl/shader/spheres.frag.js +1 -1
- package/lib/commonjs/mol-gl/shader-code.d.ts +3 -1
- package/lib/commonjs/mol-gl/shader-code.js +43 -14
- package/lib/commonjs/mol-gl/webgl/render-item.d.ts +7 -6
- package/lib/commonjs/mol-gl/webgl/render-item.js +10 -8
- package/lib/commonjs/mol-gl/webgl/resources.js +8 -1
- package/lib/commonjs/mol-io/reader/cif/schema/mmcif.d.ts +326 -1
- package/lib/commonjs/mol-io/reader/cif/schema/mmcif.js +326 -1
- package/lib/commonjs/mol-io/reader/mol2/parser.d.ts +1 -1
- package/lib/commonjs/mol-io/reader/mol2/parser.js +33 -3
- package/lib/commonjs/mol-io/reader/mol2/schema.d.ts +12 -1
- package/lib/commonjs/mol-io/reader/mol2/schema.js +1 -1
- package/lib/commonjs/mol-math/geometry/gaussian-density/gpu.js +2 -2
- package/lib/commonjs/mol-math/geometry/symmetry-operator.js +3 -2
- package/lib/commonjs/mol-math/linear-algebra/3d/quat.d.ts +9 -1
- package/lib/commonjs/mol-math/linear-algebra/3d/quat.js +20 -1
- package/lib/commonjs/mol-model/structure/model/model.d.ts +1 -0
- package/lib/commonjs/mol-model/structure/model/model.js +8 -2
- package/lib/commonjs/mol-model/structure/model/properties/atomic/hierarchy.d.ts +6 -1
- package/lib/commonjs/mol-model/structure/model/properties/atomic/hierarchy.js +1 -1
- package/lib/commonjs/mol-model/structure/model/properties/utils/atomic-derived.d.ts +1 -1
- package/lib/commonjs/mol-model/structure/model/properties/utils/atomic-derived.js +4 -1
- package/lib/commonjs/mol-model/structure/model/properties/utils/atomic-index.d.ts +1 -1
- package/lib/commonjs/mol-model/structure/model/properties/utils/atomic-index.js +12 -1
- package/lib/commonjs/mol-model/structure/model/types.js +9 -0
- package/lib/commonjs/mol-model/structure/structure/element/stats.js +8 -0
- package/lib/commonjs/mol-model/structure/structure/unit/bonds/common.d.ts +2 -1
- package/lib/commonjs/mol-model/structure/structure/unit/bonds/common.js +11 -2
- 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 +20 -10
- 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 +21 -11
- package/lib/commonjs/mol-model/structure/structure/unit/rings.js +2 -0
- package/lib/commonjs/mol-model-formats/shape/ply.d.ts +20 -0
- package/lib/commonjs/mol-model-formats/structure/mol2.d.ts +1 -1
- package/lib/commonjs/mol-model-formats/structure/mol2.js +37 -7
- package/lib/commonjs/mol-model-formats/structure/property/bonds/index-pair.d.ts +18 -1
- package/lib/commonjs/mol-model-formats/structure/property/bonds/index-pair.js +18 -5
- package/lib/commonjs/mol-model-props/computed/representations/interactions-inter-unit-cylinder.d.ts +10 -0
- package/lib/commonjs/mol-model-props/computed/representations/interactions-intra-unit-cylinder.d.ts +10 -0
- package/lib/commonjs/mol-model-props/computed/representations/interactions.d.ts +30 -0
- package/lib/commonjs/mol-model-props/integrative/cross-link-restraint/representation.d.ts +40 -0
- package/lib/commonjs/mol-plugin/behavior/dynamic/representation.js +4 -6
- package/lib/commonjs/mol-plugin/behavior/dynamic/selection/structure-focus-representation.d.ts +11 -0
- package/lib/commonjs/mol-plugin/behavior/dynamic/selection/structure-focus-representation.js +3 -1
- package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/model.d.ts +3 -2
- package/lib/commonjs/mol-plugin/commands.d.ts +1 -4
- package/lib/commonjs/mol-plugin/config.d.ts +2 -2
- package/lib/commonjs/mol-plugin/config.js +5 -25
- package/lib/commonjs/mol-plugin/features.d.ts +9 -0
- package/lib/commonjs/mol-plugin/features.js +38 -0
- package/lib/commonjs/mol-plugin/spec.js +1 -0
- package/lib/commonjs/mol-plugin/util/viewport-screenshot.d.ts +12 -0
- package/lib/commonjs/mol-plugin-state/actions/structure.d.ts +8 -1
- package/lib/commonjs/mol-plugin-state/actions/structure.js +183 -72
- package/lib/commonjs/mol-plugin-state/builder/structure/hierarchy-preset.d.ts +5 -355
- package/lib/commonjs/mol-plugin-state/builder/structure/hierarchy-preset.js +13 -8
- package/lib/commonjs/mol-plugin-state/builder/structure/hierarchy.d.ts +1 -71
- package/lib/commonjs/mol-plugin-state/builder/structure/representation-preset.d.ts +4 -4
- package/lib/commonjs/mol-plugin-state/helpers/structure-clipping.d.ts +1 -1
- package/lib/commonjs/mol-plugin-state/helpers/structure-clipping.js +1 -1
- package/lib/commonjs/mol-plugin-state/helpers/structure-selection-query.js +33 -19
- package/lib/commonjs/mol-plugin-state/manager/structure/component.d.ts +13 -1
- package/lib/commonjs/mol-plugin-state/manager/structure/component.js +13 -8
- package/lib/commonjs/mol-plugin-state/manager/structure/selection.js +3 -1
- package/lib/commonjs/mol-plugin-state/transforms/representation.d.ts +32 -0
- package/lib/commonjs/mol-plugin-state/transforms/representation.js +2 -2
- package/lib/commonjs/mol-plugin-ui/index.d.ts +4 -4
- package/lib/commonjs/mol-plugin-ui/index.js +13 -16
- package/lib/commonjs/mol-plugin-ui/plugin.js +1 -1
- package/lib/commonjs/mol-plugin-ui/viewport/simple-settings.js +2 -6
- package/lib/commonjs/mol-repr/shape/loci/angle.d.ts +10 -0
- package/lib/commonjs/mol-repr/shape/loci/common.d.ts +10 -0
- package/lib/commonjs/mol-repr/shape/loci/dihedral.d.ts +10 -0
- package/lib/commonjs/mol-repr/shape/loci/distance.d.ts +10 -0
- package/lib/commonjs/mol-repr/shape/loci/label.d.ts +10 -0
- package/lib/commonjs/mol-repr/shape/loci/orientation.d.ts +10 -0
- package/lib/commonjs/mol-repr/shape/loci/plane.d.ts +10 -0
- package/lib/commonjs/mol-repr/shape/model/unitcell.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/complex-representation.js +1 -1
- package/lib/commonjs/mol-repr/structure/complex-visual.d.ts +61 -19
- package/lib/commonjs/mol-repr/structure/params.d.ts +81 -19
- package/lib/commonjs/mol-repr/structure/registry.d.ts +141 -19
- package/lib/commonjs/mol-repr/structure/representation/backbone.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/ball-and-stick.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/carbohydrate.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/cartoon.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/ellipsoid.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/gaussian-surface.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/gaussian-surface.js +1 -1
- package/lib/commonjs/mol-repr/structure/representation/gaussian-volume.d.ts +34 -58
- package/lib/commonjs/mol-repr/structure/representation/gaussian-volume.js +2 -7
- package/lib/commonjs/mol-repr/structure/representation/label.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/label.js +1 -1
- package/lib/commonjs/mol-repr/structure/representation/line.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/molecular-surface.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/molecular-surface.js +1 -1
- package/lib/commonjs/mol-repr/structure/representation/orientation.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/point.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/putty.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/representation/spacefill.d.ts +30 -0
- package/lib/commonjs/mol-repr/structure/units-representation.js +1 -1
- package/lib/commonjs/mol-repr/structure/units-visual.d.ts +81 -19
- package/lib/commonjs/mol-repr/structure/visual/bond-inter-unit-cylinder.d.ts +20 -0
- package/lib/commonjs/mol-repr/structure/visual/bond-inter-unit-line.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/bond-intra-unit-cylinder.d.ts +20 -0
- package/lib/commonjs/mol-repr/structure/visual/bond-intra-unit-cylinder.js +2 -2
- package/lib/commonjs/mol-repr/structure/visual/bond-intra-unit-line.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/bond-intra-unit-line.js +2 -2
- package/lib/commonjs/mol-repr/structure/visual/carbohydrate-link-cylinder.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/carbohydrate-symbol-mesh.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/carbohydrate-terminal-link-cylinder.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/element-cross.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/element-point.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/element-sphere.d.ts +20 -0
- package/lib/commonjs/mol-repr/structure/visual/ellipsoid-mesh.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/gaussian-density-volume.d.ts +22 -38
- package/lib/commonjs/mol-repr/structure/visual/gaussian-density-volume.js +8 -6
- package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-mesh.d.ts +40 -0
- package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-mesh.js +11 -8
- package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-wireframe.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-wireframe.js +1 -1
- package/lib/commonjs/mol-repr/structure/visual/label-text.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/label-text.js +1 -2
- package/lib/commonjs/mol-repr/structure/visual/molecular-surface-mesh.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/molecular-surface-mesh.js +1 -1
- package/lib/commonjs/mol-repr/structure/visual/molecular-surface-wireframe.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/molecular-surface-wireframe.js +1 -1
- package/lib/commonjs/mol-repr/structure/visual/nucleotide-block-mesh.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/nucleotide-ring-mesh.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/orientation-ellipsoid-mesh.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-backbone-cylinder.d.ts +20 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-backbone-sphere.d.ts +20 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-direction-wedge.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-gap-cylinder.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-trace-mesh.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/polymer-trace-mesh.js +1 -1
- package/lib/commonjs/mol-repr/structure/visual/polymer-tube-mesh.d.ts +10 -0
- package/lib/commonjs/mol-repr/structure/visual/util/bond.js +1 -1
- package/lib/commonjs/mol-repr/structure/visual/util/common.d.ts +3 -2
- package/lib/commonjs/mol-repr/structure/visual/util/common.js +2 -5
- package/lib/commonjs/mol-repr/structure/visual/util/gaussian.d.ts +7 -6
- package/lib/commonjs/mol-repr/structure/visual/util/gaussian.js +12 -12
- package/lib/commonjs/mol-repr/structure/visual/util/molecular-surface.d.ts +2 -1
- package/lib/commonjs/mol-repr/structure/visual/util/molecular-surface.js +4 -4
- package/lib/commonjs/mol-repr/visual.js +11 -7
- package/lib/commonjs/mol-repr/volume/direct-volume.d.ts +33 -57
- package/lib/commonjs/mol-repr/volume/direct-volume.js +8 -12
- package/lib/commonjs/mol-repr/volume/isosurface.d.ts +60 -0
- package/lib/commonjs/mol-repr/volume/isosurface.js +11 -2
- package/lib/commonjs/mol-repr/volume/registry.d.ts +31 -19
- package/lib/commonjs/mol-repr/volume/representation.d.ts +10 -0
- package/lib/commonjs/mol-repr/volume/slice.d.ts +30 -0
- package/lib/commonjs/mol-repr/volume/slice.js +2 -2
- package/lib/commonjs/mol-repr/volume/util.js +2 -2
- package/lib/commonjs/mol-script/language/builder.d.ts +0 -1
- package/lib/commonjs/mol-theme/clipping.d.ts +7 -15
- package/lib/commonjs/mol-theme/clipping.js +5 -12
- package/lib/commonjs/mol-theme/color/volume-value.d.ts +17 -0
- package/lib/commonjs/mol-theme/color/volume-value.js +57 -0
- package/lib/commonjs/mol-theme/color.d.ts +3 -0
- package/lib/commonjs/mol-theme/color.js +2 -0
- package/lib/commonjs/mol-util/clip.d.ts +49 -0
- package/lib/commonjs/mol-util/clip.js +97 -0
- package/lib/commonjs/mol-util/number-packing.d.ts +11 -0
- package/lib/commonjs/mol-util/{float-packing.js → number-packing.js} +10 -19
- package/lib/examples/alpha-orbitals/index.html +61 -60
- package/lib/examples/alpha-orbitals/index.js +4 -5
- package/lib/examples/basic-wrapper/index.html +137 -136
- package/lib/examples/basic-wrapper/index.js +24 -12
- package/lib/examples/lighting/index.d.ts +1 -1
- package/lib/examples/lighting/index.html +88 -86
- package/lib/examples/lighting/index.js +58 -42
- package/lib/examples/proteopedia-wrapper/index.html +236 -235
- package/lib/examples/proteopedia-wrapper/index.js +27 -15
- package/lib/extensions/alpha-orbitals/transforms.d.ts +0 -1
- package/lib/extensions/alpha-orbitals/transforms.js +1 -14
- package/lib/extensions/anvil/behavior.d.ts +4 -0
- package/lib/extensions/anvil/representation.d.ts +50 -0
- package/lib/extensions/cellpack/representation.d.ts +10 -0
- package/lib/extensions/dnatco/confal-pyramids/representation.d.ts +30 -0
- package/lib/extensions/geo-export/mesh-exporter.js +4 -4
- package/lib/extensions/model-archive/quality-assessment/behavior.d.ts +68 -0
- package/lib/extensions/model-archive/quality-assessment/behavior.js +233 -0
- package/lib/extensions/model-archive/quality-assessment/color/plddt.d.ts +14 -0
- package/lib/extensions/model-archive/quality-assessment/color/plddt.js +120 -0
- package/lib/extensions/model-archive/quality-assessment/color/qmean.d.ts +12 -0
- package/lib/extensions/model-archive/quality-assessment/color/qmean.js +106 -0
- package/lib/extensions/model-archive/quality-assessment/prop.d.ts +28 -0
- package/lib/extensions/model-archive/quality-assessment/prop.js +127 -0
- package/lib/extensions/pdbe/structure-quality-report/prop.js +1 -1
- package/lib/extensions/rcsb/assembly-symmetry/behavior.d.ts +6 -2
- package/lib/extensions/rcsb/assembly-symmetry/prop.js +1 -1
- package/lib/extensions/rcsb/assembly-symmetry/representation.d.ts +10 -0
- package/lib/extensions/rcsb/validation-report/prop.js +1 -1
- package/lib/extensions/rcsb/validation-report/representation.d.ts +50 -0
- package/lib/mol-canvas3d/canvas3d.d.ts +3 -9
- package/lib/mol-canvas3d/canvas3d.js +34 -23
- package/lib/mol-canvas3d/helper/bounding-sphere-helper.js +3 -2
- package/lib/mol-canvas3d/helper/camera-helper.d.ts +4 -0
- package/lib/mol-canvas3d/helper/camera-helper.js +2 -2
- package/lib/mol-canvas3d/helper/handle-helper.d.ts +4 -0
- package/lib/mol-canvas3d/helper/handle-helper.js +2 -2
- package/lib/mol-canvas3d/helper/helper.d.ts +2 -0
- package/lib/mol-canvas3d/passes/draw.d.ts +13 -1
- package/lib/mol-canvas3d/passes/draw.js +16 -15
- package/lib/mol-canvas3d/passes/image.d.ts +1 -0
- package/lib/mol-canvas3d/passes/image.js +3 -2
- package/lib/mol-canvas3d/passes/marking.js +1 -1
- package/lib/mol-canvas3d/passes/multi-sample.d.ts +10 -2
- package/lib/mol-canvas3d/passes/multi-sample.js +18 -14
- package/lib/mol-canvas3d/passes/pick.js +11 -11
- package/lib/mol-canvas3d/passes/postprocessing.js +3 -3
- package/lib/mol-canvas3d/passes/smaa.js +1 -1
- package/lib/mol-geo/geometry/base.d.ts +18 -0
- package/lib/mol-geo/geometry/base.js +18 -1
- package/lib/mol-geo/geometry/clipping-data.d.ts +1 -3
- package/lib/mol-geo/geometry/clipping-data.js +3 -8
- package/lib/mol-geo/geometry/color-data.d.ts +1 -1
- package/lib/mol-geo/geometry/color-data.js +22 -0
- package/lib/mol-geo/geometry/cylinders/cylinders.d.ts +12 -2
- package/lib/mol-geo/geometry/cylinders/cylinders.js +2 -2
- package/lib/mol-geo/geometry/direct-volume/direct-volume.d.ts +15 -38
- package/lib/mol-geo/geometry/direct-volume/direct-volume.js +22 -67
- package/lib/mol-geo/geometry/direct-volume/transfer-function.d.ts +2 -4
- package/lib/mol-geo/geometry/direct-volume/transfer-function.js +4 -7
- package/lib/mol-geo/geometry/image/image.d.ts +10 -0
- package/lib/mol-geo/geometry/image/image.js +1 -1
- package/lib/mol-geo/geometry/lines/lines.d.ts +11 -0
- package/lib/mol-geo/geometry/lines/lines.js +1 -1
- package/lib/mol-geo/geometry/marker-data.d.ts +0 -1
- package/lib/mol-geo/geometry/marker-data.js +13 -9
- package/lib/mol-geo/geometry/mesh/mesh.d.ts +10 -0
- package/lib/mol-geo/geometry/mesh/mesh.js +2 -2
- package/lib/mol-geo/geometry/points/points.d.ts +11 -1
- package/lib/mol-geo/geometry/points/points.js +1 -1
- package/lib/mol-geo/geometry/size-data.js +5 -5
- package/lib/mol-geo/geometry/spheres/spheres.d.ts +10 -0
- package/lib/mol-geo/geometry/spheres/spheres.js +2 -2
- package/lib/mol-geo/geometry/text/text.d.ts +10 -0
- package/lib/mol-geo/geometry/text/text.js +1 -1
- package/lib/mol-geo/geometry/texture-mesh/texture-mesh.d.ts +10 -0
- package/lib/mol-geo/geometry/texture-mesh/texture-mesh.js +2 -2
- package/lib/mol-gl/compute/histogram-pyramid/sum.js +2 -2
- package/lib/mol-gl/compute/marching-cubes/isosurface.d.ts +2 -2
- package/lib/mol-gl/compute/marching-cubes/isosurface.js +10 -9
- package/lib/mol-gl/render-object.d.ts +2 -1
- package/lib/mol-gl/render-object.js +10 -10
- package/lib/mol-gl/renderable/cylinders.d.ts +11 -5
- package/lib/mol-gl/renderable/cylinders.js +3 -3
- package/lib/mol-gl/renderable/direct-volume.d.ts +15 -14
- package/lib/mol-gl/renderable/direct-volume.js +3 -3
- package/lib/mol-gl/renderable/image.d.ts +10 -4
- package/lib/mol-gl/renderable/image.js +2 -2
- package/lib/mol-gl/renderable/lines.d.ts +39 -33
- package/lib/mol-gl/renderable/lines.js +4 -4
- package/lib/mol-gl/renderable/mesh.d.ts +11 -5
- package/lib/mol-gl/renderable/mesh.js +3 -3
- package/lib/mol-gl/renderable/points.d.ts +10 -4
- package/lib/mol-gl/renderable/points.js +2 -2
- package/lib/mol-gl/renderable/schema.d.ts +10 -11
- package/lib/mol-gl/renderable/schema.js +4 -10
- package/lib/mol-gl/renderable/spheres.d.ts +11 -5
- package/lib/mol-gl/renderable/spheres.js +3 -3
- package/lib/mol-gl/renderable/text.d.ts +10 -4
- package/lib/mol-gl/renderable/text.js +2 -2
- package/lib/mol-gl/renderable/texture-mesh.d.ts +11 -6
- package/lib/mol-gl/renderable/texture-mesh.js +3 -3
- package/lib/mol-gl/renderable.d.ts +0 -1
- package/lib/mol-gl/renderer.d.ts +12 -12
- package/lib/mol-gl/renderer.js +24 -93
- package/lib/mol-gl/scene.d.ts +2 -2
- package/lib/mol-gl/scene.js +7 -5
- package/lib/mol-gl/shader/chunks/apply-light-color.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/apply-light-color.glsl.js +1 -1
- 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 +1 -1
- package/lib/mol-gl/shader/chunks/assign-group.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/assign-group.glsl.js +1 -1
- package/lib/mol-gl/shader/chunks/assign-marker-varying.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/assign-marker-varying.glsl.js +1 -1
- 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 +1 -1
- package/lib/mol-gl/shader/chunks/assign-position.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/assign-position.glsl.js +1 -1
- package/lib/mol-gl/shader/chunks/assign-size.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/assign-size.glsl.js +1 -1
- 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 +1 -1
- 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 +1 -1
- 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 +1 -1
- package/lib/mol-gl/shader/chunks/common-vert-params.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/common-vert-params.glsl.js +1 -1
- package/lib/mol-gl/shader/chunks/common.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/common.glsl.js +1 -1
- package/lib/mol-gl/shader/chunks/wboit-write.glsl.d.ts +1 -1
- package/lib/mol-gl/shader/chunks/wboit-write.glsl.js +1 -1
- package/lib/mol-gl/shader/compute/color-smoothing/accumulate.vert.d.ts +1 -1
- package/lib/mol-gl/shader/compute/color-smoothing/accumulate.vert.js +1 -1
- package/lib/mol-gl/shader/cylinders.frag.d.ts +1 -1
- package/lib/mol-gl/shader/cylinders.frag.js +1 -1
- package/lib/mol-gl/shader/direct-volume.frag.d.ts +1 -1
- package/lib/mol-gl/shader/direct-volume.frag.js +1 -1
- package/lib/mol-gl/shader/gaussian-density.frag.d.ts +1 -1
- package/lib/mol-gl/shader/gaussian-density.frag.js +1 -1
- package/lib/mol-gl/shader/histogram-pyramid/reduction.frag.d.ts +1 -1
- package/lib/mol-gl/shader/histogram-pyramid/reduction.frag.js +1 -1
- package/lib/mol-gl/shader/image.frag.d.ts +1 -1
- package/lib/mol-gl/shader/image.frag.js +1 -1
- package/lib/mol-gl/shader/marching-cubes/isosurface.frag.d.ts +1 -1
- package/lib/mol-gl/shader/marching-cubes/isosurface.frag.js +1 -1
- package/lib/mol-gl/shader/mesh.frag.d.ts +1 -1
- package/lib/mol-gl/shader/mesh.frag.js +1 -1
- package/lib/mol-gl/shader/mesh.vert.d.ts +1 -1
- package/lib/mol-gl/shader/mesh.vert.js +1 -1
- package/lib/mol-gl/shader/spheres.frag.d.ts +1 -1
- package/lib/mol-gl/shader/spheres.frag.js +1 -1
- package/lib/mol-gl/shader-code.d.ts +3 -1
- package/lib/mol-gl/shader-code.js +43 -14
- package/lib/mol-gl/webgl/render-item.d.ts +7 -6
- package/lib/mol-gl/webgl/render-item.js +8 -6
- package/lib/mol-gl/webgl/resources.js +8 -1
- package/lib/mol-io/reader/cif/schema/mmcif.d.ts +326 -1
- package/lib/mol-io/reader/cif/schema/mmcif.js +326 -1
- package/lib/mol-io/reader/mol2/parser.d.ts +1 -1
- package/lib/mol-io/reader/mol2/parser.js +33 -3
- package/lib/mol-io/reader/mol2/schema.d.ts +12 -1
- package/lib/mol-io/reader/mol2/schema.js +1 -1
- package/lib/mol-math/geometry/gaussian-density/gpu.js +2 -2
- package/lib/mol-math/geometry/symmetry-operator.js +3 -2
- package/lib/mol-math/linear-algebra/3d/quat.d.ts +9 -1
- package/lib/mol-math/linear-algebra/3d/quat.js +20 -1
- package/lib/mol-model/structure/model/model.d.ts +1 -0
- package/lib/mol-model/structure/model/model.js +8 -2
- package/lib/mol-model/structure/model/properties/atomic/hierarchy.d.ts +6 -1
- package/lib/mol-model/structure/model/properties/atomic/hierarchy.js +1 -1
- package/lib/mol-model/structure/model/properties/utils/atomic-derived.d.ts +1 -1
- package/lib/mol-model/structure/model/properties/utils/atomic-derived.js +5 -2
- package/lib/mol-model/structure/model/properties/utils/atomic-index.d.ts +1 -1
- package/lib/mol-model/structure/model/properties/utils/atomic-index.js +12 -1
- package/lib/mol-model/structure/model/types.js +9 -0
- package/lib/mol-model/structure/structure/element/stats.js +8 -0
- package/lib/mol-model/structure/structure/unit/bonds/common.d.ts +2 -1
- package/lib/mol-model/structure/structure/unit/bonds/common.js +9 -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 +21 -11
- 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 +22 -12
- package/lib/mol-model/structure/structure/unit/rings.js +2 -0
- package/lib/mol-model-formats/shape/ply.d.ts +20 -0
- package/lib/mol-model-formats/structure/mol2.d.ts +1 -1
- package/lib/mol-model-formats/structure/mol2.js +37 -7
- package/lib/mol-model-formats/structure/property/bonds/index-pair.d.ts +18 -1
- package/lib/mol-model-formats/structure/property/bonds/index-pair.js +18 -5
- package/lib/mol-model-props/computed/representations/interactions-inter-unit-cylinder.d.ts +10 -0
- package/lib/mol-model-props/computed/representations/interactions-intra-unit-cylinder.d.ts +10 -0
- package/lib/mol-model-props/computed/representations/interactions.d.ts +30 -0
- package/lib/mol-model-props/integrative/cross-link-restraint/representation.d.ts +40 -0
- package/lib/mol-plugin/behavior/dynamic/representation.js +4 -6
- package/lib/mol-plugin/behavior/dynamic/selection/structure-focus-representation.d.ts +11 -0
- package/lib/mol-plugin/behavior/dynamic/selection/structure-focus-representation.js +3 -1
- package/lib/mol-plugin/behavior/dynamic/volume-streaming/model.d.ts +3 -2
- package/lib/mol-plugin/commands.d.ts +1 -4
- package/lib/mol-plugin/config.d.ts +2 -2
- package/lib/mol-plugin/config.js +4 -23
- package/lib/mol-plugin/features.d.ts +9 -0
- package/lib/mol-plugin/features.js +35 -0
- package/lib/mol-plugin/spec.js +1 -0
- package/lib/mol-plugin/util/viewport-screenshot.d.ts +12 -0
- package/lib/mol-plugin/version.js +2 -2
- package/lib/mol-plugin-state/actions/structure.d.ts +8 -1
- package/lib/mol-plugin-state/actions/structure.js +183 -72
- package/lib/mol-plugin-state/builder/structure/hierarchy-preset.d.ts +5 -355
- package/lib/mol-plugin-state/builder/structure/hierarchy-preset.js +14 -9
- package/lib/mol-plugin-state/builder/structure/hierarchy.d.ts +1 -71
- package/lib/mol-plugin-state/builder/structure/representation-preset.d.ts +4 -4
- package/lib/mol-plugin-state/helpers/structure-clipping.d.ts +1 -1
- package/lib/mol-plugin-state/helpers/structure-clipping.js +1 -1
- package/lib/mol-plugin-state/helpers/structure-selection-query.js +34 -20
- package/lib/mol-plugin-state/manager/structure/component.d.ts +13 -1
- package/lib/mol-plugin-state/manager/structure/component.js +14 -9
- package/lib/mol-plugin-state/manager/structure/selection.js +3 -1
- package/lib/mol-plugin-state/transforms/representation.d.ts +32 -0
- package/lib/mol-plugin-state/transforms/representation.js +2 -2
- package/lib/mol-plugin-ui/index.d.ts +4 -4
- package/lib/mol-plugin-ui/index.js +11 -13
- package/lib/mol-plugin-ui/plugin.js +1 -1
- package/lib/mol-plugin-ui/skin/base/base.scss +32 -32
- package/lib/mol-plugin-ui/skin/base/components/controls-base.scss +333 -333
- package/lib/mol-plugin-ui/skin/base/components/controls.scss +418 -418
- 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 +643 -643
- 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 +127 -127
- 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 +85 -85
- 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/viewport/simple-settings.js +2 -6
- package/lib/mol-repr/shape/loci/angle.d.ts +10 -0
- package/lib/mol-repr/shape/loci/common.d.ts +10 -0
- package/lib/mol-repr/shape/loci/dihedral.d.ts +10 -0
- package/lib/mol-repr/shape/loci/distance.d.ts +10 -0
- package/lib/mol-repr/shape/loci/label.d.ts +10 -0
- package/lib/mol-repr/shape/loci/orientation.d.ts +10 -0
- package/lib/mol-repr/shape/loci/plane.d.ts +10 -0
- package/lib/mol-repr/shape/model/unitcell.d.ts +10 -0
- package/lib/mol-repr/structure/complex-representation.js +1 -1
- package/lib/mol-repr/structure/complex-visual.d.ts +61 -19
- package/lib/mol-repr/structure/params.d.ts +81 -19
- package/lib/mol-repr/structure/registry.d.ts +141 -19
- package/lib/mol-repr/structure/representation/backbone.d.ts +30 -0
- package/lib/mol-repr/structure/representation/ball-and-stick.d.ts +30 -0
- package/lib/mol-repr/structure/representation/carbohydrate.d.ts +30 -0
- package/lib/mol-repr/structure/representation/cartoon.d.ts +30 -0
- package/lib/mol-repr/structure/representation/ellipsoid.d.ts +30 -0
- package/lib/mol-repr/structure/representation/gaussian-surface.d.ts +30 -0
- package/lib/mol-repr/structure/representation/gaussian-surface.js +1 -1
- package/lib/mol-repr/structure/representation/gaussian-volume.d.ts +34 -58
- package/lib/mol-repr/structure/representation/gaussian-volume.js +2 -7
- package/lib/mol-repr/structure/representation/label.d.ts +30 -0
- package/lib/mol-repr/structure/representation/label.js +1 -1
- package/lib/mol-repr/structure/representation/line.d.ts +30 -0
- package/lib/mol-repr/structure/representation/molecular-surface.d.ts +30 -0
- package/lib/mol-repr/structure/representation/molecular-surface.js +1 -1
- package/lib/mol-repr/structure/representation/orientation.d.ts +30 -0
- package/lib/mol-repr/structure/representation/point.d.ts +30 -0
- package/lib/mol-repr/structure/representation/putty.d.ts +30 -0
- package/lib/mol-repr/structure/representation/spacefill.d.ts +30 -0
- package/lib/mol-repr/structure/units-representation.js +1 -1
- package/lib/mol-repr/structure/units-visual.d.ts +81 -19
- package/lib/mol-repr/structure/visual/bond-inter-unit-cylinder.d.ts +20 -0
- package/lib/mol-repr/structure/visual/bond-inter-unit-line.d.ts +10 -0
- package/lib/mol-repr/structure/visual/bond-intra-unit-cylinder.d.ts +20 -0
- package/lib/mol-repr/structure/visual/bond-intra-unit-cylinder.js +2 -2
- package/lib/mol-repr/structure/visual/bond-intra-unit-line.d.ts +10 -0
- package/lib/mol-repr/structure/visual/bond-intra-unit-line.js +2 -2
- package/lib/mol-repr/structure/visual/carbohydrate-link-cylinder.d.ts +10 -0
- package/lib/mol-repr/structure/visual/carbohydrate-symbol-mesh.d.ts +10 -0
- package/lib/mol-repr/structure/visual/carbohydrate-terminal-link-cylinder.d.ts +10 -0
- package/lib/mol-repr/structure/visual/element-cross.d.ts +10 -0
- package/lib/mol-repr/structure/visual/element-point.d.ts +10 -0
- package/lib/mol-repr/structure/visual/element-sphere.d.ts +20 -0
- package/lib/mol-repr/structure/visual/ellipsoid-mesh.d.ts +10 -0
- package/lib/mol-repr/structure/visual/gaussian-density-volume.d.ts +22 -38
- package/lib/mol-repr/structure/visual/gaussian-density-volume.js +8 -6
- package/lib/mol-repr/structure/visual/gaussian-surface-mesh.d.ts +40 -0
- package/lib/mol-repr/structure/visual/gaussian-surface-mesh.js +11 -8
- package/lib/mol-repr/structure/visual/gaussian-surface-wireframe.d.ts +10 -0
- package/lib/mol-repr/structure/visual/gaussian-surface-wireframe.js +1 -1
- package/lib/mol-repr/structure/visual/label-text.d.ts +10 -0
- package/lib/mol-repr/structure/visual/label-text.js +1 -2
- package/lib/mol-repr/structure/visual/molecular-surface-mesh.d.ts +10 -0
- package/lib/mol-repr/structure/visual/molecular-surface-mesh.js +1 -1
- package/lib/mol-repr/structure/visual/molecular-surface-wireframe.d.ts +10 -0
- package/lib/mol-repr/structure/visual/molecular-surface-wireframe.js +1 -1
- package/lib/mol-repr/structure/visual/nucleotide-block-mesh.d.ts +10 -0
- package/lib/mol-repr/structure/visual/nucleotide-ring-mesh.d.ts +10 -0
- package/lib/mol-repr/structure/visual/orientation-ellipsoid-mesh.d.ts +10 -0
- package/lib/mol-repr/structure/visual/polymer-backbone-cylinder.d.ts +20 -0
- package/lib/mol-repr/structure/visual/polymer-backbone-sphere.d.ts +20 -0
- package/lib/mol-repr/structure/visual/polymer-direction-wedge.d.ts +10 -0
- package/lib/mol-repr/structure/visual/polymer-gap-cylinder.d.ts +10 -0
- package/lib/mol-repr/structure/visual/polymer-trace-mesh.d.ts +10 -0
- package/lib/mol-repr/structure/visual/polymer-trace-mesh.js +1 -1
- package/lib/mol-repr/structure/visual/polymer-tube-mesh.d.ts +10 -0
- package/lib/mol-repr/structure/visual/util/bond.js +1 -1
- package/lib/mol-repr/structure/visual/util/common.d.ts +3 -2
- package/lib/mol-repr/structure/visual/util/common.js +2 -5
- package/lib/mol-repr/structure/visual/util/gaussian.d.ts +7 -6
- package/lib/mol-repr/structure/visual/util/gaussian.js +12 -12
- package/lib/mol-repr/structure/visual/util/molecular-surface.d.ts +2 -1
- package/lib/mol-repr/structure/visual/util/molecular-surface.js +4 -4
- package/lib/mol-repr/visual.js +11 -7
- package/lib/mol-repr/volume/direct-volume.d.ts +33 -57
- package/lib/mol-repr/volume/direct-volume.js +8 -12
- package/lib/mol-repr/volume/isosurface.d.ts +60 -0
- package/lib/mol-repr/volume/isosurface.js +11 -2
- package/lib/mol-repr/volume/registry.d.ts +31 -19
- package/lib/mol-repr/volume/representation.d.ts +10 -0
- package/lib/mol-repr/volume/slice.d.ts +30 -0
- package/lib/mol-repr/volume/slice.js +2 -2
- package/lib/mol-repr/volume/util.js +2 -2
- package/lib/mol-script/language/builder.d.ts +0 -1
- package/lib/mol-theme/clipping.d.ts +7 -15
- package/lib/mol-theme/clipping.js +5 -12
- package/lib/mol-theme/color/volume-value.d.ts +17 -0
- package/lib/mol-theme/color/volume-value.js +52 -0
- package/lib/mol-theme/color.d.ts +3 -0
- package/lib/mol-theme/color.js +2 -0
- package/lib/mol-util/clip.d.ts +49 -0
- package/lib/mol-util/clip.js +93 -0
- package/lib/mol-util/number-packing.d.ts +11 -0
- package/lib/mol-util/{float-packing.js → number-packing.js} +7 -14
- package/package.json +162 -162
- package/lib/commonjs/mol-util/float-packing.d.ts +0 -15
- package/lib/mol-util/float-packing.d.ts +0 -15
|
@@ -11,6 +11,7 @@ import { addSphere } from '../../mol-geo/geometry/mesh/builder/sphere';
|
|
|
11
11
|
import { Mesh } from '../../mol-geo/geometry/mesh/mesh';
|
|
12
12
|
import { MeshBuilder } from '../../mol-geo/geometry/mesh/mesh-builder';
|
|
13
13
|
import { Scene } from '../../mol-gl/scene';
|
|
14
|
+
import { GraphicsRenderVariantsBlended } from '../../mol-gl/webgl/render-item';
|
|
14
15
|
import { Sphere3D } from '../../mol-math/geometry';
|
|
15
16
|
import { Mat4, Vec3 } from '../../mol-math/linear-algebra';
|
|
16
17
|
import { DataLoci, EmptyLoci } from '../../mol-model/loci';
|
|
@@ -52,7 +53,7 @@ var CameraHelper = /** @class */ (function () {
|
|
|
52
53
|
}
|
|
53
54
|
return changed;
|
|
54
55
|
};
|
|
55
|
-
this.scene = Scene.create(webgl);
|
|
56
|
+
this.scene = Scene.create(webgl, GraphicsRenderVariantsBlended);
|
|
56
57
|
this.camera = new Camera();
|
|
57
58
|
Vec3.set(this.camera.up, 0, 1, 0);
|
|
58
59
|
Vec3.set(this.camera.target, 0, 0, 0);
|
|
@@ -67,7 +68,6 @@ var CameraHelper = /** @class */ (function () {
|
|
|
67
68
|
_this.scene.clear();
|
|
68
69
|
var params = __assign(__assign({}, props.axes.params), { scale: props.axes.params.scale * _this.webgl.pixelRatio });
|
|
69
70
|
_this.renderObject = createAxesRenderObject(params);
|
|
70
|
-
_this.renderObject.state.noClip = true;
|
|
71
71
|
_this.scene.add(_this.renderObject);
|
|
72
72
|
_this.scene.commit();
|
|
73
73
|
Vec3.set(_this.camera.position, 0, 0, params.scale * 200);
|
|
@@ -20,6 +20,7 @@ import { DataLoci, EmptyLoci } from '../../mol-model/loci';
|
|
|
20
20
|
import { MarkerActions } from '../../mol-util/marker-action';
|
|
21
21
|
import { Visual } from '../../mol-repr/visual';
|
|
22
22
|
import { Interval } from '../../mol-data/int';
|
|
23
|
+
import { GraphicsRenderVariantsBlended } from '../../mol-gl/webgl/render-item';
|
|
23
24
|
var HandleParams = __assign(__assign({}, Mesh.Params), { alpha: __assign(__assign({}, Mesh.Params.alpha), { defaultValue: 1 }), ignoreLight: __assign(__assign({}, Mesh.Params.ignoreLight), { defaultValue: true }), colorX: PD.Color(ColorNames.red, { isEssential: true }), colorY: PD.Color(ColorNames.green, { isEssential: true }), colorZ: PD.Color(ColorNames.blue, { isEssential: true }), scale: PD.Numeric(0.33, { min: 0.1, max: 2, step: 0.1 }, { isEssential: true }) });
|
|
24
25
|
export var HandleHelperParams = {
|
|
25
26
|
handle: PD.MappedStatic('off', {
|
|
@@ -52,7 +53,7 @@ var HandleHelper = /** @class */ (function () {
|
|
|
52
53
|
}
|
|
53
54
|
return changed;
|
|
54
55
|
};
|
|
55
|
-
this.scene = Scene.create(webgl);
|
|
56
|
+
this.scene = Scene.create(webgl, GraphicsRenderVariantsBlended);
|
|
56
57
|
this.setProps(props);
|
|
57
58
|
}
|
|
58
59
|
HandleHelper.prototype.getBoundingSphere = function (out, instanceId) {
|
|
@@ -72,7 +73,6 @@ var HandleHelper = /** @class */ (function () {
|
|
|
72
73
|
_this.scene.clear();
|
|
73
74
|
var params = __assign(__assign({}, props.handle.params), { scale: props.handle.params.scale * _this.webgl.pixelRatio });
|
|
74
75
|
_this.renderObject = createHandleRenderObject(params);
|
|
75
|
-
_this.renderObject.state.noClip = true;
|
|
76
76
|
_this.scene.add(_this.renderObject);
|
|
77
77
|
_this.scene.commit();
|
|
78
78
|
p.handle.params = __assign({}, props.handle.params);
|
|
@@ -37,6 +37,7 @@ export declare const HelperParams: {
|
|
|
37
37
|
bumpAmplitude: any;
|
|
38
38
|
quality: any;
|
|
39
39
|
material: any;
|
|
40
|
+
clip: any;
|
|
40
41
|
}>, "on">;
|
|
41
42
|
}>>;
|
|
42
43
|
};
|
|
@@ -68,6 +69,7 @@ export declare const DefaultHelperProps: PD.Values<{
|
|
|
68
69
|
bumpAmplitude: any;
|
|
69
70
|
quality: any;
|
|
70
71
|
material: any;
|
|
72
|
+
clip: any;
|
|
71
73
|
}>, "on">;
|
|
72
74
|
}>>;
|
|
73
75
|
}>;
|
|
@@ -14,6 +14,17 @@ import { Helper } from '../helper/helper';
|
|
|
14
14
|
import { StereoCamera } from '../camera/stereo';
|
|
15
15
|
import { PostprocessingPass, PostprocessingProps } from './postprocessing';
|
|
16
16
|
import { MarkingProps } from './marking';
|
|
17
|
+
declare type Props = {
|
|
18
|
+
postprocessing: PostprocessingProps;
|
|
19
|
+
marking: MarkingProps;
|
|
20
|
+
transparentBackground: boolean;
|
|
21
|
+
};
|
|
22
|
+
declare type RenderContext = {
|
|
23
|
+
renderer: Renderer;
|
|
24
|
+
camera: Camera | StereoCamera;
|
|
25
|
+
scene: Scene;
|
|
26
|
+
helper: Helper;
|
|
27
|
+
};
|
|
17
28
|
export declare class DrawPass {
|
|
18
29
|
private webgl;
|
|
19
30
|
private readonly drawTarget;
|
|
@@ -40,6 +51,7 @@ export declare class DrawPass {
|
|
|
40
51
|
private _renderWboit;
|
|
41
52
|
private _renderBlended;
|
|
42
53
|
private _render;
|
|
43
|
-
render(
|
|
54
|
+
render(ctx: RenderContext, props: Props, toDrawingBuffer: boolean): void;
|
|
44
55
|
getColorTarget(postprocessingProps: PostprocessingProps): RenderTarget;
|
|
45
56
|
}
|
|
57
|
+
export {};
|
|
@@ -194,23 +194,23 @@ var DrawPass = /** @class */ (function () {
|
|
|
194
194
|
}
|
|
195
195
|
renderer.renderBlendedTransparent(scene.primitives, camera, null);
|
|
196
196
|
};
|
|
197
|
-
DrawPass.prototype._render = function (renderer, camera, scene, helper, toDrawingBuffer,
|
|
197
|
+
DrawPass.prototype._render = function (renderer, camera, scene, helper, toDrawingBuffer, props) {
|
|
198
198
|
var volumeRendering = scene.volumes.renderables.length > 0;
|
|
199
|
-
var postprocessingEnabled = PostprocessingPass.isEnabled(
|
|
200
|
-
var antialiasingEnabled = AntialiasingPass.isEnabled(
|
|
201
|
-
var markingEnabled = MarkingPass.isEnabled(
|
|
199
|
+
var postprocessingEnabled = PostprocessingPass.isEnabled(props.postprocessing);
|
|
200
|
+
var antialiasingEnabled = AntialiasingPass.isEnabled(props.postprocessing);
|
|
201
|
+
var markingEnabled = MarkingPass.isEnabled(props.marking);
|
|
202
202
|
var _a = camera.viewport, x = _a.x, y = _a.y, width = _a.width, height = _a.height;
|
|
203
203
|
renderer.setViewport(x, y, width, height);
|
|
204
204
|
renderer.update(camera);
|
|
205
|
-
if (transparentBackground && !antialiasingEnabled && toDrawingBuffer) {
|
|
205
|
+
if (props.transparentBackground && !antialiasingEnabled && toDrawingBuffer) {
|
|
206
206
|
this.drawTarget.bind();
|
|
207
207
|
renderer.clear(false);
|
|
208
208
|
}
|
|
209
209
|
if (this.wboitEnabled) {
|
|
210
|
-
this._renderWboit(renderer, camera, scene, transparentBackground,
|
|
210
|
+
this._renderWboit(renderer, camera, scene, props.transparentBackground, props.postprocessing);
|
|
211
211
|
}
|
|
212
212
|
else {
|
|
213
|
-
this._renderBlended(renderer, camera, scene, !volumeRendering && !postprocessingEnabled && !antialiasingEnabled && toDrawingBuffer, transparentBackground,
|
|
213
|
+
this._renderBlended(renderer, camera, scene, !volumeRendering && !postprocessingEnabled && !antialiasingEnabled && toDrawingBuffer, props.transparentBackground, props.postprocessing);
|
|
214
214
|
}
|
|
215
215
|
if (postprocessingEnabled) {
|
|
216
216
|
this.postprocessing.target.bind();
|
|
@@ -222,7 +222,7 @@ var DrawPass = /** @class */ (function () {
|
|
|
222
222
|
this.drawTarget.bind();
|
|
223
223
|
}
|
|
224
224
|
if (markingEnabled) {
|
|
225
|
-
var markingDepthTest =
|
|
225
|
+
var markingDepthTest = props.marking.ghostEdgeStrength < 1;
|
|
226
226
|
if (markingDepthTest) {
|
|
227
227
|
this.marking.depthTarget.bind();
|
|
228
228
|
renderer.clear(false);
|
|
@@ -231,7 +231,7 @@ var DrawPass = /** @class */ (function () {
|
|
|
231
231
|
this.marking.maskTarget.bind();
|
|
232
232
|
renderer.clear(false);
|
|
233
233
|
renderer.renderMarkingMask(scene.primitives, camera, markingDepthTest ? this.marking.depthTarget.texture : null);
|
|
234
|
-
this.marking.update(
|
|
234
|
+
this.marking.update(props.marking);
|
|
235
235
|
this.marking.render(camera.viewport, postprocessingEnabled ? this.postprocessing.target : this.colorTarget);
|
|
236
236
|
}
|
|
237
237
|
if (helper.debug.isEnabled) {
|
|
@@ -247,7 +247,7 @@ var DrawPass = /** @class */ (function () {
|
|
|
247
247
|
renderer.renderBlended(helper.camera.scene, helper.camera.camera, null);
|
|
248
248
|
}
|
|
249
249
|
if (antialiasingEnabled) {
|
|
250
|
-
this.antialiasing.render(camera, toDrawingBuffer,
|
|
250
|
+
this.antialiasing.render(camera, toDrawingBuffer, props.postprocessing);
|
|
251
251
|
}
|
|
252
252
|
else if (toDrawingBuffer) {
|
|
253
253
|
this.drawTarget.bind();
|
|
@@ -261,16 +261,17 @@ var DrawPass = /** @class */ (function () {
|
|
|
261
261
|
}
|
|
262
262
|
this.webgl.gl.flush();
|
|
263
263
|
};
|
|
264
|
-
DrawPass.prototype.render = function (
|
|
265
|
-
renderer.
|
|
264
|
+
DrawPass.prototype.render = function (ctx, props, toDrawingBuffer) {
|
|
265
|
+
var renderer = ctx.renderer, camera = ctx.camera, scene = ctx.scene, helper = ctx.helper;
|
|
266
|
+
renderer.setTransparentBackground(props.transparentBackground);
|
|
266
267
|
renderer.setDrawingBufferSize(this.colorTarget.getWidth(), this.colorTarget.getHeight());
|
|
267
268
|
renderer.setPixelRatio(this.webgl.pixelRatio);
|
|
268
269
|
if (StereoCamera.is(camera)) {
|
|
269
|
-
this._render(renderer, camera.left, scene, helper, toDrawingBuffer,
|
|
270
|
-
this._render(renderer, camera.right, scene, helper, toDrawingBuffer,
|
|
270
|
+
this._render(renderer, camera.left, scene, helper, toDrawingBuffer, props);
|
|
271
|
+
this._render(renderer, camera.right, scene, helper, toDrawingBuffer, props);
|
|
271
272
|
}
|
|
272
273
|
else {
|
|
273
|
-
this._render(renderer, camera, scene, helper, toDrawingBuffer,
|
|
274
|
+
this._render(renderer, camera, scene, helper, toDrawingBuffer, props);
|
|
274
275
|
}
|
|
275
276
|
};
|
|
276
277
|
DrawPass.prototype.getColorTarget = function (postprocessingProps) {
|
|
@@ -73,12 +73,13 @@ var ImagePass = /** @class */ (function () {
|
|
|
73
73
|
Camera.copySnapshot(this._camera.state, this.camera.state);
|
|
74
74
|
Viewport.set(this._camera.viewport, 0, 0, this._width, this._height);
|
|
75
75
|
this._camera.update();
|
|
76
|
+
var ctx = { renderer: this.renderer, camera: this._camera, scene: this.scene, helper: this.helper };
|
|
76
77
|
if (MultiSamplePass.isEnabled(this.props.multiSample)) {
|
|
77
|
-
this.multiSampleHelper.render(
|
|
78
|
+
this.multiSampleHelper.render(ctx, this.props, false);
|
|
78
79
|
this._colorTarget = this.multiSamplePass.colorTarget;
|
|
79
80
|
}
|
|
80
81
|
else {
|
|
81
|
-
this.drawPass.render(
|
|
82
|
+
this.drawPass.render(ctx, this.props, false);
|
|
82
83
|
this._colorTarget = this.drawPass.getColorTarget(this.props.postprocessing);
|
|
83
84
|
}
|
|
84
85
|
};
|
|
@@ -17,7 +17,7 @@ import { overlay_frag } from '../../mol-gl/shader/marking/overlay.frag';
|
|
|
17
17
|
import { Color } from '../../mol-util/color';
|
|
18
18
|
import { edge_frag } from '../../mol-gl/shader/marking/edge.frag';
|
|
19
19
|
export var MarkingParams = {
|
|
20
|
-
enabled: PD.Boolean(
|
|
20
|
+
enabled: PD.Boolean(true),
|
|
21
21
|
highlightEdgeColor: PD.Color(Color.darken(Color.fromNormalizedRgb(1.0, 0.4, 0.6), 1.0)),
|
|
22
22
|
selectEdgeColor: PD.Color(Color.darken(Color.fromNormalizedRgb(0.2, 1.0, 0.1), 1.0)),
|
|
23
23
|
edgeScale: PD.Numeric(1, { min: 1, max: 3, step: 1 }, { description: 'Thickness of the edge.' }),
|
|
@@ -23,6 +23,13 @@ declare type Props = {
|
|
|
23
23
|
multiSample: MultiSampleProps;
|
|
24
24
|
postprocessing: PostprocessingProps;
|
|
25
25
|
marking: MarkingProps;
|
|
26
|
+
transparentBackground: boolean;
|
|
27
|
+
};
|
|
28
|
+
declare type RenderContext = {
|
|
29
|
+
renderer: Renderer;
|
|
30
|
+
camera: Camera | StereoCamera;
|
|
31
|
+
scene: Scene;
|
|
32
|
+
helper: Helper;
|
|
26
33
|
};
|
|
27
34
|
export declare class MultiSamplePass {
|
|
28
35
|
private webgl;
|
|
@@ -34,7 +41,7 @@ export declare class MultiSamplePass {
|
|
|
34
41
|
private compose;
|
|
35
42
|
constructor(webgl: WebGLContext, drawPass: DrawPass);
|
|
36
43
|
syncSize(): void;
|
|
37
|
-
render(sampleIndex: number,
|
|
44
|
+
render(sampleIndex: number, ctx: RenderContext, props: Props, toDrawingBuffer: boolean, forceOn: boolean): number;
|
|
38
45
|
private bindOutputTarget;
|
|
39
46
|
private renderMultiSample;
|
|
40
47
|
private renderTemporalMultiSample;
|
|
@@ -43,7 +50,8 @@ export declare class MultiSampleHelper {
|
|
|
43
50
|
private multiSamplePass;
|
|
44
51
|
private sampleIndex;
|
|
45
52
|
update(changed: boolean, props: MultiSampleProps): boolean;
|
|
46
|
-
|
|
53
|
+
/** Return `true` while more samples are needed */
|
|
54
|
+
render(ctx: RenderContext, props: Props, toDrawingBuffer: boolean, forceOn?: boolean): boolean;
|
|
47
55
|
constructor(multiSamplePass: MultiSamplePass);
|
|
48
56
|
}
|
|
49
57
|
export {};
|
|
@@ -24,8 +24,8 @@ function getComposeRenderable(ctx, colorTexture) {
|
|
|
24
24
|
return createComputeRenderable(renderItem, values);
|
|
25
25
|
}
|
|
26
26
|
export var MultiSampleParams = {
|
|
27
|
-
mode: PD.Select('
|
|
28
|
-
sampleLevel: PD.Numeric(2, { min: 0, max: 5, step: 1 }),
|
|
27
|
+
mode: PD.Select('temporal', [['off', 'Off'], ['on', 'On'], ['temporal', 'Temporal']]),
|
|
28
|
+
sampleLevel: PD.Numeric(2, { min: 0, max: 5, step: 1 }, { description: 'Take level^2 samples.' }),
|
|
29
29
|
};
|
|
30
30
|
var MultiSamplePass = /** @class */ (function () {
|
|
31
31
|
function MultiSamplePass(webgl, drawPass) {
|
|
@@ -55,13 +55,13 @@ var MultiSamplePass = /** @class */ (function () {
|
|
|
55
55
|
ValueCell.update(this.compose.values.uTexSize, Vec2.set(this.compose.values.uTexSize.ref.value, width, height));
|
|
56
56
|
}
|
|
57
57
|
};
|
|
58
|
-
MultiSamplePass.prototype.render = function (sampleIndex,
|
|
59
|
-
if (props.multiSample.mode === 'temporal') {
|
|
60
|
-
return this.renderTemporalMultiSample(sampleIndex,
|
|
58
|
+
MultiSamplePass.prototype.render = function (sampleIndex, ctx, props, toDrawingBuffer, forceOn) {
|
|
59
|
+
if (props.multiSample.mode === 'temporal' && !forceOn) {
|
|
60
|
+
return this.renderTemporalMultiSample(sampleIndex, ctx, props, toDrawingBuffer);
|
|
61
61
|
}
|
|
62
62
|
else {
|
|
63
|
-
this.renderMultiSample(
|
|
64
|
-
return
|
|
63
|
+
this.renderMultiSample(ctx, toDrawingBuffer, props);
|
|
64
|
+
return -2;
|
|
65
65
|
}
|
|
66
66
|
};
|
|
67
67
|
MultiSamplePass.prototype.bindOutputTarget = function (toDrawingBuffer) {
|
|
@@ -72,7 +72,8 @@ var MultiSamplePass = /** @class */ (function () {
|
|
|
72
72
|
this.colorTarget.bind();
|
|
73
73
|
}
|
|
74
74
|
};
|
|
75
|
-
MultiSamplePass.prototype.renderMultiSample = function (
|
|
75
|
+
MultiSamplePass.prototype.renderMultiSample = function (ctx, toDrawingBuffer, props) {
|
|
76
|
+
var camera = ctx.camera;
|
|
76
77
|
var _a = this, compose = _a.compose, composeTarget = _a.composeTarget, drawPass = _a.drawPass, webgl = _a.webgl;
|
|
77
78
|
var gl = webgl.gl, state = webgl.state;
|
|
78
79
|
// based on the Multisample Anti-Aliasing Render Pass
|
|
@@ -100,7 +101,7 @@ var MultiSamplePass = /** @class */ (function () {
|
|
|
100
101
|
var sampleWeight = baseSampleWeight + roundingRange * uniformCenteredDistribution;
|
|
101
102
|
ValueCell.update(compose.values.uWeight, sampleWeight);
|
|
102
103
|
// render scene
|
|
103
|
-
drawPass.render(
|
|
104
|
+
drawPass.render(ctx, props, false);
|
|
104
105
|
// compose rendered scene with compose target
|
|
105
106
|
composeTarget.bind();
|
|
106
107
|
state.enable(gl.BLEND);
|
|
@@ -127,7 +128,8 @@ var MultiSamplePass = /** @class */ (function () {
|
|
|
127
128
|
camera.viewOffset.enabled = false;
|
|
128
129
|
camera.update();
|
|
129
130
|
};
|
|
130
|
-
MultiSamplePass.prototype.renderTemporalMultiSample = function (sampleIndex,
|
|
131
|
+
MultiSamplePass.prototype.renderTemporalMultiSample = function (sampleIndex, ctx, props, toDrawingBuffer) {
|
|
132
|
+
var camera = ctx.camera;
|
|
131
133
|
var _a = this, compose = _a.compose, composeTarget = _a.composeTarget, holdTarget = _a.holdTarget, drawPass = _a.drawPass, webgl = _a.webgl;
|
|
132
134
|
var gl = webgl.gl, state = webgl.state;
|
|
133
135
|
// based on the Multisample Anti-Aliasing Render Pass
|
|
@@ -141,7 +143,7 @@ var MultiSamplePass = /** @class */ (function () {
|
|
|
141
143
|
var _b = camera.viewport, x = _b.x, y = _b.y, width = _b.width, height = _b.height;
|
|
142
144
|
var sampleWeight = 1.0 / offsetList.length;
|
|
143
145
|
if (sampleIndex === -1) {
|
|
144
|
-
drawPass.render(
|
|
146
|
+
drawPass.render(ctx, props, false);
|
|
145
147
|
ValueCell.update(compose.values.uWeight, 1.0);
|
|
146
148
|
ValueCell.update(compose.values.tColor, drawPass.getColorTarget(props.postprocessing).texture);
|
|
147
149
|
compose.update();
|
|
@@ -167,7 +169,7 @@ var MultiSamplePass = /** @class */ (function () {
|
|
|
167
169
|
Camera.setViewOffset(camera.viewOffset, width, height, offset[0], offset[1], width, height);
|
|
168
170
|
camera.update();
|
|
169
171
|
// render scene
|
|
170
|
-
drawPass.render(
|
|
172
|
+
drawPass.render(ctx, props, false);
|
|
171
173
|
// compose rendered scene with compose target
|
|
172
174
|
composeTarget.bind();
|
|
173
175
|
state.enable(gl.BLEND);
|
|
@@ -263,8 +265,10 @@ var MultiSampleHelper = /** @class */ (function () {
|
|
|
263
265
|
this.sampleIndex = -1;
|
|
264
266
|
return props.mode === 'temporal' ? this.sampleIndex !== -2 : false;
|
|
265
267
|
};
|
|
266
|
-
|
|
267
|
-
|
|
268
|
+
/** Return `true` while more samples are needed */
|
|
269
|
+
MultiSampleHelper.prototype.render = function (ctx, props, toDrawingBuffer, forceOn) {
|
|
270
|
+
this.sampleIndex = this.multiSamplePass.render(this.sampleIndex, ctx, props, toDrawingBuffer, !!forceOn);
|
|
271
|
+
return this.sampleIndex < 0;
|
|
268
272
|
};
|
|
269
273
|
return MultiSampleHelper;
|
|
270
274
|
}());
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
*/
|
|
6
6
|
import { Vec3 } from '../../mol-math/linear-algebra';
|
|
7
7
|
import { spiral2d } from '../../mol-math/misc';
|
|
8
|
-
import {
|
|
8
|
+
import { unpackRGBToInt, unpackRGBAToDepth } from '../../mol-util/number-packing';
|
|
9
9
|
import { StereoCamera } from '../camera/stereo';
|
|
10
10
|
import { cameraUnproject } from '../camera/util';
|
|
11
11
|
import { Viewport } from '../camera/util';
|
|
@@ -43,29 +43,29 @@ var PickPass = /** @class */ (function () {
|
|
|
43
43
|
this.depthPickTarget.setSize(this.pickWidth, this.pickHeight);
|
|
44
44
|
}
|
|
45
45
|
};
|
|
46
|
-
PickPass.prototype.renderVariant = function (renderer, camera, scene, helper, variant) {
|
|
46
|
+
PickPass.prototype.renderVariant = function (renderer, camera, scene, helper, variant, pickType) {
|
|
47
47
|
var depth = this.drawPass.depthTexturePrimitives;
|
|
48
48
|
renderer.clear(false);
|
|
49
49
|
renderer.update(camera);
|
|
50
|
-
renderer.renderPick(scene.primitives, camera, variant, null);
|
|
51
|
-
renderer.renderPick(scene.volumes, camera, variant, depth);
|
|
52
|
-
renderer.renderPick(helper.handle.scene, camera, variant, null);
|
|
50
|
+
renderer.renderPick(scene.primitives, camera, variant, null, pickType);
|
|
51
|
+
renderer.renderPick(scene.volumes, camera, variant, depth, pickType);
|
|
52
|
+
renderer.renderPick(helper.handle.scene, camera, variant, null, pickType);
|
|
53
53
|
if (helper.camera.isEnabled) {
|
|
54
54
|
helper.camera.update(camera);
|
|
55
55
|
renderer.update(helper.camera.camera);
|
|
56
|
-
renderer.renderPick(helper.camera.scene, helper.camera.camera, variant, null);
|
|
56
|
+
renderer.renderPick(helper.camera.scene, helper.camera.camera, variant, null, pickType);
|
|
57
57
|
}
|
|
58
58
|
};
|
|
59
59
|
PickPass.prototype.render = function (renderer, camera, scene, helper) {
|
|
60
60
|
this.objectPickTarget.bind();
|
|
61
|
-
this.renderVariant(renderer, camera, scene, helper, '
|
|
61
|
+
this.renderVariant(renderer, camera, scene, helper, 'pick', 1 /* Object */);
|
|
62
62
|
this.instancePickTarget.bind();
|
|
63
|
-
this.renderVariant(renderer, camera, scene, helper, '
|
|
63
|
+
this.renderVariant(renderer, camera, scene, helper, 'pick', 2 /* Instance */);
|
|
64
64
|
this.groupPickTarget.bind();
|
|
65
|
-
this.renderVariant(renderer, camera, scene, helper, '
|
|
65
|
+
this.renderVariant(renderer, camera, scene, helper, 'pick', 3 /* Group */);
|
|
66
66
|
// printTexture(this.webgl, this.groupPickTarget.texture, { id: 'group' })
|
|
67
67
|
this.depthPickTarget.bind();
|
|
68
|
-
this.renderVariant(renderer, camera, scene, helper, 'depth');
|
|
68
|
+
this.renderVariant(renderer, camera, scene, helper, 'depth', 0 /* None */);
|
|
69
69
|
};
|
|
70
70
|
return PickPass;
|
|
71
71
|
}());
|
|
@@ -128,7 +128,7 @@ var PickHelper = /** @class */ (function () {
|
|
|
128
128
|
};
|
|
129
129
|
PickHelper.prototype.getId = function (x, y, buffer) {
|
|
130
130
|
var idx = this.getBufferIdx(x, y);
|
|
131
|
-
return
|
|
131
|
+
return unpackRGBToInt(buffer[idx], buffer[idx + 1], buffer[idx + 2]);
|
|
132
132
|
};
|
|
133
133
|
PickHelper.prototype.render = function (camera) {
|
|
134
134
|
var _a = this, pickX = _a.pickX, pickY = _a.pickY, pickWidth = _a.pickWidth, pickHeight = _a.pickHeight, halfPickWidth = _a.halfPickWidth;
|
|
@@ -31,7 +31,7 @@ function getOutlinesRenderable(ctx, depthTexture) {
|
|
|
31
31
|
}
|
|
32
32
|
var SsaoSchema = __assign(__assign({}, QuadSchema), { tDepth: TextureSpec('texture', 'rgba', 'ubyte', 'nearest'), uSamples: UniformSpec('v3[]'), dNSamples: DefineSpec('number'), uProjection: UniformSpec('m4'), uInvProjection: UniformSpec('m4'), uBounds: UniformSpec('v4'), uTexSize: UniformSpec('v2'), uRadius: UniformSpec('f'), uBias: UniformSpec('f') });
|
|
33
33
|
function getSsaoRenderable(ctx, depthTexture) {
|
|
34
|
-
var values = __assign(__assign({}, QuadValues), { tDepth: ValueCell.create(depthTexture), uSamples: ValueCell.create([0.0, 0.0, 1.0]), dNSamples: ValueCell.create(
|
|
34
|
+
var values = __assign(__assign({}, QuadValues), { tDepth: ValueCell.create(depthTexture), uSamples: ValueCell.create([0.0, 0.0, 1.0]), dNSamples: ValueCell.create(32), uProjection: ValueCell.create(Mat4.identity()), uInvProjection: ValueCell.create(Mat4.identity()), uBounds: ValueCell.create(Vec4()), uTexSize: ValueCell.create(Vec2.create(ctx.gl.drawingBufferWidth, ctx.gl.drawingBufferHeight)), uRadius: ValueCell.create(8.0), uBias: ValueCell.create(0.025) });
|
|
35
35
|
var schema = __assign({}, SsaoSchema);
|
|
36
36
|
var shaderCode = ShaderCode('ssao', quad_vert, ssao_frag);
|
|
37
37
|
var renderItem = createComputeRenderItem(ctx, 'triangles', shaderCode, schema, values);
|
|
@@ -39,7 +39,7 @@ function getSsaoRenderable(ctx, depthTexture) {
|
|
|
39
39
|
}
|
|
40
40
|
var SsaoBlurSchema = __assign(__assign({}, QuadSchema), { tSsaoDepth: TextureSpec('texture', 'rgba', 'ubyte', 'nearest'), uTexSize: UniformSpec('v2'), uKernel: UniformSpec('f[]'), dOcclusionKernelSize: DefineSpec('number'), uBlurDirectionX: UniformSpec('f'), uBlurDirectionY: UniformSpec('f'), uMaxPossibleViewZDiff: UniformSpec('f'), uNear: UniformSpec('f'), uFar: UniformSpec('f'), uBounds: UniformSpec('v4'), dOrthographic: DefineSpec('number') });
|
|
41
41
|
function getSsaoBlurRenderable(ctx, ssaoDepthTexture, direction) {
|
|
42
|
-
var values = __assign(__assign({}, QuadValues), { tSsaoDepth: ValueCell.create(ssaoDepthTexture), uTexSize: ValueCell.create(Vec2.create(ssaoDepthTexture.getWidth(), ssaoDepthTexture.getHeight())), uKernel: ValueCell.create([0.0]), dOcclusionKernelSize: ValueCell.create(
|
|
42
|
+
var values = __assign(__assign({}, QuadValues), { tSsaoDepth: ValueCell.create(ssaoDepthTexture), uTexSize: ValueCell.create(Vec2.create(ssaoDepthTexture.getWidth(), ssaoDepthTexture.getHeight())), uKernel: ValueCell.create([0.0]), dOcclusionKernelSize: ValueCell.create(15), uBlurDirectionX: ValueCell.create(direction === 'horizontal' ? 1 : 0), uBlurDirectionY: ValueCell.create(direction === 'vertical' ? 1 : 0), uMaxPossibleViewZDiff: ValueCell.create(0.5), uNear: ValueCell.create(0.0), uFar: ValueCell.create(10000.0), uBounds: ValueCell.create(Vec4()), dOrthographic: ValueCell.create(0) });
|
|
43
43
|
var schema = __assign({}, SsaoBlurSchema);
|
|
44
44
|
var shaderCode = ShaderCode('ssao_blur', quad_vert, ssaoBlur_frag);
|
|
45
45
|
var renderItem = createComputeRenderItem(ctx, 'triangles', shaderCode, schema, values);
|
|
@@ -67,7 +67,7 @@ function getSamples(vectorSamples, nSamples) {
|
|
|
67
67
|
}
|
|
68
68
|
var PostprocessingSchema = __assign(__assign({}, QuadSchema), { tSsaoDepth: TextureSpec('texture', 'rgba', 'ubyte', 'nearest'), tColor: TextureSpec('texture', 'rgba', 'ubyte', 'nearest'), tDepth: TextureSpec('texture', 'rgba', 'ubyte', 'nearest'), tOutlines: TextureSpec('texture', 'rgba', 'ubyte', 'nearest'), uTexSize: UniformSpec('v2'), dOrthographic: DefineSpec('number'), uNear: UniformSpec('f'), uFar: UniformSpec('f'), uFogNear: UniformSpec('f'), uFogFar: UniformSpec('f'), uFogColor: UniformSpec('v3'), uOutlineColor: UniformSpec('v3'), uTransparentBackground: UniformSpec('b'), uMaxPossibleViewZDiff: UniformSpec('f'), dOcclusionEnable: DefineSpec('boolean'), dOutlineEnable: DefineSpec('boolean'), dOutlineScale: DefineSpec('number'), uOutlineThreshold: UniformSpec('f') });
|
|
69
69
|
function getPostprocessingRenderable(ctx, colorTexture, depthTexture, outlinesTexture, ssaoDepthTexture) {
|
|
70
|
-
var values = __assign(__assign({}, QuadValues), { tSsaoDepth: ValueCell.create(ssaoDepthTexture), tColor: ValueCell.create(colorTexture), tDepth: ValueCell.create(depthTexture), tOutlines: ValueCell.create(outlinesTexture), uTexSize: ValueCell.create(Vec2.create(colorTexture.getWidth(), colorTexture.getHeight())), dOrthographic: ValueCell.create(0), uNear: ValueCell.create(1), uFar: ValueCell.create(10000), uFogNear: ValueCell.create(10000), uFogFar: ValueCell.create(10000), uFogColor: ValueCell.create(Vec3.create(1, 1, 1)), uOutlineColor: ValueCell.create(Vec3.create(0, 0, 0)), uTransparentBackground: ValueCell.create(false), uMaxPossibleViewZDiff: ValueCell.create(0.5), dOcclusionEnable: ValueCell.create(
|
|
70
|
+
var values = __assign(__assign({}, QuadValues), { tSsaoDepth: ValueCell.create(ssaoDepthTexture), tColor: ValueCell.create(colorTexture), tDepth: ValueCell.create(depthTexture), tOutlines: ValueCell.create(outlinesTexture), uTexSize: ValueCell.create(Vec2.create(colorTexture.getWidth(), colorTexture.getHeight())), dOrthographic: ValueCell.create(0), uNear: ValueCell.create(1), uFar: ValueCell.create(10000), uFogNear: ValueCell.create(10000), uFogFar: ValueCell.create(10000), uFogColor: ValueCell.create(Vec3.create(1, 1, 1)), uOutlineColor: ValueCell.create(Vec3.create(0, 0, 0)), uTransparentBackground: ValueCell.create(false), uMaxPossibleViewZDiff: ValueCell.create(0.5), dOcclusionEnable: ValueCell.create(true), dOutlineEnable: ValueCell.create(false), dOutlineScale: ValueCell.create(1), uOutlineThreshold: ValueCell.create(0.33) });
|
|
71
71
|
var schema = __assign({}, PostprocessingSchema);
|
|
72
72
|
var shaderCode = ShaderCode('postprocessing', quad_vert, postprocessing_frag);
|
|
73
73
|
var renderItem = createComputeRenderItem(ctx, 'triangles', shaderCode, schema, values);
|
|
@@ -135,7 +135,7 @@ function getWeightsRenderable(ctx, edgesTexture) {
|
|
|
135
135
|
var height = edgesTexture.getHeight();
|
|
136
136
|
var areaTexture = createTexture(ctx.gl, ctx.extensions, 'image-uint8', 'rgb', 'ubyte', 'linear');
|
|
137
137
|
var searchTexture = createTexture(ctx.gl, ctx.extensions, 'image-uint8', 'rgba', 'ubyte', 'nearest');
|
|
138
|
-
var values = __assign(__assign({}, QuadValues), { tEdges: ValueCell.create(edgesTexture), tArea: ValueCell.create(areaTexture), tSearch: ValueCell.create(searchTexture), uTexSizeInv: ValueCell.create(Vec2.create(1 / width, 1 / height)), uViewport: ValueCell.create(Vec4()), dMaxSearchSteps: ValueCell.create(
|
|
138
|
+
var values = __assign(__assign({}, QuadValues), { tEdges: ValueCell.create(edgesTexture), tArea: ValueCell.create(areaTexture), tSearch: ValueCell.create(searchTexture), uTexSizeInv: ValueCell.create(Vec2.create(1 / width, 1 / height)), uViewport: ValueCell.create(Vec4()), dMaxSearchSteps: ValueCell.create(16) });
|
|
139
139
|
// Note: loading image textures requires `HTMLImageElement` to be available
|
|
140
140
|
loadImageTexture(getAreaTexture(), values.tArea, areaTexture);
|
|
141
141
|
loadImageTexture(getSearchTexture(), values.tSearch, searchTexture);
|
|
@@ -10,6 +10,7 @@ import { LocationIterator } from '../util/location-iterator';
|
|
|
10
10
|
import { ParamDefinition as PD } from '../../mol-util/param-definition';
|
|
11
11
|
import { TransformData } from './transform-data';
|
|
12
12
|
import { Theme } from '../../mol-theme/theme';
|
|
13
|
+
import { Clip } from '../../mol-util/clip';
|
|
13
14
|
export declare const VisualQualityInfo: {
|
|
14
15
|
custom: {};
|
|
15
16
|
auto: {};
|
|
@@ -48,6 +49,16 @@ export declare namespace BaseGeometry {
|
|
|
48
49
|
roughness: number;
|
|
49
50
|
bumpiness: number;
|
|
50
51
|
}>>;
|
|
52
|
+
clip: PD.Group<PD.Normalize<{
|
|
53
|
+
variant: Clip.Variant;
|
|
54
|
+
objects: PD.Normalize<{
|
|
55
|
+
type: any;
|
|
56
|
+
invert: any;
|
|
57
|
+
position: any;
|
|
58
|
+
rotation: any;
|
|
59
|
+
scale: any;
|
|
60
|
+
}>[];
|
|
61
|
+
}>>;
|
|
51
62
|
};
|
|
52
63
|
type Params = typeof Params;
|
|
53
64
|
type Counts = {
|
|
@@ -71,6 +82,13 @@ export declare namespace BaseGeometry {
|
|
|
71
82
|
uRoughness: ValueCell<number, never>;
|
|
72
83
|
uBumpiness: ValueCell<number, never>;
|
|
73
84
|
dLightCount: ValueCell<number, never>;
|
|
85
|
+
dClipObjectCount: ValueCell<number, never>;
|
|
86
|
+
dClipVariant: ValueCell<Clip.Variant, never>;
|
|
87
|
+
uClipObjectType: ValueCell<number[], never>;
|
|
88
|
+
uClipObjectInvert: ValueCell<boolean[], never>;
|
|
89
|
+
uClipObjectPosition: ValueCell<number[], never>;
|
|
90
|
+
uClipObjectRotation: ValueCell<number[], never>;
|
|
91
|
+
uClipObjectScale: ValueCell<number[], never>;
|
|
74
92
|
};
|
|
75
93
|
function updateValues(values: BaseValues, props: PD.Values<Params>): void;
|
|
76
94
|
function createRenderableState(props?: Partial<PD.Values<Params>>): RenderableState;
|
|
@@ -13,6 +13,7 @@ import { UniformColorTheme } from '../../mol-theme/color/uniform';
|
|
|
13
13
|
import { UniformSizeTheme } from '../../mol-theme/size/uniform';
|
|
14
14
|
import { smoothstep } from '../../mol-math/interpolate';
|
|
15
15
|
import { Material } from '../../mol-util/material';
|
|
16
|
+
import { Clip } from '../../mol-util/clip';
|
|
16
17
|
export var VisualQualityInfo = {
|
|
17
18
|
'custom': {},
|
|
18
19
|
'auto': {},
|
|
@@ -71,6 +72,7 @@ export var BaseGeometry;
|
|
|
71
72
|
alpha: PD.Numeric(1, { min: 0, max: 1, step: 0.01 }, { label: 'Opacity', isEssential: true, description: 'How opaque/transparent the representation is rendered.' }),
|
|
72
73
|
quality: PD.Select('auto', VisualQualityOptions, { isEssential: true, description: 'Visual/rendering quality of the representation.' }),
|
|
73
74
|
material: Material.getParam(),
|
|
75
|
+
clip: PD.Group(Clip.Params),
|
|
74
76
|
};
|
|
75
77
|
function createSimple(colorValue, sizeValue, transform) {
|
|
76
78
|
if (colorValue === void 0) { colorValue = ColorNames.grey; }
|
|
@@ -86,6 +88,7 @@ export var BaseGeometry;
|
|
|
86
88
|
}
|
|
87
89
|
BaseGeometry.createSimple = createSimple;
|
|
88
90
|
function createValues(props, counts) {
|
|
91
|
+
var clip = Clip.getClip(props.clip);
|
|
89
92
|
return {
|
|
90
93
|
alpha: ValueCell.create(props.alpha),
|
|
91
94
|
uAlpha: ValueCell.create(props.alpha),
|
|
@@ -96,6 +99,13 @@ export var BaseGeometry;
|
|
|
96
99
|
uRoughness: ValueCell.create(props.material.roughness),
|
|
97
100
|
uBumpiness: ValueCell.create(props.material.bumpiness),
|
|
98
101
|
dLightCount: ValueCell.create(1),
|
|
102
|
+
dClipObjectCount: ValueCell.create(clip.objects.count),
|
|
103
|
+
dClipVariant: ValueCell.create(clip.variant),
|
|
104
|
+
uClipObjectType: ValueCell.create(clip.objects.type),
|
|
105
|
+
uClipObjectInvert: ValueCell.create(clip.objects.invert),
|
|
106
|
+
uClipObjectPosition: ValueCell.create(clip.objects.position),
|
|
107
|
+
uClipObjectRotation: ValueCell.create(clip.objects.rotation),
|
|
108
|
+
uClipObjectScale: ValueCell.create(clip.objects.scale),
|
|
99
109
|
};
|
|
100
110
|
}
|
|
101
111
|
BaseGeometry.createValues = createValues;
|
|
@@ -104,6 +114,14 @@ export var BaseGeometry;
|
|
|
104
114
|
ValueCell.updateIfChanged(values.uMetalness, props.material.metalness);
|
|
105
115
|
ValueCell.updateIfChanged(values.uRoughness, props.material.roughness);
|
|
106
116
|
ValueCell.updateIfChanged(values.uBumpiness, props.material.bumpiness);
|
|
117
|
+
var clip = Clip.getClip(props.clip);
|
|
118
|
+
ValueCell.update(values.dClipObjectCount, clip.objects.count);
|
|
119
|
+
ValueCell.update(values.dClipVariant, clip.variant);
|
|
120
|
+
ValueCell.update(values.uClipObjectType, clip.objects.type);
|
|
121
|
+
ValueCell.update(values.uClipObjectInvert, clip.objects.invert);
|
|
122
|
+
ValueCell.update(values.uClipObjectPosition, clip.objects.position);
|
|
123
|
+
ValueCell.update(values.uClipObjectRotation, clip.objects.rotation);
|
|
124
|
+
ValueCell.update(values.uClipObjectScale, clip.objects.scale);
|
|
107
125
|
}
|
|
108
126
|
BaseGeometry.updateValues = updateValues;
|
|
109
127
|
function createRenderableState(props) {
|
|
@@ -117,7 +135,6 @@ export var BaseGeometry;
|
|
|
117
135
|
colorOnly: false,
|
|
118
136
|
opaque: opaque,
|
|
119
137
|
writeDepth: opaque,
|
|
120
|
-
noClip: false,
|
|
121
138
|
};
|
|
122
139
|
}
|
|
123
140
|
BaseGeometry.createRenderableState = createRenderableState;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright (c) 2020 mol* contributors, licensed under MIT, See LICENSE file for more info.
|
|
2
|
+
* Copyright (c) 2020-2021 mol* contributors, licensed under MIT, See LICENSE file for more info.
|
|
3
3
|
*
|
|
4
4
|
* @author Alexander Rose <alexander.rose@weirdbyte.de>
|
|
5
5
|
*/
|
|
@@ -8,8 +8,6 @@ import { Vec2 } from '../../mol-math/linear-algebra';
|
|
|
8
8
|
import { TextureImage } from '../../mol-gl/renderable/util';
|
|
9
9
|
import { Clipping } from '../../mol-theme/clipping';
|
|
10
10
|
export declare type ClippingData = {
|
|
11
|
-
dClipObjectCount: ValueCell<number>;
|
|
12
|
-
dClipVariant: ValueCell<string>;
|
|
13
11
|
tClipping: ValueCell<TextureImage<Uint8Array>>;
|
|
14
12
|
uClippingTexDim: ValueCell<Vec2>;
|
|
15
13
|
dClipping: ValueCell<boolean>;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright (c) 2020 mol* contributors, licensed under MIT, See LICENSE file for more info.
|
|
2
|
+
* Copyright (c) 2020-2021 mol* contributors, licensed under MIT, See LICENSE file for more info.
|
|
3
3
|
*
|
|
4
4
|
* @author Alexander Rose <alexander.rose@weirdbyte.de>
|
|
5
5
|
*/
|
|
@@ -7,9 +7,7 @@ import { ValueCell } from '../../mol-util/value-cell';
|
|
|
7
7
|
import { Vec2 } from '../../mol-math/linear-algebra';
|
|
8
8
|
import { createTextureImage } from '../../mol-gl/renderable/util';
|
|
9
9
|
export function applyClippingGroups(array, start, end, groups) {
|
|
10
|
-
|
|
11
|
-
array[i] = groups;
|
|
12
|
-
}
|
|
10
|
+
array.fill(groups, start, end);
|
|
13
11
|
return true;
|
|
14
12
|
}
|
|
15
13
|
export function clearClipping(array, start, end) {
|
|
@@ -25,8 +23,6 @@ export function createClipping(count, clippingData) {
|
|
|
25
23
|
}
|
|
26
24
|
else {
|
|
27
25
|
return {
|
|
28
|
-
dClipObjectCount: ValueCell.create(0),
|
|
29
|
-
dClipVariant: ValueCell.create('instance'),
|
|
30
26
|
tClipping: ValueCell.create(clipping),
|
|
31
27
|
uClippingTexDim: ValueCell.create(Vec2.create(clipping.width, clipping.height)),
|
|
32
28
|
dClipping: ValueCell.create(count > 0),
|
|
@@ -38,12 +34,11 @@ export function createEmptyClipping(clippingData) {
|
|
|
38
34
|
if (clippingData) {
|
|
39
35
|
ValueCell.update(clippingData.tClipping, emptyClippingTexture);
|
|
40
36
|
ValueCell.update(clippingData.uClippingTexDim, Vec2.create(1, 1));
|
|
37
|
+
ValueCell.updateIfChanged(clippingData.dClipping, false);
|
|
41
38
|
return clippingData;
|
|
42
39
|
}
|
|
43
40
|
else {
|
|
44
41
|
return {
|
|
45
|
-
dClipObjectCount: ValueCell.create(0),
|
|
46
|
-
dClipVariant: ValueCell.create('instance'),
|
|
47
42
|
tClipping: ValueCell.create(emptyClippingTexture),
|
|
48
43
|
uClippingTexDim: ValueCell.create(Vec2.create(1, 1)),
|
|
49
44
|
dClipping: ValueCell.create(false),
|
|
@@ -11,7 +11,7 @@ import { Vec2, Vec3, Vec4 } from '../../mol-math/linear-algebra';
|
|
|
11
11
|
import { LocationIterator } from '../util/location-iterator';
|
|
12
12
|
import { ColorTheme } from '../../mol-theme/color';
|
|
13
13
|
import { Texture } from '../../mol-gl/webgl/texture';
|
|
14
|
-
export declare type ColorType = 'uniform' | 'instance' | 'group' | 'groupInstance' | 'vertex' | 'vertexInstance' | 'volume' | 'volumeInstance';
|
|
14
|
+
export declare type ColorType = 'uniform' | 'instance' | 'group' | 'groupInstance' | 'vertex' | 'vertexInstance' | 'volume' | 'volumeInstance' | 'direct';
|
|
15
15
|
export declare type ColorData = {
|
|
16
16
|
uColor: ValueCell<Vec3>;
|
|
17
17
|
tColor: ValueCell<TextureImage<Uint8Array>>;
|