clipping-data.ts 4.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /**
  2. * Copyright (c) 2020-2021 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  5. */
  6. import { ValueCell } from '../../mol-util/value-cell';
  7. import { Vec2 } from '../../mol-math/linear-algebra';
  8. import { TextureImage, createTextureImage } from '../../mol-gl/renderable/util';
  9. import { Clipping } from '../../mol-theme/clipping';
  10. export type ClippingData = {
  11. dClipObjectCount: ValueCell<number>,
  12. dClipVariant: ValueCell<string>,
  13. tClipping: ValueCell<TextureImage<Uint8Array>>
  14. uClippingTexDim: ValueCell<Vec2>
  15. dClipping: ValueCell<boolean>,
  16. uClipObjectType: ValueCell<number[]>,
  17. uClipObjectInvert: ValueCell<boolean[]>,
  18. uClipObjectPosition: ValueCell<number[]>,
  19. uClipObjectRotation: ValueCell<number[]>,
  20. uClipObjectScale: ValueCell<number[]>,
  21. }
  22. export function applyClippingGroups(array: Uint8Array, start: number, end: number, groups: Clipping.Groups) {
  23. array.fill(groups, start, end);
  24. return true;
  25. }
  26. export function clearClipping(array: Uint8Array, start: number, end: number) {
  27. array.fill(0, start, end);
  28. }
  29. export function createClipping(count: number, variant: Clipping.Variant, objects: Clipping.Objects, clippingData?: ClippingData): ClippingData {
  30. const clipping = createTextureImage(Math.max(1, count), 1, Uint8Array, clippingData && clippingData.tClipping.ref.value.array);
  31. if (clippingData) {
  32. ValueCell.update(clippingData.dClipObjectCount, objects.count);
  33. ValueCell.update(clippingData.dClipVariant, variant);
  34. ValueCell.update(clippingData.tClipping, clipping);
  35. ValueCell.update(clippingData.uClippingTexDim, Vec2.create(clipping.width, clipping.height));
  36. ValueCell.updateIfChanged(clippingData.dClipping, count > 0);
  37. ValueCell.update(clippingData.uClipObjectType, objects.type);
  38. ValueCell.update(clippingData.uClipObjectInvert, objects.invert);
  39. ValueCell.update(clippingData.uClipObjectPosition, objects.position);
  40. ValueCell.update(clippingData.uClipObjectRotation, objects.rotation);
  41. ValueCell.update(clippingData.uClipObjectScale, objects.scale);
  42. return clippingData;
  43. } else {
  44. return {
  45. dClipObjectCount: ValueCell.create(objects.count),
  46. dClipVariant: ValueCell.create(variant),
  47. tClipping: ValueCell.create(clipping),
  48. uClippingTexDim: ValueCell.create(Vec2.create(clipping.width, clipping.height)),
  49. dClipping: ValueCell.create(count > 0),
  50. uClipObjectType: ValueCell.create(objects.type),
  51. uClipObjectInvert: ValueCell.create(objects.invert),
  52. uClipObjectPosition: ValueCell.create(objects.position),
  53. uClipObjectRotation: ValueCell.create(objects.rotation),
  54. uClipObjectScale: ValueCell.create(objects.scale),
  55. };
  56. }
  57. }
  58. const emptyClippingTexture = { array: new Uint8Array(1), width: 1, height: 1 };
  59. export function createEmptyClipping(clippingData?: ClippingData): ClippingData {
  60. if (clippingData) {
  61. ValueCell.update(clippingData.dClipObjectCount, 0);
  62. ValueCell.update(clippingData.tClipping, emptyClippingTexture);
  63. ValueCell.update(clippingData.uClippingTexDim, Vec2.create(1, 1));
  64. ValueCell.updateIfChanged(clippingData.dClipping, false);
  65. return clippingData;
  66. } else {
  67. const { objects, variant } = Clipping.Empty;
  68. return {
  69. dClipObjectCount: ValueCell.create(0),
  70. dClipVariant: ValueCell.create(variant),
  71. tClipping: ValueCell.create(emptyClippingTexture),
  72. uClippingTexDim: ValueCell.create(Vec2.create(1, 1)),
  73. dClipping: ValueCell.create(false),
  74. uClipObjectType: ValueCell.create(objects.type),
  75. uClipObjectInvert: ValueCell.create(objects.invert),
  76. uClipObjectPosition: ValueCell.create(objects.position),
  77. uClipObjectRotation: ValueCell.create(objects.rotation),
  78. uClipObjectScale: ValueCell.create(objects.scale),
  79. };
  80. }
  81. }