diff --git a/src/mol-geo/representation/index.ts b/src/mol-geo/representation/index.ts index f1d6355511aed3a5a2d281e9bc0f7e261bd1687d..90ac94490bdfeb28ba54360b9035b28ea27739ee 100644 --- a/src/mol-geo/representation/index.ts +++ b/src/mol-geo/representation/index.ts @@ -13,6 +13,7 @@ import { MarkerAction } from '../util/marker-data'; export interface RepresentationProps {} export interface Representation<D, P extends RepresentationProps = {}> { + readonly label: string readonly renderObjects: ReadonlyArray<RenderObject> readonly props: Readonly<P> createOrUpdate: (props?: Partial<P>, data?: D) => Task<void> diff --git a/src/mol-geo/representation/shape/index.ts b/src/mol-geo/representation/shape/index.ts index 3f5c408767ac3fafab8a09f45395757a61b71074..52ee7ebc4726535028204dfa6eb214ec24bce54c 100644 --- a/src/mol-geo/representation/shape/index.ts +++ b/src/mol-geo/representation/shape/index.ts @@ -73,6 +73,7 @@ export function ShapeRepresentation<P extends ShapeProps>(): ShapeRepresentation } return { + label: 'Shape mesh', get renderObjects () { return renderObjects }, get props () { return _props }, createOrUpdate, diff --git a/src/mol-geo/representation/structure/complex-representation.ts b/src/mol-geo/representation/structure/complex-representation.ts index ed9a0b1f333879d434e6fc0f24597dd00bb42f8e..6053df8f3ee85b4cd62fdbc2066330c838496741 100644 --- a/src/mol-geo/representation/structure/complex-representation.ts +++ b/src/mol-geo/representation/structure/complex-representation.ts @@ -14,7 +14,7 @@ import { getQualityProps } from '../util'; import { StructureProps, DefaultStructureProps, StructureRepresentation } from '.'; import { ComplexVisual } from './complex-visual'; -export function ComplexRepresentation<P extends StructureProps>(visualCtor: () => ComplexVisual<P>): StructureRepresentation<P> { +export function ComplexRepresentation<P extends StructureProps>(label: string, visualCtor: () => ComplexVisual<P>): StructureRepresentation<P> { let visual: ComplexVisual<P> | undefined let _props: P @@ -41,6 +41,7 @@ export function ComplexRepresentation<P extends StructureProps>(visualCtor: () = } return { + label, get renderObjects() { return visual && visual.renderObject ? [ visual.renderObject ] : [] }, diff --git a/src/mol-geo/representation/structure/representation/backbone.ts b/src/mol-geo/representation/structure/representation/backbone.ts index a76e239a5f23efc4b3109bca0c0c8b324f483a05..cb6c6f9d54cce679ab98ab76b7ee311d651c8528 100644 --- a/src/mol-geo/representation/structure/representation/backbone.ts +++ b/src/mol-geo/representation/structure/representation/backbone.ts @@ -20,10 +20,11 @@ export type BackboneProps = typeof DefaultBackboneProps export type BackboneRepresentation = StructureRepresentation<BackboneProps> export function BackboneRepresentation(): BackboneRepresentation { - const traceRepr = UnitsRepresentation(PolymerBackboneVisual) + const traceRepr = UnitsRepresentation('Polymer backbone cylinder', PolymerBackboneVisual) let currentProps: BackboneProps return { + label: 'Backbone', get renderObjects() { return [ ...traceRepr.renderObjects ] }, diff --git a/src/mol-geo/representation/structure/representation/ball-and-stick.ts b/src/mol-geo/representation/structure/representation/ball-and-stick.ts index 3c236ede10c615ef036a3e6aa57ca148a0c57ad4..2c4bbceca2587dd2ae057ab59c7e6f66219ce844 100644 --- a/src/mol-geo/representation/structure/representation/ball-and-stick.ts +++ b/src/mol-geo/representation/structure/representation/ball-and-stick.ts @@ -19,7 +19,7 @@ export const DefaultBallAndStickProps = { ...DefaultElementSphereProps, ...DefaultIntraUnitLinkProps, - sizeTheme: { name: 'uniform', value: 0.25 } as SizeThemeProps, + sizeTheme: { name: 'uniform', value: 0.2 } as SizeThemeProps, unitKinds: [ Unit.Kind.Atomic ] as Unit.Kind[] } export type BallAndStickProps = typeof DefaultBallAndStickProps @@ -27,12 +27,13 @@ export type BallAndStickProps = typeof DefaultBallAndStickProps export type BallAndStickRepresentation = StructureRepresentation<BallAndStickProps> export function BallAndStickRepresentation(): BallAndStickRepresentation { - const elmementRepr = UnitsRepresentation(ElementSphereVisual) - const intraLinkRepr = UnitsRepresentation(IntraUnitLinkVisual) - const interLinkRepr = ComplexRepresentation(InterUnitLinkVisual) + const elmementRepr = UnitsRepresentation('Element sphere mesh', ElementSphereVisual) + const intraLinkRepr = UnitsRepresentation('Intra-unit link cylinder', IntraUnitLinkVisual) + const interLinkRepr = ComplexRepresentation('Inter-unit link cylinder', InterUnitLinkVisual) let currentProps: BallAndStickProps return { + label: 'Ball & Stick', get renderObjects() { return [ ...elmementRepr.renderObjects, ...intraLinkRepr.renderObjects, ...interLinkRepr.renderObjects ] }, diff --git a/src/mol-geo/representation/structure/representation/carbohydrate.ts b/src/mol-geo/representation/structure/representation/carbohydrate.ts index 6a01069b4a6923d5a37322b48c60135a63efe1cb..1c5dc29226b18d543a4d354b0242010652882fad 100644 --- a/src/mol-geo/representation/structure/representation/carbohydrate.ts +++ b/src/mol-geo/representation/structure/representation/carbohydrate.ts @@ -12,21 +12,25 @@ import { Loci, isEmptyLoci } from 'mol-model/loci'; import { MarkerAction } from '../../../util/marker-data'; import { CarbohydrateSymbolVisual, DefaultCarbohydrateSymbolProps } from '../visual/carbohydrate-symbol-mesh'; import { CarbohydrateLinkVisual, DefaultCarbohydrateLinkProps } from '../visual/carbohydrate-link-cylinder'; +import { SizeThemeProps } from 'mol-view/theme/size'; export const DefaultCartoonProps = { ...DefaultCarbohydrateSymbolProps, - ...DefaultCarbohydrateLinkProps + ...DefaultCarbohydrateLinkProps, + + sizeTheme: { name: 'uniform', value: 1, factor: 1 } as SizeThemeProps, } export type CarbohydrateProps = typeof DefaultCartoonProps export type CarbohydrateRepresentation = StructureRepresentation<CarbohydrateProps> export function CarbohydrateRepresentation(): CarbohydrateRepresentation { - const carbohydrateSymbolRepr = ComplexRepresentation(CarbohydrateSymbolVisual) - const carbohydrateLinkRepr = ComplexRepresentation(CarbohydrateLinkVisual) + const carbohydrateSymbolRepr = ComplexRepresentation('Carbohydrate symbol mesh', CarbohydrateSymbolVisual) + const carbohydrateLinkRepr = ComplexRepresentation('Carbohydrate link cylinder', CarbohydrateLinkVisual) let currentProps: CarbohydrateProps return { + label: 'Carbohydrate', get renderObjects() { return [ ...carbohydrateSymbolRepr.renderObjects, ...carbohydrateLinkRepr.renderObjects ] }, diff --git a/src/mol-geo/representation/structure/representation/cartoon.ts b/src/mol-geo/representation/structure/representation/cartoon.ts index ca40d4ee8c0a3ce18811984c9f57f4a994d64485..9f503a09281ca30c30c706fa7bb5762c6956219f 100644 --- a/src/mol-geo/representation/structure/representation/cartoon.ts +++ b/src/mol-geo/representation/structure/representation/cartoon.ts @@ -13,26 +13,30 @@ import { MarkerAction } from '../../../util/marker-data'; import { PolymerTraceVisual, DefaultPolymerTraceProps } from '../visual/polymer-trace-mesh'; import { PolymerGapVisual, DefaultPolymerGapProps } from '../visual/polymer-gap-cylinder'; import { NucleotideBlockVisual, DefaultNucleotideBlockProps } from '../visual/nucleotide-block-mesh'; -import { /* PolymerDirectionVisual, */ DefaultPolymerDirectionProps } from '../visual/polymer-direction-wedge'; +import { SizeThemeProps } from 'mol-view/theme/size'; +// import { PolymerDirectionVisual, DefaultPolymerDirectionProps } from '../visual/polymer-direction-wedge'; export const DefaultCartoonProps = { ...DefaultPolymerTraceProps, ...DefaultPolymerGapProps, ...DefaultNucleotideBlockProps, - ...DefaultPolymerDirectionProps + // ...DefaultPolymerDirectionProps, + + sizeTheme: { name: 'uniform', value: 0.2 } as SizeThemeProps, } export type CartoonProps = typeof DefaultCartoonProps export type CartoonRepresentation = StructureRepresentation<CartoonProps> export function CartoonRepresentation(): CartoonRepresentation { - const traceRepr = UnitsRepresentation(PolymerTraceVisual) - const gapRepr = UnitsRepresentation(PolymerGapVisual) - const blockRepr = UnitsRepresentation(NucleotideBlockVisual) - // const directionRepr = UnitsRepresentation(PolymerDirectionVisual) + const traceRepr = UnitsRepresentation('Polymer trace mesh', PolymerTraceVisual) + const gapRepr = UnitsRepresentation('Polymer gap cylinder', PolymerGapVisual) + const blockRepr = UnitsRepresentation('Nucleotide block mesh', NucleotideBlockVisual) + // const directionRepr = UnitsRepresentation('Polymer direction wedge', PolymerDirectionVisual) let currentProps: CartoonProps return { + label: 'Cartoon', get renderObjects() { return [ ...traceRepr.renderObjects, ...gapRepr.renderObjects, ...blockRepr.renderObjects // , ...directionRepr.renderObjects diff --git a/src/mol-geo/representation/structure/representation/distance-restraint.ts b/src/mol-geo/representation/structure/representation/distance-restraint.ts index 47a340e9a63a584c7400db6186f8d6ba83bd3c61..2c61a224eb91cdd382f7ed90543be87b5c60813a 100644 --- a/src/mol-geo/representation/structure/representation/distance-restraint.ts +++ b/src/mol-geo/representation/structure/representation/distance-restraint.ts @@ -22,10 +22,11 @@ export type DistanceRestraintProps = typeof DefaultDistanceRestraintProps export type DistanceRestraintRepresentation = StructureRepresentation<DistanceRestraintProps> export function DistanceRestraintRepresentation(): DistanceRestraintRepresentation { - const crossLinkRepr = ComplexRepresentation(CrossLinkRestraintVisual) + const crossLinkRepr = ComplexRepresentation('Cross-link restraint', CrossLinkRestraintVisual) let currentProps: DistanceRestraintProps return { + label: 'Distance restraint', get renderObjects() { return [ ...crossLinkRepr.renderObjects ] }, diff --git a/src/mol-geo/representation/structure/representation/point.ts b/src/mol-geo/representation/structure/representation/point.ts index 6ea64af0e5799f0da73205ca329b9505a5548bd2..892ffa0c2bb51bc88ca54c052351a42ccac8654e 100644 --- a/src/mol-geo/representation/structure/representation/point.ts +++ b/src/mol-geo/representation/structure/representation/point.ts @@ -7,14 +7,17 @@ import { UnitsRepresentation } from '..'; import { ElementPointVisual, DefaultElementPointProps } from '../visual/element-point'; import { StructureRepresentation } from '../units-representation'; +import { SizeThemeProps } from 'mol-view/theme/size'; export const DefaultPointProps = { ...DefaultElementPointProps, + + sizeTheme: { name: 'uniform', value: 0.2 } as SizeThemeProps, } export type PointProps = typeof DefaultPointProps export type PointRepresentation = StructureRepresentation<PointProps> export function PointRepresentation(): PointRepresentation { - return UnitsRepresentation(ElementPointVisual) + return UnitsRepresentation('Point', ElementPointVisual) } \ No newline at end of file diff --git a/src/mol-geo/representation/structure/representation/spacefill.ts b/src/mol-geo/representation/structure/representation/spacefill.ts index fb18a901a88137ad88fc526bfa03b01325125a17..ede5bb1b74e335e7f4667299e505b17ffccfeab7 100644 --- a/src/mol-geo/representation/structure/representation/spacefill.ts +++ b/src/mol-geo/representation/structure/representation/spacefill.ts @@ -16,5 +16,5 @@ export type SpacefillProps = typeof DefaultSpacefillProps export type SpacefillRepresentation = StructureRepresentation<SpacefillProps> export function SpacefillRepresentation(): SpacefillRepresentation { - return UnitsRepresentation(ElementSphereVisual) + return UnitsRepresentation('Spacefill', ElementSphereVisual) } \ No newline at end of file diff --git a/src/mol-geo/representation/structure/visual/element-point.ts b/src/mol-geo/representation/structure/visual/element-point.ts index b244c830c2e31b8255471798be92434b79d985a2..549ff4aab0f7b080c896b8ba2246889ddf114b63 100644 --- a/src/mol-geo/representation/structure/visual/element-point.ts +++ b/src/mol-geo/representation/structure/visual/element-point.ts @@ -75,6 +75,7 @@ export function ElementPointVisual(): UnitsVisual<ElementPointProps> { vertices = await createElementPointVertices(ctx, unit, vertices) renderObject = await createUnitsPointRenderObject(ctx, group, vertices, locationIt, currentProps) + console.log(renderObject) } else if (renderObject) { if (group) currentGroup = group diff --git a/src/mol-geo/representation/structure/visual/inter-unit-link-cylinder.ts b/src/mol-geo/representation/structure/visual/inter-unit-link-cylinder.ts index 813da2a3b9ce6864298fe0e8424972e05ab97b7a..44469dacff2b8bc4587e8cdb89ce9da3a15b4bff 100644 --- a/src/mol-geo/representation/structure/visual/inter-unit-link-cylinder.ts +++ b/src/mol-geo/representation/structure/visual/inter-unit-link-cylinder.ts @@ -51,6 +51,7 @@ async function createInterUnitLinkCylinderMesh(ctx: RuntimeContext, structure: S export const DefaultInterUnitLinkProps = { ...DefaultComplexMeshProps, ...DefaultLinkCylinderProps, + sizeTheme: { name: 'physical', factor: 0.3 } as SizeThemeProps, } export type InterUnitLinkProps = typeof DefaultInterUnitLinkProps diff --git a/src/mol-geo/representation/structure/visual/intra-unit-link-cylinder.ts b/src/mol-geo/representation/structure/visual/intra-unit-link-cylinder.ts index bf3e964bc6788f9b2f36e47324de31e147e6eb40..f5934887e2d1b7ad553c3a252a33cea1f92f863e 100644 --- a/src/mol-geo/representation/structure/visual/intra-unit-link-cylinder.ts +++ b/src/mol-geo/representation/structure/visual/intra-unit-link-cylinder.ts @@ -65,6 +65,7 @@ async function createIntraUnitLinkCylinderMesh(ctx: RuntimeContext, unit: Unit, export const DefaultIntraUnitLinkProps = { ...DefaultUnitsMeshProps, ...DefaultLinkCylinderProps, + sizeTheme: { name: 'physical', factor: 0.3 } as SizeThemeProps, } export type IntraUnitLinkProps = typeof DefaultIntraUnitLinkProps diff --git a/src/mol-geo/representation/util.ts b/src/mol-geo/representation/util.ts index 7d548d60dde519c45b691f4cc571f4b007cddf95..50c795ce0dc16d2a39dd6eb9e36ed6e50b389d92 100644 --- a/src/mol-geo/representation/util.ts +++ b/src/mol-geo/representation/util.ts @@ -14,7 +14,7 @@ export const DefaultBaseProps = { alpha: 1, visible: true, depthMask: true, - useFog: true, + useFog: false, quality: 'auto' as VisualQuality } export type BaseProps = typeof DefaultBaseProps diff --git a/src/mol-geo/representation/volume/index.ts b/src/mol-geo/representation/volume/index.ts index 588712d7a14236ae6bb3aaa5b17c23a020bad02d..5f3234dcbaca949311962fc458ed057cb51421e0 100644 --- a/src/mol-geo/representation/volume/index.ts +++ b/src/mol-geo/representation/volume/index.ts @@ -42,6 +42,7 @@ export function VolumeRepresentation<P extends VolumeProps>(visualCtor: (volumeD } return { + label: 'Volume mesh', get renderObjects () { return renderObjects }, get props () { return _props }, createOrUpdate,