ellipsoid.ts 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. /**
  2. * Copyright (c) 2019 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  5. */
  6. import { ParamDefinition as PD } from '../../../mol-util/param-definition';
  7. import { RepresentationParamsGetter, RepresentationContext, Representation } from '../../../mol-repr/representation';
  8. import { ThemeRegistryContext } from '../../../mol-theme/theme';
  9. import { Structure } from '../../../mol-model/structure';
  10. import { UnitsRepresentation, StructureRepresentation, StructureRepresentationStateBuilder, StructureRepresentationProvider, ComplexRepresentation } from '../../../mol-repr/structure/representation';
  11. import { EllipsoidMeshParams, EllipsoidMeshVisual } from '../visual/ellipsoid-mesh';
  12. import { UnitKind, UnitKindOptions } from '../../../mol-repr/structure/visual/util/common';
  13. import { AtomSiteAnisotrop } from '../../../mol-model-formats/structure/mmcif/anisotropic';
  14. import { IntraUnitBondParams, IntraUnitBondVisual } from '../visual/bond-intra-unit-cylinder';
  15. import { InterUnitBondParams, InterUnitBondVisual } from '../visual/bond-inter-unit-cylinder';
  16. const EllipsoidVisuals = {
  17. 'ellipsoid-mesh': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, EllipsoidMeshParams>) => UnitsRepresentation('Ellipsoid Mesh', ctx, getParams, EllipsoidMeshVisual),
  18. 'intra-bond': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, IntraUnitBondParams>) => UnitsRepresentation('Intra-unit bond cylinder', ctx, getParams, IntraUnitBondVisual),
  19. 'inter-bond': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, InterUnitBondParams>) => ComplexRepresentation('Inter-unit bond cylinder', ctx, getParams, InterUnitBondVisual),
  20. }
  21. export const EllipsoidParams = {
  22. ...EllipsoidMeshParams,
  23. ...IntraUnitBondParams,
  24. ...InterUnitBondParams,
  25. unitKinds: PD.MultiSelect<UnitKind>(['atomic'], UnitKindOptions),
  26. sizeFactor: PD.Numeric(1, { min: 0.01, max: 10, step: 0.01 }),
  27. sizeAspectRatio: PD.Numeric(0.1, { min: 0.01, max: 3, step: 0.01 }),
  28. bondCap: PD.Boolean(true),
  29. visuals: PD.MultiSelect(['ellipsoid-mesh', 'intra-bond', 'inter-bond'], PD.objectToOptions(EllipsoidVisuals)),
  30. }
  31. export type EllipsoidParams = typeof EllipsoidParams
  32. export function getEllipsoidParams(ctx: ThemeRegistryContext, structure: Structure) {
  33. return PD.clone(EllipsoidParams)
  34. }
  35. export type EllipsoidRepresentation = StructureRepresentation<EllipsoidParams>
  36. export function EllipsoidRepresentation(ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, EllipsoidParams>): EllipsoidRepresentation {
  37. return Representation.createMulti('Ellipsoid', ctx, getParams, StructureRepresentationStateBuilder, EllipsoidVisuals as unknown as Representation.Def<Structure, EllipsoidParams>)
  38. }
  39. export const EllipsoidRepresentationProvider: StructureRepresentationProvider<EllipsoidParams> = {
  40. label: 'Ellipsoid',
  41. description: 'Displays anisotropic displacement ellipsoids of atomic elements plus bonds as cylinders.',
  42. factory: EllipsoidRepresentation,
  43. getParams: getEllipsoidParams,
  44. defaultValues: PD.getDefaultValues(EllipsoidParams),
  45. defaultColorTheme: 'element-symbol',
  46. defaultSizeTheme: 'uniform',
  47. isApplicable: (structure: Structure) => structure.elementCount > 0 && structure.models.some(m => m.customProperties.has(AtomSiteAnisotrop.Descriptor))
  48. }