gaussian-surface.ts 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /**
  2. * Copyright (c) 2018-2019 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  5. */
  6. import { GaussianSurfaceMeshVisual, GaussianSurfaceTextureMeshVisual, GaussianSurfaceMeshParams, StructureGaussianSurfaceMeshParams, StructureGaussianSurfaceMeshVisual } from '../visual/gaussian-surface-mesh';
  7. import { UnitsRepresentation } from '../units-representation';
  8. import { GaussianWireframeVisual, GaussianWireframeParams } from '../visual/gaussian-surface-wireframe';
  9. import { ParamDefinition as PD } from '../../../mol-util/param-definition';
  10. import { StructureRepresentation, StructureRepresentationProvider, StructureRepresentationStateBuilder, ComplexRepresentation } from '../representation';
  11. import { Representation, RepresentationParamsGetter, RepresentationContext } from '../../../mol-repr/representation';
  12. import { ThemeRegistryContext } from '../../../mol-theme/theme';
  13. import { Structure } from '../../../mol-model/structure';
  14. const GaussianSurfaceVisuals = {
  15. 'gaussian-surface-mesh': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, GaussianSurfaceMeshParams>) => UnitsRepresentation('Gaussian surface mesh', ctx, getParams, GaussianSurfaceMeshVisual),
  16. 'structure-gaussian-surface-mesh': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, StructureGaussianSurfaceMeshParams>) => ComplexRepresentation('Structure-Gaussian surface mesh', ctx, getParams, StructureGaussianSurfaceMeshVisual),
  17. 'gaussian-surface-texture-mesh': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, GaussianSurfaceMeshParams>) => UnitsRepresentation('Gaussian surface texture-mesh', ctx, getParams, GaussianSurfaceTextureMeshVisual),
  18. 'gaussian-surface-wireframe': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, GaussianWireframeParams>) => UnitsRepresentation('Gaussian surface wireframe', ctx, getParams, GaussianWireframeVisual),
  19. }
  20. export const GaussianSurfaceParams = {
  21. ...GaussianSurfaceMeshParams,
  22. ...GaussianWireframeParams,
  23. visuals: PD.MultiSelect(['gaussian-surface-mesh'], PD.objectToOptions(GaussianSurfaceVisuals)),
  24. }
  25. export type GaussianSurfaceParams = typeof GaussianSurfaceParams
  26. export function getGaussianSurfaceParams(ctx: ThemeRegistryContext, structure: Structure) {
  27. return PD.clone(GaussianSurfaceParams)
  28. }
  29. export type GaussianSurfaceRepresentation = StructureRepresentation<GaussianSurfaceParams>
  30. export function GaussianSurfaceRepresentation(ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, GaussianSurfaceParams>): GaussianSurfaceRepresentation {
  31. return Representation.createMulti('Gaussian Surface', ctx, getParams, StructureRepresentationStateBuilder, GaussianSurfaceVisuals as unknown as Representation.Def<Structure, GaussianSurfaceParams>)
  32. }
  33. export const GaussianSurfaceRepresentationProvider = StructureRepresentationProvider({
  34. name: 'gaussian-surface',
  35. label: 'Gaussian Surface',
  36. description: 'Displays a gaussian molecular surface.',
  37. factory: GaussianSurfaceRepresentation,
  38. getParams: getGaussianSurfaceParams,
  39. defaultValues: PD.getDefaultValues(GaussianSurfaceParams),
  40. defaultColorTheme: { name: 'polymer-id' },
  41. defaultSizeTheme: { name: 'uniform' },
  42. isApplicable: (structure: Structure) => structure.elementCount > 0
  43. })