molecular-surface.ts 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. /**
  2. * Copyright (c) 2018 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  5. */
  6. import { GaussianSurfaceVisual, GaussianSurfaceParams } 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 { GaussianDensityVolumeParams, GaussianDensityVolumeVisual } from '../visual/gaussian-density-volume';
  11. import { StructureRepresentation, StructureRepresentationProvider } from '../representation';
  12. import { Representation, RepresentationParamsGetter, RepresentationContext } from 'mol-repr/representation';
  13. import { ThemeRegistryContext } from 'mol-theme/theme';
  14. import { Structure } from 'mol-model/structure';
  15. import { BuiltInColorThemeOptions, getBuiltInColorThemeParams } from 'mol-theme/color';
  16. const MolecularSurfaceVisuals = {
  17. 'gaussian-surface': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, GaussianSurfaceParams>) => UnitsRepresentation('Gaussian surface', ctx, getParams, GaussianSurfaceVisual),
  18. 'gaussian-wireframe': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, GaussianWireframeParams>) => UnitsRepresentation('Gaussian wireframe', ctx, getParams, GaussianWireframeVisual),
  19. 'gaussian-volume': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, GaussianDensityVolumeParams>) => UnitsRepresentation('Gaussian volume', ctx, getParams, GaussianDensityVolumeVisual)
  20. }
  21. type MolecularSurfaceVisualName = keyof typeof MolecularSurfaceVisuals
  22. const MolecularSurfaceVisualOptions = Object.keys(MolecularSurfaceVisuals).map(name => [name, name] as [MolecularSurfaceVisualName, string])
  23. export const MolecularSurfaceParams = {
  24. ...GaussianSurfaceParams,
  25. ...GaussianWireframeParams,
  26. ...GaussianDensityVolumeParams,
  27. colorTheme: PD.Mapped('polymer-id', BuiltInColorThemeOptions, getBuiltInColorThemeParams),
  28. visuals: PD.MultiSelect<MolecularSurfaceVisualName>(['gaussian-surface'], MolecularSurfaceVisualOptions),
  29. }
  30. PD.getDefaultValues(MolecularSurfaceParams).colorTheme.name
  31. export type MolecularSurfaceParams = typeof MolecularSurfaceParams
  32. export function getMolecularSurfaceParams(ctx: ThemeRegistryContext, structure: Structure) {
  33. return PD.clone(MolecularSurfaceParams)
  34. }
  35. export type MolecularSurfaceRepresentation = StructureRepresentation<MolecularSurfaceParams>
  36. export function MolecularSurfaceRepresentation(ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, MolecularSurfaceParams>): MolecularSurfaceRepresentation {
  37. return Representation.createMulti('Molecular Surface', ctx, getParams, MolecularSurfaceVisuals as unknown as Representation.Def<Structure, MolecularSurfaceParams>)
  38. }
  39. export const MolecularSurfaceRepresentationProvider: StructureRepresentationProvider<MolecularSurfaceParams> = {
  40. label: 'Molecular Surface',
  41. description: 'Displays a gaussian molecular surface.',
  42. factory: MolecularSurfaceRepresentation,
  43. getParams: getMolecularSurfaceParams,
  44. defaultValues: PD.getDefaultValues(MolecularSurfaceParams)
  45. }