|
@@ -8,22 +8,34 @@ import { ParamDefinition as PD } from '../../../mol-util/param-definition';
|
|
|
import { RepresentationParamsGetter, RepresentationContext, Representation } from '../../../mol-repr/representation';
|
|
|
import { ThemeRegistryContext } from '../../../mol-theme/theme';
|
|
|
import { Structure } from '../../../mol-model/structure';
|
|
|
-import { UnitsRepresentation, StructureRepresentation, StructureRepresentationStateBuilder, StructureRepresentationProvider } from '../../../mol-repr/structure/representation';
|
|
|
+import { UnitsRepresentation, StructureRepresentation, StructureRepresentationStateBuilder, StructureRepresentationProvider, ComplexRepresentation } from '../../../mol-repr/structure/representation';
|
|
|
import { EllipsoidMeshParams, EllipsoidMeshVisual } from '../visual/ellipsoid-mesh';
|
|
|
import { UnitKind, UnitKindOptions } from '../../../mol-repr/structure/visual/util/common';
|
|
|
import { AtomSiteAnisotrop } from '../../../mol-model-formats/structure/mmcif/anisotropic';
|
|
|
+import { IntraUnitLinkParams, IntraUnitLinkVisual } from '../visual/intra-unit-link-cylinder';
|
|
|
+import { InterUnitLinkParams, InterUnitLinkVisual } from '../visual/inter-unit-link-cylinder';
|
|
|
|
|
|
const EllipsoidVisuals = {
|
|
|
- 'ellipsoid-mesh': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, EllipsoidParams>) => UnitsRepresentation('Ellipsoid Mesh', ctx, getParams, EllipsoidMeshVisual),
|
|
|
+ 'ellipsoid-mesh': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, EllipsoidMeshParams>) => UnitsRepresentation('Ellipsoid Mesh', ctx, getParams, EllipsoidMeshVisual),
|
|
|
+ 'intra-link': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, IntraUnitLinkParams>) => UnitsRepresentation('Intra-unit link cylinder', ctx, getParams, IntraUnitLinkVisual),
|
|
|
+ 'inter-link': (ctx: RepresentationContext, getParams: RepresentationParamsGetter<Structure, InterUnitLinkParams>) => ComplexRepresentation('Inter-unit link cylinder', ctx, getParams, InterUnitLinkVisual),
|
|
|
}
|
|
|
+type EllipsoidVisualName = keyof typeof EllipsoidVisuals
|
|
|
+const EllipsoidVisualOptions = Object.keys(EllipsoidVisuals).map(name => [name, name] as [EllipsoidVisualName, string])
|
|
|
|
|
|
export const EllipsoidParams = {
|
|
|
...EllipsoidMeshParams,
|
|
|
+ ...IntraUnitLinkParams,
|
|
|
+ ...InterUnitLinkParams,
|
|
|
unitKinds: PD.MultiSelect<UnitKind>(['atomic'], UnitKindOptions),
|
|
|
+ sizeFactor: PD.Numeric(1, { min: 0.01, max: 10, step: 0.01 }),
|
|
|
+ sizeAspectRatio: PD.Numeric(0.1, { min: 0.01, max: 3, step: 0.01 }),
|
|
|
+ linkCap: PD.Boolean(true),
|
|
|
+ visuals: PD.MultiSelect<EllipsoidVisualName>(['ellipsoid-mesh', 'intra-link', 'inter-link'], EllipsoidVisualOptions),
|
|
|
}
|
|
|
-export type EllipsoidParams = typeof EllipsoidMeshParams
|
|
|
+export type EllipsoidParams = typeof EllipsoidParams
|
|
|
export function getEllipsoidParams(ctx: ThemeRegistryContext, structure: Structure) {
|
|
|
- return PD.clone(EllipsoidMeshParams)
|
|
|
+ return PD.clone(EllipsoidParams)
|
|
|
}
|
|
|
|
|
|
export type EllipsoidRepresentation = StructureRepresentation<EllipsoidParams>
|
|
@@ -33,10 +45,10 @@ export function EllipsoidRepresentation(ctx: RepresentationContext, getParams: R
|
|
|
|
|
|
export const EllipsoidRepresentationProvider: StructureRepresentationProvider<EllipsoidParams> = {
|
|
|
label: 'Ellipsoid',
|
|
|
- description: 'Displays anisotropic displacement ellipsoids of atomic elements.',
|
|
|
+ description: 'Displays anisotropic displacement ellipsoids of atomic elements plus bonds as cylinders.',
|
|
|
factory: EllipsoidRepresentation,
|
|
|
getParams: getEllipsoidParams,
|
|
|
- defaultValues: PD.getDefaultValues(EllipsoidMeshParams),
|
|
|
+ defaultValues: PD.getDefaultValues(EllipsoidParams),
|
|
|
defaultColorTheme: 'element-symbol',
|
|
|
defaultSizeTheme: 'uniform',
|
|
|
isApplicable: (structure: Structure) => structure.elementCount > 0 && structure.models.some(m => m.customProperties.has(AtomSiteAnisotrop.Descriptor))
|