cross-link.ts 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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 { Link } from 'mol-model/structure';
  7. import { Color, ColorScale } from 'mol-util/color';
  8. import { Location } from 'mol-model/location';
  9. import { ColorTheme, LocationColor } from '../color';
  10. import { Vec3 } from 'mol-math/linear-algebra';
  11. import { ParamDefinition as PD } from 'mol-util/param-definition'
  12. import { ThemeDataContext } from 'mol-theme/theme';
  13. import { ColorListName, ColorListOptions } from 'mol-util/color/scale';
  14. const DefaultColor = Color(0xCCCCCC)
  15. const Description = 'Colors cross-links by the deviation of the observed distance versus the modeled distance (e.g. `ihm_cross_link_restraint.distance_threshold`).'
  16. export const CrossLinkColorThemeParams = {
  17. domain: PD.Interval([-10, 10]),
  18. list: PD.Select<ColorListName>('RdYlBu', ColorListOptions),
  19. }
  20. export type CrossLinkColorThemeParams = typeof CrossLinkColorThemeParams
  21. export function getCrossLinkColorThemeParams(ctx: ThemeDataContext) {
  22. return CrossLinkColorThemeParams // TODO return copy
  23. }
  24. const distVecA = Vec3.zero(), distVecB = Vec3.zero()
  25. function linkDistance(link: Link.Location) {
  26. link.aUnit.conformation.position(link.aUnit.elements[link.aIndex], distVecA)
  27. link.bUnit.conformation.position(link.bUnit.elements[link.bIndex], distVecB)
  28. return Vec3.distance(distVecA, distVecB)
  29. }
  30. export function CrossLinkColorTheme(ctx: ThemeDataContext, props: PD.Values<CrossLinkColorThemeParams>): ColorTheme<CrossLinkColorThemeParams> {
  31. let color: LocationColor
  32. let scale: ColorScale | undefined = undefined
  33. if (ctx.structure) {
  34. const crosslinks = ctx.structure.crossLinkRestraints
  35. scale = ColorScale.create({
  36. domain: props.domain,
  37. listOrName: props.list
  38. })
  39. const scaleColor = scale.color
  40. color = (location: Location): Color => {
  41. if (Link.isLocation(location)) {
  42. const pairs = crosslinks.getPairs(location.aIndex, location.aUnit, location.bIndex, location.bUnit)
  43. if (pairs) {
  44. return scaleColor(linkDistance(location) - pairs[0].distanceThreshold)
  45. }
  46. }
  47. return DefaultColor
  48. }
  49. } else {
  50. color = () => DefaultColor
  51. }
  52. return {
  53. factory: CrossLinkColorTheme,
  54. granularity: 'group',
  55. color,
  56. props,
  57. description: Description,
  58. legend: scale ? scale.legend : undefined
  59. }
  60. }
  61. export const CrossLinkColorThemeProvider: ColorTheme.Provider<CrossLinkColorThemeParams> = {
  62. label: 'Cross Link',
  63. factory: CrossLinkColorTheme,
  64. getParams: getCrossLinkColorThemeParams,
  65. defaultValues: PD.getDefaultValues(CrossLinkColorThemeParams)
  66. }