clipping-data.ts 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  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. tClipping: ValueCell<TextureImage<Uint8Array>>
  12. uClippingTexDim: ValueCell<Vec2>
  13. dClipping: ValueCell<boolean>,
  14. }
  15. export function applyClippingGroups(array: Uint8Array, start: number, end: number, groups: Clipping.Groups) {
  16. array.fill(groups, start, end);
  17. return true;
  18. }
  19. export function clearClipping(array: Uint8Array, start: number, end: number) {
  20. array.fill(0, start, end);
  21. }
  22. export function createClipping(count: number, clippingData?: ClippingData): ClippingData {
  23. const clipping = createTextureImage(Math.max(1, count), 1, Uint8Array, clippingData && clippingData.tClipping.ref.value.array);
  24. if (clippingData) {
  25. ValueCell.update(clippingData.tClipping, clipping);
  26. ValueCell.update(clippingData.uClippingTexDim, Vec2.create(clipping.width, clipping.height));
  27. ValueCell.updateIfChanged(clippingData.dClipping, count > 0);
  28. return clippingData;
  29. } else {
  30. return {
  31. tClipping: ValueCell.create(clipping),
  32. uClippingTexDim: ValueCell.create(Vec2.create(clipping.width, clipping.height)),
  33. dClipping: ValueCell.create(count > 0),
  34. };
  35. }
  36. }
  37. const emptyClippingTexture = { array: new Uint8Array(1), width: 1, height: 1 };
  38. export function createEmptyClipping(clippingData?: ClippingData): ClippingData {
  39. if (clippingData) {
  40. ValueCell.update(clippingData.tClipping, emptyClippingTexture);
  41. ValueCell.update(clippingData.uClippingTexDim, Vec2.create(1, 1));
  42. ValueCell.updateIfChanged(clippingData.dClipping, false);
  43. return clippingData;
  44. } else {
  45. return {
  46. tClipping: ValueCell.create(emptyClippingTexture),
  47. uClippingTexDim: ValueCell.create(Vec2.create(1, 1)),
  48. dClipping: ValueCell.create(false),
  49. };
  50. }
  51. }